Initial commit
This commit is contained in:
159
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/CHANGELOG.md
vendored
Normal file
159
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/CHANGELOG.md
vendored
Normal file
@ -0,0 +1,159 @@
|
||||
## [3.1.7](https://github.com/Codeinwp/themeisle-sdk/compare/v3.1.6...v3.1.7) (2019-11-07)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* license field style on wp5.3 ([0239997](https://github.com/Codeinwp/themeisle-sdk/commit/0239997))
|
||||
* license field style on wp5.3 ([86d3a1b](https://github.com/Codeinwp/themeisle-sdk/commit/86d3a1b))
|
||||
|
||||
## [3.1.6](https://github.com/Codeinwp/themeisle-sdk/compare/v3.1.5...v3.1.6) (2019-09-24)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* remove license related options when deactivated ([02cd6ce](https://github.com/Codeinwp/themeisle-sdk/commit/02cd6ce))
|
||||
* remove license related options when deactivated ([d3c1a1f](https://github.com/Codeinwp/themeisle-sdk/commit/d3c1a1f))
|
||||
|
||||
## [3.1.5](https://github.com/Codeinwp/themeisle-sdk/compare/v3.1.4...v3.1.5) (2019-09-11)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* allow unloading certain module features ([2a2559a](https://github.com/Codeinwp/themeisle-sdk/commit/2a2559a))
|
||||
* license activation workflow, show error message when failed to a… ([ade795c](https://github.com/Codeinwp/themeisle-sdk/commit/ade795c))
|
||||
* license activation workflow, show error message when failed to activate ([2f5cbae](https://github.com/Codeinwp/themeisle-sdk/commit/2f5cbae))
|
||||
|
||||
## [3.1.4](https://github.com/Codeinwp/themeisle-sdk/compare/v3.1.3...v3.1.4) (2019-08-23)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* license key was missing on get_version call ([365cde6](https://github.com/Codeinwp/themeisle-sdk/commit/365cde6))
|
||||
* license key was missing on get_version call ([c02f225](https://github.com/Codeinwp/themeisle-sdk/commit/c02f225))
|
||||
|
||||
## [3.1.3](https://github.com/Codeinwp/themeisle-sdk/compare/v3.1.2...v3.1.3) (2019-08-20)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* license deactivation behaviour https://github.com/Codeinwp/visua… ([59c4afe](https://github.com/Codeinwp/themeisle-sdk/commit/59c4afe))
|
||||
* license deactivation behaviour https://github.com/Codeinwp/visualizer-pro/issues/192 ([f641e18](https://github.com/Codeinwp/themeisle-sdk/commit/f641e18))
|
||||
|
||||
## [3.1.2](https://github.com/Codeinwp/themeisle-sdk/compare/v3.1.1...v3.1.2) (2019-08-12)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* phpunit test case ([efe851c](https://github.com/Codeinwp/themeisle-sdk/commit/efe851c))
|
||||
* url format for license endpoint, improve changelog handling and license checks ([a492c68](https://github.com/Codeinwp/themeisle-sdk/commit/a492c68))
|
||||
|
||||
## [3.1.1](https://github.com/Codeinwp/themeisle-sdk/compare/v3.1.0...v3.1.1) (2019-08-08)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* adds is_file for file existence check ([d1205c4](https://github.com/Codeinwp/themeisle-sdk/commit/d1205c4))
|
||||
* adds is_file for file existence check ([be119c1](https://github.com/Codeinwp/themeisle-sdk/commit/be119c1))
|
||||
|
||||
# [3.1.0](https://github.com/Codeinwp/themeisle-sdk/compare/v3.0.10...v3.1.0) (2019-08-05)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* adds extra comments for rest of the options, fix [#64](https://github.com/Codeinwp/themeisle-sdk/issues/64) ([018b22f](https://github.com/Codeinwp/themeisle-sdk/commit/018b22f))
|
||||
* hide license key when active under a password mask, fix [#67](https://github.com/Codeinwp/themeisle-sdk/issues/67) ([c0633c2](https://github.com/Codeinwp/themeisle-sdk/commit/c0633c2))
|
||||
* new uninstall feedback popup issues ([5bda4bd](https://github.com/Codeinwp/themeisle-sdk/commit/5bda4bd))
|
||||
* phpcs indentation errors ([d59ed4f](https://github.com/Codeinwp/themeisle-sdk/commit/d59ed4f))
|
||||
* undefined notices on license check, fix [#60](https://github.com/Codeinwp/themeisle-sdk/issues/60) ([7f56a97](https://github.com/Codeinwp/themeisle-sdk/commit/7f56a97))
|
||||
* uninstall feedback popup placement [[#61](https://github.com/Codeinwp/themeisle-sdk/issues/61)] ([1102d6c](https://github.com/Codeinwp/themeisle-sdk/commit/1102d6c))
|
||||
|
||||
|
||||
### Features
|
||||
|
||||
* new product feedback popup ([f0dbab3](https://github.com/Codeinwp/themeisle-sdk/commit/f0dbab3))
|
||||
* new uninstall feedback form for themes ([8a29f21](https://github.com/Codeinwp/themeisle-sdk/commit/8a29f21))
|
||||
|
||||
## [3.0.10](https://github.com/Codeinwp/themeisle-sdk/compare/v3.0.9...v3.0.10) (2019-07-16)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* compatibility with lower PHP versions ([065ac8e](https://github.com/Codeinwp/themeisle-sdk/commit/065ac8e))
|
||||
* not loading licenser when SDK comes from theme [[#62](https://github.com/Codeinwp/themeisle-sdk/issues/62)] ([b706ca7](https://github.com/Codeinwp/themeisle-sdk/commit/b706ca7))
|
||||
* not loading licenser when SDK comes from theme [[#65](https://github.com/Codeinwp/themeisle-sdk/issues/65) ([419d8e6](https://github.com/Codeinwp/themeisle-sdk/commit/419d8e6))
|
||||
* preserve loaded when adding the licenser one ([cd50434](https://github.com/Codeinwp/themeisle-sdk/commit/cd50434))
|
||||
|
||||
## [3.0.9](https://github.com/Codeinwp/themeisle-sdk/compare/v3.0.8...v3.0.9) (2019-06-26)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* adds new icon for dashboard widget ([de78068](https://github.com/Codeinwp/themeisle-sdk/commit/de78068))
|
||||
* anchor element on license activation message which should link to the license field, fix [#57](https://github.com/Codeinwp/themeisle-sdk/issues/57) ([2e78856](https://github.com/Codeinwp/themeisle-sdk/commit/2e78856))
|
||||
* change uninstall feedback logo with new version, fix [#58](https://github.com/Codeinwp/themeisle-sdk/issues/58) ([2554a4f](https://github.com/Codeinwp/themeisle-sdk/commit/2554a4f))
|
||||
* remove soon to expire notice, fix https://github.com/Codeinwp/themeisle/issues/752 ([a126225](https://github.com/Codeinwp/themeisle-sdk/commit/a126225))
|
||||
|
||||
## [3.0.8](https://github.com/Codeinwp/themeisle-sdk/compare/v3.0.7...v3.0.8) (2019-05-28)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* undefined class on diff module which should check the class on global namespace ([df6bb12](https://github.com/Codeinwp/themeisle-sdk/commit/df6bb12))
|
||||
|
||||
## [3.0.7](https://github.com/Codeinwp/themeisle-sdk/compare/v3.0.6...v3.0.7) (2019-05-27)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* change store url with the new domain ([6bdbe1e](https://github.com/Codeinwp/themeisle-sdk/commit/6bdbe1e))
|
||||
|
||||
## [3.0.6](https://github.com/Codeinwp/themeisle-sdk/compare/v3.0.5...v3.0.6) (2019-05-21)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* build php version for deployment stage ([a785699](https://github.com/Codeinwp/themeisle-sdk/commit/a785699))
|
||||
* uninstall feedback should load only on the proper pages ([259e78f](https://github.com/Codeinwp/themeisle-sdk/commit/259e78f))
|
||||
|
||||
## [3.0.5](https://github.com/Codeinwp/themeisle-sdk/compare/v3.0.4...v3.0.5) (2019-03-07)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* dashboard widget issues and recommended module inconsistency fix [#50](https://github.com/Codeinwp/themeisle-sdk/issues/50), [#49](https://github.com/Codeinwp/themeisle-sdk/issues/49), [#47](https://github.com/Codeinwp/themeisle-sdk/issues/47) ([757eb02](https://github.com/Codeinwp/themeisle-sdk/commit/757eb02))
|
||||
|
||||
## [3.0.4](https://github.com/Codeinwp/themeisle-sdk/compare/v3.0.3...v3.0.4) (2019-01-28)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* uninstall feedback disclosure issues when one of the feedback fields is open ([4631eef](https://github.com/Codeinwp/themeisle-sdk/commit/4631eef))
|
||||
|
||||
## [3.0.3](https://github.com/Codeinwp/themeisle-sdk/compare/v3.0.2...v3.0.3) (2019-01-07)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* **build:** fix exit code when is running outside wordpress context ([d298bb5](https://github.com/Codeinwp/themeisle-sdk/commit/d298bb5))
|
||||
|
||||
## [3.0.2](https://github.com/Codeinwp/themeisle-sdk/compare/v3.0.1...v3.0.2) (2018-12-28)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* remove composer/installers from package requirements ([a0ad543](https://github.com/Codeinwp/themeisle-sdk/commit/a0ad543))
|
||||
|
||||
## [3.0.1](https://github.com/Codeinwp/themeisle-sdk/compare/v3.0.0...v3.0.1) (2018-12-24)
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* notifications setup triggers after all products register their n… ([999a944](https://github.com/Codeinwp/themeisle-sdk/commit/999a944))
|
||||
* notifications setup triggers after all products register their notices ([ec3cacc](https://github.com/Codeinwp/themeisle-sdk/commit/ec3cacc))
|
||||
|
||||
# 1.0.0 (2018-12-21)
|
||||
|
||||
|
||||
### Features
|
||||
|
||||
* adds uninstall feedback privacy policy info ([ed17943](https://github.com/Codeinwp/themeisle-sdk/commit/ed17943))
|
674
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/LICENSE
vendored
Normal file
674
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/LICENSE
vendored
Normal file
@ -0,0 +1,674 @@
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
Version 3, 29 June 2007
|
||||
|
||||
Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
|
||||
Everyone is permitted to copy and distribute verbatim copies
|
||||
of this license document, but changing it is not allowed.
|
||||
|
||||
Preamble
|
||||
|
||||
The GNU General Public License is a free, copyleft license for
|
||||
software and other kinds of works.
|
||||
|
||||
The licenses for most software and other practical works are designed
|
||||
to take away your freedom to share and change the works. By contrast,
|
||||
the GNU General Public License is intended to guarantee your freedom to
|
||||
share and change all versions of a program--to make sure it remains free
|
||||
software for all its users. We, the Free Software Foundation, use the
|
||||
GNU General Public License for most of our software; it applies also to
|
||||
any other work released this way by its authors. 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
|
||||
them 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 prevent others from denying you
|
||||
these rights or asking you to surrender the rights. Therefore, you have
|
||||
certain responsibilities if you distribute copies of the software, or if
|
||||
you modify it: responsibilities to respect the freedom of others.
|
||||
|
||||
For example, if you distribute copies of such a program, whether
|
||||
gratis or for a fee, you must pass on to the recipients the same
|
||||
freedoms that you received. 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.
|
||||
|
||||
Developers that use the GNU GPL protect your rights with two steps:
|
||||
(1) assert copyright on the software, and (2) offer you this License
|
||||
giving you legal permission to copy, distribute and/or modify it.
|
||||
|
||||
For the developers' and authors' protection, the GPL clearly explains
|
||||
that there is no warranty for this free software. For both users' and
|
||||
authors' sake, the GPL requires that modified versions be marked as
|
||||
changed, so that their problems will not be attributed erroneously to
|
||||
authors of previous versions.
|
||||
|
||||
Some devices are designed to deny users access to install or run
|
||||
modified versions of the software inside them, although the manufacturer
|
||||
can do so. This is fundamentally incompatible with the aim of
|
||||
protecting users' freedom to change the software. The systematic
|
||||
pattern of such abuse occurs in the area of products for individuals to
|
||||
use, which is precisely where it is most unacceptable. Therefore, we
|
||||
have designed this version of the GPL to prohibit the practice for those
|
||||
products. If such problems arise substantially in other domains, we
|
||||
stand ready to extend this provision to those domains in future versions
|
||||
of the GPL, as needed to protect the freedom of users.
|
||||
|
||||
Finally, every program is threatened constantly by software patents.
|
||||
States should not allow patents to restrict development and use of
|
||||
software on general-purpose computers, but in those that do, we wish to
|
||||
avoid the special danger that patents applied to a free program could
|
||||
make it effectively proprietary. To prevent this, the GPL assures that
|
||||
patents cannot be used to render the program non-free.
|
||||
|
||||
The precise terms and conditions for copying, distribution and
|
||||
modification follow.
|
||||
|
||||
TERMS AND CONDITIONS
|
||||
|
||||
0. Definitions.
|
||||
|
||||
"This License" refers to version 3 of the GNU General Public License.
|
||||
|
||||
"Copyright" also means copyright-like laws that apply to other kinds of
|
||||
works, such as semiconductor masks.
|
||||
|
||||
"The Program" refers to any copyrightable work licensed under this
|
||||
License. Each licensee is addressed as "you". "Licensees" and
|
||||
"recipients" may be individuals or organizations.
|
||||
|
||||
To "modify" a work means to copy from or adapt all or part of the work
|
||||
in a fashion requiring copyright permission, other than the making of an
|
||||
exact copy. The resulting work is called a "modified version" of the
|
||||
earlier work or a work "based on" the earlier work.
|
||||
|
||||
A "covered work" means either the unmodified Program or a work based
|
||||
on the Program.
|
||||
|
||||
To "propagate" a work means to do anything with it that, without
|
||||
permission, would make you directly or secondarily liable for
|
||||
infringement under applicable copyright law, except executing it on a
|
||||
computer or modifying a private copy. Propagation includes copying,
|
||||
distribution (with or without modification), making available to the
|
||||
public, and in some countries other activities as well.
|
||||
|
||||
To "convey" a work means any kind of propagation that enables other
|
||||
parties to make or receive copies. Mere interaction with a user through
|
||||
a computer network, with no transfer of a copy, is not conveying.
|
||||
|
||||
An interactive user interface displays "Appropriate Legal Notices"
|
||||
to the extent that it includes a convenient and prominently visible
|
||||
feature that (1) displays an appropriate copyright notice, and (2)
|
||||
tells the user that there is no warranty for the work (except to the
|
||||
extent that warranties are provided), that licensees may convey the
|
||||
work under this License, and how to view a copy of this License. If
|
||||
the interface presents a list of user commands or options, such as a
|
||||
menu, a prominent item in the list meets this criterion.
|
||||
|
||||
1. Source Code.
|
||||
|
||||
The "source code" for a work means the preferred form of the work
|
||||
for making modifications to it. "Object code" means any non-source
|
||||
form of a work.
|
||||
|
||||
A "Standard Interface" means an interface that either is an official
|
||||
standard defined by a recognized standards body, or, in the case of
|
||||
interfaces specified for a particular programming language, one that
|
||||
is widely used among developers working in that language.
|
||||
|
||||
The "System Libraries" of an executable work include anything, other
|
||||
than the work as a whole, that (a) is included in the normal form of
|
||||
packaging a Major Component, but which is not part of that Major
|
||||
Component, and (b) serves only to enable use of the work with that
|
||||
Major Component, or to implement a Standard Interface for which an
|
||||
implementation is available to the public in source code form. A
|
||||
"Major Component", in this context, means a major essential component
|
||||
(kernel, window system, and so on) of the specific operating system
|
||||
(if any) on which the executable work runs, or a compiler used to
|
||||
produce the work, or an object code interpreter used to run it.
|
||||
|
||||
The "Corresponding Source" for a work in object code form means all
|
||||
the source code needed to generate, install, and (for an executable
|
||||
work) run the object code and to modify the work, including scripts to
|
||||
control those activities. However, it does not include the work's
|
||||
System Libraries, or general-purpose tools or generally available free
|
||||
programs which are used unmodified in performing those activities but
|
||||
which are not part of the work. For example, Corresponding Source
|
||||
includes interface definition files associated with source files for
|
||||
the work, and the source code for shared libraries and dynamically
|
||||
linked subprograms that the work is specifically designed to require,
|
||||
such as by intimate data communication or control flow between those
|
||||
subprograms and other parts of the work.
|
||||
|
||||
The Corresponding Source need not include anything that users
|
||||
can regenerate automatically from other parts of the Corresponding
|
||||
Source.
|
||||
|
||||
The Corresponding Source for a work in source code form is that
|
||||
same work.
|
||||
|
||||
2. Basic Permissions.
|
||||
|
||||
All rights granted under this License are granted for the term of
|
||||
copyright on the Program, and are irrevocable provided the stated
|
||||
conditions are met. This License explicitly affirms your unlimited
|
||||
permission to run the unmodified Program. The output from running a
|
||||
covered work is covered by this License only if the output, given its
|
||||
content, constitutes a covered work. This License acknowledges your
|
||||
rights of fair use or other equivalent, as provided by copyright law.
|
||||
|
||||
You may make, run and propagate covered works that you do not
|
||||
convey, without conditions so long as your license otherwise remains
|
||||
in force. You may convey covered works to others for the sole purpose
|
||||
of having them make modifications exclusively for you, or provide you
|
||||
with facilities for running those works, provided that you comply with
|
||||
the terms of this License in conveying all material for which you do
|
||||
not control copyright. Those thus making or running the covered works
|
||||
for you must do so exclusively on your behalf, under your direction
|
||||
and control, on terms that prohibit them from making any copies of
|
||||
your copyrighted material outside their relationship with you.
|
||||
|
||||
Conveying under any other circumstances is permitted solely under
|
||||
the conditions stated below. Sublicensing is not allowed; section 10
|
||||
makes it unnecessary.
|
||||
|
||||
3. Protecting Users' Legal Rights From Anti-Circumvention Law.
|
||||
|
||||
No covered work shall be deemed part of an effective technological
|
||||
measure under any applicable law fulfilling obligations under article
|
||||
11 of the WIPO copyright treaty adopted on 20 December 1996, or
|
||||
similar laws prohibiting or restricting circumvention of such
|
||||
measures.
|
||||
|
||||
When you convey a covered work, you waive any legal power to forbid
|
||||
circumvention of technological measures to the extent such circumvention
|
||||
is effected by exercising rights under this License with respect to
|
||||
the covered work, and you disclaim any intention to limit operation or
|
||||
modification of the work as a means of enforcing, against the work's
|
||||
users, your or third parties' legal rights to forbid circumvention of
|
||||
technological measures.
|
||||
|
||||
4. Conveying Verbatim Copies.
|
||||
|
||||
You may convey 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;
|
||||
keep intact all notices stating that this License and any
|
||||
non-permissive terms added in accord with section 7 apply to the code;
|
||||
keep intact all notices of the absence of any warranty; and give all
|
||||
recipients a copy of this License along with the Program.
|
||||
|
||||
You may charge any price or no price for each copy that you convey,
|
||||
and you may offer support or warranty protection for a fee.
|
||||
|
||||
5. Conveying Modified Source Versions.
|
||||
|
||||
You may convey a work based on the Program, or the modifications to
|
||||
produce it from the Program, in the form of source code under the
|
||||
terms of section 4, provided that you also meet all of these conditions:
|
||||
|
||||
a) The work must carry prominent notices stating that you modified
|
||||
it, and giving a relevant date.
|
||||
|
||||
b) The work must carry prominent notices stating that it is
|
||||
released under this License and any conditions added under section
|
||||
7. This requirement modifies the requirement in section 4 to
|
||||
"keep intact all notices".
|
||||
|
||||
c) You must license the entire work, as a whole, under this
|
||||
License to anyone who comes into possession of a copy. This
|
||||
License will therefore apply, along with any applicable section 7
|
||||
additional terms, to the whole of the work, and all its parts,
|
||||
regardless of how they are packaged. This License gives no
|
||||
permission to license the work in any other way, but it does not
|
||||
invalidate such permission if you have separately received it.
|
||||
|
||||
d) If the work has interactive user interfaces, each must display
|
||||
Appropriate Legal Notices; however, if the Program has interactive
|
||||
interfaces that do not display Appropriate Legal Notices, your
|
||||
work need not make them do so.
|
||||
|
||||
A compilation of a covered work with other separate and independent
|
||||
works, which are not by their nature extensions of the covered work,
|
||||
and which are not combined with it such as to form a larger program,
|
||||
in or on a volume of a storage or distribution medium, is called an
|
||||
"aggregate" if the compilation and its resulting copyright are not
|
||||
used to limit the access or legal rights of the compilation's users
|
||||
beyond what the individual works permit. Inclusion of a covered work
|
||||
in an aggregate does not cause this License to apply to the other
|
||||
parts of the aggregate.
|
||||
|
||||
6. Conveying Non-Source Forms.
|
||||
|
||||
You may convey a covered work in object code form under the terms
|
||||
of sections 4 and 5, provided that you also convey the
|
||||
machine-readable Corresponding Source under the terms of this License,
|
||||
in one of these ways:
|
||||
|
||||
a) Convey the object code in, or embodied in, a physical product
|
||||
(including a physical distribution medium), accompanied by the
|
||||
Corresponding Source fixed on a durable physical medium
|
||||
customarily used for software interchange.
|
||||
|
||||
b) Convey the object code in, or embodied in, a physical product
|
||||
(including a physical distribution medium), accompanied by a
|
||||
written offer, valid for at least three years and valid for as
|
||||
long as you offer spare parts or customer support for that product
|
||||
model, to give anyone who possesses the object code either (1) a
|
||||
copy of the Corresponding Source for all the software in the
|
||||
product that is covered by this License, on a durable physical
|
||||
medium customarily used for software interchange, for a price no
|
||||
more than your reasonable cost of physically performing this
|
||||
conveying of source, or (2) access to copy the
|
||||
Corresponding Source from a network server at no charge.
|
||||
|
||||
c) Convey individual copies of the object code with a copy of the
|
||||
written offer to provide the Corresponding Source. This
|
||||
alternative is allowed only occasionally and noncommercially, and
|
||||
only if you received the object code with such an offer, in accord
|
||||
with subsection 6b.
|
||||
|
||||
d) Convey the object code by offering access from a designated
|
||||
place (gratis or for a charge), and offer equivalent access to the
|
||||
Corresponding Source in the same way through the same place at no
|
||||
further charge. You need not require recipients to copy the
|
||||
Corresponding Source along with the object code. If the place to
|
||||
copy the object code is a network server, the Corresponding Source
|
||||
may be on a different server (operated by you or a third party)
|
||||
that supports equivalent copying facilities, provided you maintain
|
||||
clear directions next to the object code saying where to find the
|
||||
Corresponding Source. Regardless of what server hosts the
|
||||
Corresponding Source, you remain obligated to ensure that it is
|
||||
available for as long as needed to satisfy these requirements.
|
||||
|
||||
e) Convey the object code using peer-to-peer transmission, provided
|
||||
you inform other peers where the object code and Corresponding
|
||||
Source of the work are being offered to the general public at no
|
||||
charge under subsection 6d.
|
||||
|
||||
A separable portion of the object code, whose source code is excluded
|
||||
from the Corresponding Source as a System Library, need not be
|
||||
included in conveying the object code work.
|
||||
|
||||
A "User Product" is either (1) a "consumer product", which means any
|
||||
tangible personal property which is normally used for personal, family,
|
||||
or household purposes, or (2) anything designed or sold for incorporation
|
||||
into a dwelling. In determining whether a product is a consumer product,
|
||||
doubtful cases shall be resolved in favor of coverage. For a particular
|
||||
product received by a particular user, "normally used" refers to a
|
||||
typical or common use of that class of product, regardless of the status
|
||||
of the particular user or of the way in which the particular user
|
||||
actually uses, or expects or is expected to use, the product. A product
|
||||
is a consumer product regardless of whether the product has substantial
|
||||
commercial, industrial or non-consumer uses, unless such uses represent
|
||||
the only significant mode of use of the product.
|
||||
|
||||
"Installation Information" for a User Product means any methods,
|
||||
procedures, authorization keys, or other information required to install
|
||||
and execute modified versions of a covered work in that User Product from
|
||||
a modified version of its Corresponding Source. The information must
|
||||
suffice to ensure that the continued functioning of the modified object
|
||||
code is in no case prevented or interfered with solely because
|
||||
modification has been made.
|
||||
|
||||
If you convey an object code work under this section in, or with, or
|
||||
specifically for use in, a User Product, and the conveying occurs as
|
||||
part of a transaction in which the right of possession and use of the
|
||||
User Product is transferred to the recipient in perpetuity or for a
|
||||
fixed term (regardless of how the transaction is characterized), the
|
||||
Corresponding Source conveyed under this section must be accompanied
|
||||
by the Installation Information. But this requirement does not apply
|
||||
if neither you nor any third party retains the ability to install
|
||||
modified object code on the User Product (for example, the work has
|
||||
been installed in ROM).
|
||||
|
||||
The requirement to provide Installation Information does not include a
|
||||
requirement to continue to provide support service, warranty, or updates
|
||||
for a work that has been modified or installed by the recipient, or for
|
||||
the User Product in which it has been modified or installed. Access to a
|
||||
network may be denied when the modification itself materially and
|
||||
adversely affects the operation of the network or violates the rules and
|
||||
protocols for communication across the network.
|
||||
|
||||
Corresponding Source conveyed, and Installation Information provided,
|
||||
in accord with this section must be in a format that is publicly
|
||||
documented (and with an implementation available to the public in
|
||||
source code form), and must require no special password or key for
|
||||
unpacking, reading or copying.
|
||||
|
||||
7. Additional Terms.
|
||||
|
||||
"Additional permissions" are terms that supplement the terms of this
|
||||
License by making exceptions from one or more of its conditions.
|
||||
Additional permissions that are applicable to the entire Program shall
|
||||
be treated as though they were included in this License, to the extent
|
||||
that they are valid under applicable law. If additional permissions
|
||||
apply only to part of the Program, that part may be used separately
|
||||
under those permissions, but the entire Program remains governed by
|
||||
this License without regard to the additional permissions.
|
||||
|
||||
When you convey a copy of a covered work, you may at your option
|
||||
remove any additional permissions from that copy, or from any part of
|
||||
it. (Additional permissions may be written to require their own
|
||||
removal in certain cases when you modify the work.) You may place
|
||||
additional permissions on material, added by you to a covered work,
|
||||
for which you have or can give appropriate copyright permission.
|
||||
|
||||
Notwithstanding any other provision of this License, for material you
|
||||
add to a covered work, you may (if authorized by the copyright holders of
|
||||
that material) supplement the terms of this License with terms:
|
||||
|
||||
a) Disclaiming warranty or limiting liability differently from the
|
||||
terms of sections 15 and 16 of this License; or
|
||||
|
||||
b) Requiring preservation of specified reasonable legal notices or
|
||||
author attributions in that material or in the Appropriate Legal
|
||||
Notices displayed by works containing it; or
|
||||
|
||||
c) Prohibiting misrepresentation of the origin of that material, or
|
||||
requiring that modified versions of such material be marked in
|
||||
reasonable ways as different from the original version; or
|
||||
|
||||
d) Limiting the use for publicity purposes of names of licensors or
|
||||
authors of the material; or
|
||||
|
||||
e) Declining to grant rights under trademark law for use of some
|
||||
trade names, trademarks, or service marks; or
|
||||
|
||||
f) Requiring indemnification of licensors and authors of that
|
||||
material by anyone who conveys the material (or modified versions of
|
||||
it) with contractual assumptions of liability to the recipient, for
|
||||
any liability that these contractual assumptions directly impose on
|
||||
those licensors and authors.
|
||||
|
||||
All other non-permissive additional terms are considered "further
|
||||
restrictions" within the meaning of section 10. If the Program as you
|
||||
received it, or any part of it, contains a notice stating that it is
|
||||
governed by this License along with a term that is a further
|
||||
restriction, you may remove that term. If a license document contains
|
||||
a further restriction but permits relicensing or conveying under this
|
||||
License, you may add to a covered work material governed by the terms
|
||||
of that license document, provided that the further restriction does
|
||||
not survive such relicensing or conveying.
|
||||
|
||||
If you add terms to a covered work in accord with this section, you
|
||||
must place, in the relevant source files, a statement of the
|
||||
additional terms that apply to those files, or a notice indicating
|
||||
where to find the applicable terms.
|
||||
|
||||
Additional terms, permissive or non-permissive, may be stated in the
|
||||
form of a separately written license, or stated as exceptions;
|
||||
the above requirements apply either way.
|
||||
|
||||
8. Termination.
|
||||
|
||||
You may not propagate or modify a covered work except as expressly
|
||||
provided under this License. Any attempt otherwise to propagate or
|
||||
modify it is void, and will automatically terminate your rights under
|
||||
this License (including any patent licenses granted under the third
|
||||
paragraph of section 11).
|
||||
|
||||
However, if you cease all violation of this License, then your
|
||||
license from a particular copyright holder is reinstated (a)
|
||||
provisionally, unless and until the copyright holder explicitly and
|
||||
finally terminates your license, and (b) permanently, if the copyright
|
||||
holder fails to notify you of the violation by some reasonable means
|
||||
prior to 60 days after the cessation.
|
||||
|
||||
Moreover, your license from a particular copyright holder is
|
||||
reinstated permanently if the copyright holder notifies you of the
|
||||
violation by some reasonable means, this is the first time you have
|
||||
received notice of violation of this License (for any work) from that
|
||||
copyright holder, and you cure the violation prior to 30 days after
|
||||
your receipt of the notice.
|
||||
|
||||
Termination of your rights under this section does not terminate the
|
||||
licenses of parties who have received copies or rights from you under
|
||||
this License. If your rights have been terminated and not permanently
|
||||
reinstated, you do not qualify to receive new licenses for the same
|
||||
material under section 10.
|
||||
|
||||
9. Acceptance Not Required for Having Copies.
|
||||
|
||||
You are not required to accept this License in order to receive or
|
||||
run a copy of the Program. Ancillary propagation of a covered work
|
||||
occurring solely as a consequence of using peer-to-peer transmission
|
||||
to receive a copy likewise does not require acceptance. However,
|
||||
nothing other than this License grants you permission to propagate or
|
||||
modify any covered work. These actions infringe copyright if you do
|
||||
not accept this License. Therefore, by modifying or propagating a
|
||||
covered work, you indicate your acceptance of this License to do so.
|
||||
|
||||
10. Automatic Licensing of Downstream Recipients.
|
||||
|
||||
Each time you convey a covered work, the recipient automatically
|
||||
receives a license from the original licensors, to run, modify and
|
||||
propagate that work, subject to this License. You are not responsible
|
||||
for enforcing compliance by third parties with this License.
|
||||
|
||||
An "entity transaction" is a transaction transferring control of an
|
||||
organization, or substantially all assets of one, or subdividing an
|
||||
organization, or merging organizations. If propagation of a covered
|
||||
work results from an entity transaction, each party to that
|
||||
transaction who receives a copy of the work also receives whatever
|
||||
licenses to the work the party's predecessor in interest had or could
|
||||
give under the previous paragraph, plus a right to possession of the
|
||||
Corresponding Source of the work from the predecessor in interest, if
|
||||
the predecessor has it or can get it with reasonable efforts.
|
||||
|
||||
You may not impose any further restrictions on the exercise of the
|
||||
rights granted or affirmed under this License. For example, you may
|
||||
not impose a license fee, royalty, or other charge for exercise of
|
||||
rights granted under this License, and you may not initiate litigation
|
||||
(including a cross-claim or counterclaim in a lawsuit) alleging that
|
||||
any patent claim is infringed by making, using, selling, offering for
|
||||
sale, or importing the Program or any portion of it.
|
||||
|
||||
11. Patents.
|
||||
|
||||
A "contributor" is a copyright holder who authorizes use under this
|
||||
License of the Program or a work on which the Program is based. The
|
||||
work thus licensed is called the contributor's "contributor version".
|
||||
|
||||
A contributor's "essential patent claims" are all patent claims
|
||||
owned or controlled by the contributor, whether already acquired or
|
||||
hereafter acquired, that would be infringed by some manner, permitted
|
||||
by this License, of making, using, or selling its contributor version,
|
||||
but do not include claims that would be infringed only as a
|
||||
consequence of further modification of the contributor version. For
|
||||
purposes of this definition, "control" includes the right to grant
|
||||
patent sublicenses in a manner consistent with the requirements of
|
||||
this License.
|
||||
|
||||
Each contributor grants you a non-exclusive, worldwide, royalty-free
|
||||
patent license under the contributor's essential patent claims, to
|
||||
make, use, sell, offer for sale, import and otherwise run, modify and
|
||||
propagate the contents of its contributor version.
|
||||
|
||||
In the following three paragraphs, a "patent license" is any express
|
||||
agreement or commitment, however denominated, not to enforce a patent
|
||||
(such as an express permission to practice a patent or covenant not to
|
||||
sue for patent infringement). To "grant" such a patent license to a
|
||||
party means to make such an agreement or commitment not to enforce a
|
||||
patent against the party.
|
||||
|
||||
If you convey a covered work, knowingly relying on a patent license,
|
||||
and the Corresponding Source of the work is not available for anyone
|
||||
to copy, free of charge and under the terms of this License, through a
|
||||
publicly available network server or other readily accessible means,
|
||||
then you must either (1) cause the Corresponding Source to be so
|
||||
available, or (2) arrange to deprive yourself of the benefit of the
|
||||
patent license for this particular work, or (3) arrange, in a manner
|
||||
consistent with the requirements of this License, to extend the patent
|
||||
license to downstream recipients. "Knowingly relying" means you have
|
||||
actual knowledge that, but for the patent license, your conveying the
|
||||
covered work in a country, or your recipient's use of the covered work
|
||||
in a country, would infringe one or more identifiable patents in that
|
||||
country that you have reason to believe are valid.
|
||||
|
||||
If, pursuant to or in connection with a single transaction or
|
||||
arrangement, you convey, or propagate by procuring conveyance of, a
|
||||
covered work, and grant a patent license to some of the parties
|
||||
receiving the covered work authorizing them to use, propagate, modify
|
||||
or convey a specific copy of the covered work, then the patent license
|
||||
you grant is automatically extended to all recipients of the covered
|
||||
work and works based on it.
|
||||
|
||||
A patent license is "discriminatory" if it does not include within
|
||||
the scope of its coverage, prohibits the exercise of, or is
|
||||
conditioned on the non-exercise of one or more of the rights that are
|
||||
specifically granted under this License. You may not convey a covered
|
||||
work if you are a party to an arrangement with a third party that is
|
||||
in the business of distributing software, under which you make payment
|
||||
to the third party based on the extent of your activity of conveying
|
||||
the work, and under which the third party grants, to any of the
|
||||
parties who would receive the covered work from you, a discriminatory
|
||||
patent license (a) in connection with copies of the covered work
|
||||
conveyed by you (or copies made from those copies), or (b) primarily
|
||||
for and in connection with specific products or compilations that
|
||||
contain the covered work, unless you entered into that arrangement,
|
||||
or that patent license was granted, prior to 28 March 2007.
|
||||
|
||||
Nothing in this License shall be construed as excluding or limiting
|
||||
any implied license or other defenses to infringement that may
|
||||
otherwise be available to you under applicable patent law.
|
||||
|
||||
12. No Surrender of Others' Freedom.
|
||||
|
||||
If 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 convey a
|
||||
covered work so as to satisfy simultaneously your obligations under this
|
||||
License and any other pertinent obligations, then as a consequence you may
|
||||
not convey it at all. For example, if you agree to terms that obligate you
|
||||
to collect a royalty for further conveying from those to whom you convey
|
||||
the Program, the only way you could satisfy both those terms and this
|
||||
License would be to refrain entirely from conveying the Program.
|
||||
|
||||
13. Use with the GNU Affero General Public License.
|
||||
|
||||
Notwithstanding any other provision of this License, you have
|
||||
permission to link or combine any covered work with a work licensed
|
||||
under version 3 of the GNU Affero General Public License into a single
|
||||
combined work, and to convey the resulting work. The terms of this
|
||||
License will continue to apply to the part which is the covered work,
|
||||
but the special requirements of the GNU Affero General Public License,
|
||||
section 13, concerning interaction through a network will apply to the
|
||||
combination as such.
|
||||
|
||||
14. Revised Versions of this License.
|
||||
|
||||
The Free Software Foundation may publish revised and/or new versions of
|
||||
the GNU 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 that a certain numbered version of the GNU General
|
||||
Public License "or any later version" applies to it, you have the
|
||||
option of following the terms and conditions either of that numbered
|
||||
version or of any later version published by the Free Software
|
||||
Foundation. If the Program does not specify a version number of the
|
||||
GNU General Public License, you may choose any version ever published
|
||||
by the Free Software Foundation.
|
||||
|
||||
If the Program specifies that a proxy can decide which future
|
||||
versions of the GNU General Public License can be used, that proxy's
|
||||
public statement of acceptance of a version permanently authorizes you
|
||||
to choose that version for the Program.
|
||||
|
||||
Later license versions may give you additional or different
|
||||
permissions. However, no additional obligations are imposed on any
|
||||
author or copyright holder as a result of your choosing to follow a
|
||||
later version.
|
||||
|
||||
15. Disclaimer of Warranty.
|
||||
|
||||
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.
|
||||
|
||||
16. Limitation of Liability.
|
||||
|
||||
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
|
||||
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.
|
||||
|
||||
17. Interpretation of Sections 15 and 16.
|
||||
|
||||
If the disclaimer of warranty and limitation of liability provided
|
||||
above cannot be given local legal effect according to their terms,
|
||||
reviewing courts shall apply local law that most closely approximates
|
||||
an absolute waiver of all civil liability in connection with the
|
||||
Program, unless a warranty or assumption of liability accompanies a
|
||||
copy of the Program in return for a fee.
|
||||
|
||||
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
|
||||
state the exclusion of warranty; and each file should have at least
|
||||
the "copyright" line and a pointer to where the full notice is found.
|
||||
|
||||
{one line to give the program's name and a brief idea of what it does.}
|
||||
Copyright (C) {year} {name of author}
|
||||
|
||||
This program is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 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, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
Also add information on how to contact you by electronic and paper mail.
|
||||
|
||||
If the program does terminal interaction, make it output a short
|
||||
notice like this when it starts in an interactive mode:
|
||||
|
||||
{project} Copyright (C) {year} {fullname}
|
||||
This program 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, your program's commands
|
||||
might be different; for a GUI interface, you would use an "about box".
|
||||
|
||||
You should also get your employer (if you work as a programmer) or school,
|
||||
if any, to sign a "copyright disclaimer" for the program, if necessary.
|
||||
For more information on this, and how to apply and follow the GNU GPL, see
|
||||
<http://www.gnu.org/licenses/>.
|
||||
|
||||
The GNU 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. But first, please read
|
||||
<http://www.gnu.org/philosophy/why-not-lgpl.html>.
|
3
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/index.php
vendored
Normal file
3
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/index.php
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
<?php
|
||||
// phpcs:ignoreFile
|
||||
// Nothing here.
|
72
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/load.php
vendored
Normal file
72
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/load.php
vendored
Normal file
@ -0,0 +1,72 @@
|
||||
<?php
|
||||
/**
|
||||
* Loader for the ThemeIsleSDK
|
||||
*
|
||||
* Logic for loading always the latest SDK from the installed themes/plugins.
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-2.0.php GNU Public License
|
||||
* @since 1.1.0
|
||||
*/
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
return;
|
||||
}
|
||||
// Current SDK version and path.
|
||||
$themeisle_sdk_version = '3.1.7';
|
||||
$themeisle_sdk_path = dirname( __FILE__ );
|
||||
|
||||
global $themeisle_sdk_max_version;
|
||||
global $themeisle_sdk_max_path;
|
||||
|
||||
// If this is the latest SDK and it comes from a theme, we should load licenser separately.
|
||||
$themeisle_sdk_relative_licenser_path = '/src/Modules/Licenser.php';
|
||||
|
||||
global $themeisle_sdk_abs_licenser_path;
|
||||
if ( ! is_file( $themeisle_sdk_path . $themeisle_sdk_relative_licenser_path ) && is_file( $themeisle_sdk_max_path . $themeisle_sdk_relative_licenser_path ) ) {
|
||||
$themeisle_sdk_abs_licenser_path = $themeisle_sdk_max_path . $themeisle_sdk_relative_licenser_path;
|
||||
add_filter( 'themeisle_sdk_required_files', 'themeisle_sdk_load_licenser_if_present' );
|
||||
}
|
||||
if ( version_compare( $themeisle_sdk_version, $themeisle_sdk_max_path ) == 0 &&
|
||||
apply_filters( 'themeisle_sdk_should_overwrite_path', false, $themeisle_sdk_path, $themeisle_sdk_max_path ) ) {
|
||||
$themeisle_sdk_max_path = $themeisle_sdk_path;
|
||||
}
|
||||
|
||||
if ( version_compare( $themeisle_sdk_version, $themeisle_sdk_max_version ) > 0 ) {
|
||||
$themeisle_sdk_max_version = $themeisle_sdk_version;
|
||||
$themeisle_sdk_max_path = $themeisle_sdk_path;
|
||||
}
|
||||
|
||||
// load the latest sdk version from the active Themeisle products.
|
||||
if ( ! function_exists( 'themeisle_sdk_load_licenser_if_present' ) ) :
|
||||
/**
|
||||
* Always load the licenser, if present.
|
||||
*
|
||||
* @param array $to_load Previously files to load.
|
||||
*/
|
||||
function themeisle_sdk_load_licenser_if_present( $to_load ) {
|
||||
global $themeisle_sdk_abs_licenser_path;
|
||||
$to_load[] = $themeisle_sdk_abs_licenser_path;
|
||||
|
||||
return $to_load;
|
||||
}
|
||||
endif;
|
||||
|
||||
// load the latest sdk version from the active Themeisle products.
|
||||
if ( ! function_exists( 'themeisle_sdk_load_latest' ) ) :
|
||||
/**
|
||||
* Always load the latest sdk version.
|
||||
*/
|
||||
function themeisle_sdk_load_latest() {
|
||||
/**
|
||||
* Don't load the library if we are on < 5.4.
|
||||
*/
|
||||
if ( version_compare( PHP_VERSION, '5.4.32', '<' ) ) {
|
||||
return;
|
||||
}
|
||||
global $themeisle_sdk_max_path;
|
||||
require_once $themeisle_sdk_max_path . '/start.php';
|
||||
}
|
||||
endif;
|
||||
add_action( 'init', 'themeisle_sdk_load_latest' );
|
66
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Common/Abstract_module.php
vendored
Normal file
66
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Common/Abstract_module.php
vendored
Normal file
@ -0,0 +1,66 @@
|
||||
<?php
|
||||
/**
|
||||
* The abstract class for module definition.
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @subpackage Loader
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-3.0.php GNU Public License
|
||||
* @since 3.0.0
|
||||
*/
|
||||
|
||||
namespace ThemeisleSDK\Common;
|
||||
|
||||
use ThemeisleSDK\Product;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
/**
|
||||
* Class Abstract_Module.
|
||||
*
|
||||
* @package ThemeisleSDK\Common
|
||||
*/
|
||||
abstract class Abstract_Module {
|
||||
/**
|
||||
* Product which use the module.
|
||||
*
|
||||
* @var Product $product Product object.
|
||||
*/
|
||||
protected $product = null;
|
||||
|
||||
/**
|
||||
* Can load the module for the selected product.
|
||||
*
|
||||
* @param Product $product Product data.
|
||||
*
|
||||
* @return bool Should load module?
|
||||
*/
|
||||
public abstract function can_load( $product );
|
||||
|
||||
/**
|
||||
* Bootstrap the module.
|
||||
*
|
||||
* @param Product $product Product object.
|
||||
*/
|
||||
public abstract function load( $product );
|
||||
|
||||
/**
|
||||
* Check if the product is from partner.
|
||||
*
|
||||
* @param Product $product Product data.
|
||||
*
|
||||
* @return bool Is product from partner.
|
||||
*/
|
||||
public function is_from_partner( $product ) {
|
||||
|
||||
foreach ( Module_Factory::$domains as $partner_domain ) {
|
||||
if ( strpos( $product->get_store_url(), $partner_domain ) !== false ) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
return array_key_exists( $product->get_slug(), Module_Factory::$slugs );
|
||||
}
|
||||
}
|
108
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Common/Module_factory.php
vendored
Normal file
108
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Common/Module_factory.php
vendored
Normal file
@ -0,0 +1,108 @@
|
||||
<?php
|
||||
/**
|
||||
* The module factory class.
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @subpackage Loader
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-3.0.php GNU Public License
|
||||
* @since 3.0.0
|
||||
*/
|
||||
|
||||
namespace ThemeisleSDK\Common;
|
||||
|
||||
use ThemeisleSDK\Product;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
/**
|
||||
* Class Job_Factory
|
||||
*
|
||||
* @package ThemeisleSDK\Common
|
||||
*/
|
||||
class Module_Factory {
|
||||
/**
|
||||
* Partners slugs.
|
||||
*
|
||||
* @var array $SLUGS Partners product slugs.
|
||||
*/
|
||||
public static $slugs = [
|
||||
'zermatt' => true,
|
||||
'neto' => true,
|
||||
'olsen' => true,
|
||||
'benson' => true,
|
||||
'romero' => true,
|
||||
'carmack' => true,
|
||||
'puzzle' => true,
|
||||
'broadsheet' => true,
|
||||
'girlywp' => true,
|
||||
'veggie' => true,
|
||||
'zeko' => true,
|
||||
'maishawp' => true,
|
||||
'didi' => true,
|
||||
'liber' => true,
|
||||
'medicpress-pt' => true,
|
||||
'adrenaline-pt' => true,
|
||||
'consultpress-pt' => true,
|
||||
'legalpress-pt' => true,
|
||||
'gympress-pt' => true,
|
||||
'readable-pt' => true,
|
||||
'bolts-pt' => true,
|
||||
];
|
||||
/**
|
||||
* Partners domains.
|
||||
*
|
||||
* @var array $DOMAINS Partners domains.
|
||||
*/
|
||||
public static $domains = [
|
||||
'proteusthemes.com',
|
||||
'anarieldesign.com',
|
||||
'prothemedesign.com',
|
||||
'cssigniter.com',
|
||||
];
|
||||
/**
|
||||
* Map which contains all the modules loaded for each product.
|
||||
*
|
||||
* @var array Mapping array.
|
||||
*/
|
||||
private static $modules_attached = [];
|
||||
|
||||
/**
|
||||
* Load availabe modules for the selected product.
|
||||
*
|
||||
* @param Product $product Loaded product.
|
||||
* @param array $modules List of modules.
|
||||
*/
|
||||
public static function attach( $product, $modules ) {
|
||||
|
||||
if ( ! isset( self::$modules_attached[ $product->get_slug() ] ) ) {
|
||||
self::$modules_attached[ $product->get_slug() ] = [];
|
||||
}
|
||||
|
||||
foreach ( $modules as $module ) {
|
||||
$class = 'ThemeisleSDK\\Modules\\' . ucwords( $module, '_' );
|
||||
/**
|
||||
* Module object.
|
||||
*
|
||||
* @var Abstract_Module $module_object Module instance.
|
||||
*/
|
||||
$module_object = new $class( $product );
|
||||
|
||||
if ( ! $module_object->can_load( $product ) ) {
|
||||
continue;
|
||||
}
|
||||
self::$modules_attached[ $product->get_slug() ][ $module ] = $module_object->load( $product );
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Products/Modules loaded map.
|
||||
*
|
||||
* @return array Modules map.
|
||||
*/
|
||||
public static function get_modules_map() {
|
||||
return self::$modules_attached;
|
||||
}
|
||||
}
|
126
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Loader.php
vendored
Normal file
126
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Loader.php
vendored
Normal file
@ -0,0 +1,126 @@
|
||||
<?php
|
||||
/**
|
||||
* The main loader class for ThemeIsle SDK
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @subpackage Loader
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-3.0.php GNU Public License
|
||||
* @since 1.0.0
|
||||
*/
|
||||
|
||||
namespace ThemeisleSDK;
|
||||
|
||||
use ThemeisleSDK\Common\Module_Factory;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Singleton loader for ThemeIsle SDK.
|
||||
*/
|
||||
final class Loader {
|
||||
/**
|
||||
* Singleton instance.
|
||||
*
|
||||
* @var Loader instance The singleton instance
|
||||
*/
|
||||
private static $instance;
|
||||
/**
|
||||
* Current loader version.
|
||||
*
|
||||
* @var string $version The class version.
|
||||
*/
|
||||
private static $version = '2.0.0';
|
||||
/**
|
||||
* Holds registered products.
|
||||
*
|
||||
* @var array The products which use the SDK.
|
||||
*/
|
||||
private static $products = [];
|
||||
/**
|
||||
* Holds available modules to load.
|
||||
*
|
||||
* @var array The modules which SDK will be using.
|
||||
*/
|
||||
private static $available_modules = [
|
||||
'dashboard_widget',
|
||||
'rollback',
|
||||
'uninstall_feedback',
|
||||
'licenser',
|
||||
'endpoint',
|
||||
'notification',
|
||||
'logger',
|
||||
'translate',
|
||||
'review',
|
||||
'recommendation',
|
||||
|
||||
];
|
||||
|
||||
/**
|
||||
* Initialize the sdk logic.
|
||||
*/
|
||||
public static function init() {
|
||||
if ( ! isset( self::$instance ) && ! ( self::$instance instanceof Loader ) ) {
|
||||
self::$instance = new Loader();
|
||||
$modules = array_merge( self::$available_modules, apply_filters( 'themeisle_sdk_modules', [] ) );
|
||||
foreach ( $modules as $key => $module ) {
|
||||
if ( ! class_exists( 'ThemeisleSDK\\Modules\\' . ucwords( $module, '_' ) ) ) {
|
||||
unset( $modules[ $key ] );
|
||||
}
|
||||
}
|
||||
self::$available_modules = $modules;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Register product into SDK.
|
||||
*
|
||||
* @param string $base_file The product base file.
|
||||
*
|
||||
* @return Loader The singleton object.
|
||||
*/
|
||||
public static function add_product( $base_file ) {
|
||||
|
||||
if ( ! is_file( $base_file ) ) {
|
||||
return self::$instance;
|
||||
}
|
||||
$product = new Product( $base_file );
|
||||
|
||||
Module_Factory::attach( $product, self::get_modules() );
|
||||
|
||||
self::$products[ $product->get_slug() ] = $product;
|
||||
|
||||
return self::$instance;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get all registered modules by the SDK.
|
||||
*
|
||||
* @return array Modules available.
|
||||
*/
|
||||
public static function get_modules() {
|
||||
return self::$available_modules;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get all products using the SDK.
|
||||
*
|
||||
* @return array Products available.
|
||||
*/
|
||||
public static function get_products() {
|
||||
return self::$products;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the version of the SDK.
|
||||
*
|
||||
* @return string The version.
|
||||
*/
|
||||
public static function get_version() {
|
||||
return self::$version;
|
||||
}
|
||||
|
||||
}
|
466
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Dashboard_widget.php
vendored
Normal file
466
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Dashboard_widget.php
vendored
Normal file
@ -0,0 +1,466 @@
|
||||
<?php
|
||||
/**
|
||||
* The blog dashboard model class for ThemeIsle SDK
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @subpackage Modules
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-3.0.php GNU Public License
|
||||
* @since 1.0.0
|
||||
*/
|
||||
|
||||
namespace ThemeisleSDK\Modules;
|
||||
|
||||
use ThemeisleSDK\Common\Abstract_Module;
|
||||
use ThemeisleSDK\Product;
|
||||
|
||||
// Exit if accessed directly.
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
/**
|
||||
* Blog dashboard widget module for ThemeIsle SDK.
|
||||
*/
|
||||
class Dashboard_Widget extends Abstract_Module {
|
||||
|
||||
/**
|
||||
* Fetched feeds items.
|
||||
*
|
||||
* @var array Feed items.
|
||||
*/
|
||||
private $items = array();
|
||||
|
||||
/**
|
||||
* Dashboard widget title.
|
||||
*
|
||||
* @var string $dashboard_name Dashboard name.
|
||||
*/
|
||||
private $dashboard_name = '';
|
||||
|
||||
/**
|
||||
* Dashboard widget feed sources.
|
||||
*
|
||||
* @var array $feeds Feed url.
|
||||
*/
|
||||
private $feeds = [];
|
||||
|
||||
/**
|
||||
* Should we load this module.
|
||||
*
|
||||
* @param Product $product Product object.
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public function can_load( $product ) {
|
||||
if ( $this->is_from_partner( $product ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if ( ! apply_filters( $product->get_slug() . '_load_dashboard_widget', true ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Registers the hooks.
|
||||
*
|
||||
* @param Product $product Product to load.
|
||||
*
|
||||
* @return Dashboard_Widget Module instance.
|
||||
*/
|
||||
public function load( $product ) {
|
||||
if ( apply_filters( 'themeisle_sdk_hide_dashboard_widget', false ) ) {
|
||||
return;
|
||||
}
|
||||
$this->product = $product;
|
||||
$this->dashboard_name = apply_filters( 'themeisle_sdk_dashboard_widget_name', 'WordPress Guides/Tutorials' );
|
||||
$this->feeds = apply_filters(
|
||||
'themeisle_sdk_dashboard_widget_feeds',
|
||||
[
|
||||
'https://themeisle.com/blog/feed',
|
||||
]
|
||||
);
|
||||
add_action( 'wp_dashboard_setup', array( &$this, 'add_widget' ) );
|
||||
add_action( 'wp_network_dashboard_setup', array( &$this, 'add_widget' ) );
|
||||
add_filter( 'themeisle_sdk_recommend_plugin_or_theme', array( &$this, 'recommend_plugin_or_theme' ) );
|
||||
|
||||
return $this;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Add widget to the dashboard
|
||||
*
|
||||
* @return string|void
|
||||
*/
|
||||
function add_widget() {
|
||||
global $wp_meta_boxes;
|
||||
if ( isset( $wp_meta_boxes['dashboard']['normal']['core']['themeisle'] ) ) {
|
||||
return;
|
||||
}
|
||||
wp_add_dashboard_widget(
|
||||
'themeisle',
|
||||
$this->dashboard_name,
|
||||
[
|
||||
$this,
|
||||
'render_dashboard_widget',
|
||||
]
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Render widget content
|
||||
*/
|
||||
function render_dashboard_widget() {
|
||||
$this->setup_feeds();
|
||||
if ( empty( $this->items ) || ! is_array( $this->items ) ) {
|
||||
return;
|
||||
}
|
||||
?>
|
||||
<style type="text/css">
|
||||
#themeisle ul li.ti-dw-recommend-item {
|
||||
padding-left: 7px;
|
||||
border-top: 1px solid #eee;
|
||||
margin-bottom: 0px;
|
||||
padding-top: 6px;
|
||||
}
|
||||
|
||||
#themeisle h2.hndle {
|
||||
background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEgAAABbCAMAAADncTNAAAAAtFBMVEVHcEyAgIB/f3+xsbGgoaGBgYGCgoKKioqAgIC1tbW5ubnFx8iAgIDU1taBgYGCgoKAgIC0tLXW19jW2NiAgIC3uLiBgYHLzMy4uLhycnLW19d/f3/T1NW0tLTX19mVlZWvr6+BgYHl5eWKiottbW5JSUnW2Nm5ubnh4eHT1NWVlZVjY2N4eHh9fX6pqqq+v79PT0/39/fu7u7Nzc7Z2ttYWFgBAQHDw8P////JysoZGRk0NTZqJc/sAAAAIXRSTlMA0FL7/oEnEPL6eibivm9gwJya76/enFq2CXI+2lFAyM8GATmPAAADj0lEQVR4Xu2YaW/iOhSGAwRCWDosnXa6znjJvm8svf//f12TuARyhiR2pfnUR6gSEnr0+uT4xK7yRb755pvhHePli5K7Bfpkuhoq8ozRJdMH+WWha6Z3sqYparCSLRJqspjImVbANJU03cNMMpofAwQZCGsmpQYyFvVM0Q00OQ9koMl5IPcCoro+RA1Dt2Ea9n9eZ0+YHJLkgIlkDywQx00wCTyaReiKH8LbNU9ybJOdkchV6QFxyCFLbVvdfaREqgUWg/tx2UbqIcK2Hex2TdGLwFTjIj3XP3YfCZFsb23KRZn/3263oymSFI0/a5S4PqUBjoBIJBDjeEhCN0wxQSRybIxtJ3K5SGzuE/vAwIQc8ZmMMJFAIM4oikZItfEFtorGgoE43FObwqHU68OtPCnOz8KZ2Jbl5LgkSW0Tc7YyIz/EFWmS4jMbiZU5mJOmKRaJpKGGyLZtDJh3iyaNUu/3+xyKnrtFL71EG+FTiMpENhQtxUQ8kSOXCIr2tnCNhg/gTX0SHYFp0t7TCwQZ7U841yoHrW6rtGroUwTWVnLMssxx+H4bgZcSOFf5MYx0Ae8FghomMDyC2EBNImBywPkNTDNqGLQpIg2TjUNU8tBy9DQMo0DAZF16rAi7vJAtFTIYFAHUc6hIRW6OuOhJgaCSwmDEAYK4oa7ro+qIEyJU/US7KTJKPNSFT9tFgVFBu0SF1y7yjX4masRA9Da7EFGj28R/BkQz6xGIOurkx38T/bKs9Uk8aIiMwm/Jw0VP1yLrJwt13xAxvABBgsK4KWLov35DkRF7ZaqgzuZ7MQ8MOntmVYyAqKTwaICKqvSUFnVccMN5sziEP/5+xGDTahbH5Q3ZB76zr8fI+nJtvUUU3t3ml5GKviK/npCg3CGodnuJ4JVkfRFJYGVDBZrqKnn9RLf+CzDTS5PaN5J38+auzX4ykU4Qoj0rdKfcYs5ijfo9OL/uRUgZyQr7NCWtWwiUSLc4arfJa7lpszTA1OJZAQ8w8dXFrR5YHzCWSnS3pZ18tOi4Ps4vl/c7i/6qomjRecN+UubrPyPGn/VEMU3T0UFHkaPzpgjxmJsnjmrtionlMDZiog0TsY/DPtn8SXtlBvbtxKtwopy7lqW3smQO+yoGE1Uu55GJ3pmI8ygoejZNnqj0vnIRCyTKfLstRdtStGQi09myUsvwvlkuzSUXbV+Xz5ryBebV33fln/A/moud69FZiEYAAAAASUVORK5CYII=');
|
||||
background-repeat: no-repeat;
|
||||
background-position: 92% 50%;
|
||||
background-size: 25px;
|
||||
}
|
||||
|
||||
#themeisle .inside {
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
.ti-feed-list {
|
||||
padding: 0 12px 5px;
|
||||
margin-bottom: 10px;
|
||||
border-bottom: 1px solid #eee;
|
||||
}
|
||||
|
||||
.ti-dw-feed-item a {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
margin-bottom: 5px;
|
||||
padding: 5px;
|
||||
transition: .2s ease;
|
||||
border-radius: 3px;
|
||||
}
|
||||
|
||||
.ti-dw-feed-item a:hover {
|
||||
background-color: #f8f8f8;
|
||||
}
|
||||
|
||||
.ti-dw-feed-item a:hover .ti-dw-date-container {
|
||||
opacity: .9;
|
||||
}
|
||||
|
||||
.ti-dw-feed-item .ti-dw-month-container {
|
||||
margin-top: -5px;
|
||||
text-transform: uppercase;
|
||||
font-size: 10px;
|
||||
letter-spacing: 1px;
|
||||
font-weight: 700;
|
||||
}
|
||||
|
||||
.ti-dw-feed-item .ti-dw-date-container {
|
||||
border-radius: 3px;
|
||||
transition: .2s ease;
|
||||
min-height: 35px;
|
||||
margin-right: 5px;
|
||||
min-width: 35px;
|
||||
text-align: center;
|
||||
border: 1px solid #2a6f97;
|
||||
color: #fff;
|
||||
background: #2ea2cc;
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
justify-content: center;
|
||||
}
|
||||
|
||||
.ti-dw-footer {
|
||||
padding: 0 12px 5px;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.ti-dw-recommend-item {
|
||||
display: block;
|
||||
}
|
||||
|
||||
.ti-dw-recommend-item span {
|
||||
color: #72777c;
|
||||
}
|
||||
|
||||
.ti-dw-powered-by {
|
||||
font-size: 11px;
|
||||
margin-top: 3px;
|
||||
display: block;
|
||||
color: #72777c;
|
||||
}
|
||||
|
||||
.ti-dw-powered-by span {
|
||||
font-weight: 600;
|
||||
}
|
||||
|
||||
</style>
|
||||
<?php do_action( 'themeisle_sdk_dashboard_widget_before', $this->product ); ?>
|
||||
|
||||
<ul class="ti-feed-list">
|
||||
<?php
|
||||
|
||||
foreach ( $this->items as $item ) {
|
||||
?>
|
||||
<li class="ti-dw-feed-item">
|
||||
<a href="
|
||||
<?php
|
||||
echo add_query_arg(
|
||||
array(
|
||||
'utm_source' => 'wpadmin',
|
||||
'utm_campaign' => 'feed',
|
||||
'utm_medium' => 'dashboard_widget',
|
||||
),
|
||||
$item['link']
|
||||
);
|
||||
?>
|
||||
" target="_blank">
|
||||
<span class="ti-dw-date-container"><span
|
||||
class="ti-dw-day-container"><?php echo date( 'd', $item['date'] ); ?></span> <span
|
||||
class="ti-dw-month-container"><?php echo substr( date( 'M', $item['date'] ), 0, 3 ); ?></span></span><?php echo $item['title']; ?>
|
||||
</a>
|
||||
</li>
|
||||
<?php
|
||||
}
|
||||
?>
|
||||
</ul>
|
||||
<?php
|
||||
$recommend = apply_filters( 'themeisle_sdk_recommend_plugin_or_theme', array() );
|
||||
if ( ! is_array( $recommend ) || empty( $recommend ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
$type = $recommend['type'];
|
||||
|
||||
if ( ( 'theme' === $type && ! current_user_can( 'install_themes' ) ) ) {
|
||||
return;
|
||||
}
|
||||
if ( ( 'plugin' === $type && ! current_user_can( 'install_plugins' ) ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
add_thickbox();
|
||||
$url = add_query_arg(
|
||||
[
|
||||
'theme' => $recommend['slug'],
|
||||
],
|
||||
network_admin_url( 'theme-install.php' )
|
||||
);
|
||||
|
||||
if ( 'plugin' === $type ) {
|
||||
|
||||
$url = add_query_arg(
|
||||
array(
|
||||
'tab' => 'plugin-information',
|
||||
'plugin' => $recommend['slug'],
|
||||
),
|
||||
network_admin_url( 'plugin-install.php' )
|
||||
);
|
||||
}
|
||||
?>
|
||||
<div class="ti-dw-footer">
|
||||
<span class="ti-dw-recommend-item ">
|
||||
<span class="ti-dw-recommend"><?php echo apply_filters( 'themeisle_sdk_dashboard_popular_label', sprintf( 'Popular %s', ucwords( $type ) ) ); ?>
|
||||
: </span>
|
||||
<?php
|
||||
echo trim(
|
||||
str_replace(
|
||||
array(
|
||||
'lite',
|
||||
'Lite',
|
||||
'(Lite)',
|
||||
'(lite)',
|
||||
),
|
||||
'',
|
||||
$recommend['name']
|
||||
)
|
||||
);
|
||||
?>
|
||||
(<a class="thickbox open-plugin-details-modal"
|
||||
href="<?php echo $url . '&TB_iframe=true&width=600&height=500'; ?>"><?php echo apply_filters( 'themeisle_sdk_dashboard_install_label', 'Install' ); ?></a>)
|
||||
</span>
|
||||
<span class="ti-dw-powered-by"><span><?php echo apply_filters( 'themeisle_sdk_dashboard_widget_powered_by', esc_attr( sprintf( 'Powered by %s', $this->product->get_friendly_name() ) ) ); ?></span></span>
|
||||
</div>
|
||||
|
||||
<?php
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Setup feed items.
|
||||
*/
|
||||
private function setup_feeds() {
|
||||
if ( false === ( $items_normalized = get_transient( 'themeisle_sdk_feed_items' ) ) ) {
|
||||
// Load SimplePie Instance.
|
||||
$feed = fetch_feed( $this->feeds );
|
||||
// TODO report error when is an error loading the feed.
|
||||
if ( is_wp_error( $feed ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
$items = $feed->get_items( 0, 5 );
|
||||
foreach ( (array) $items as $item ) {
|
||||
$items_normalized[] = array(
|
||||
'title' => $item->get_title(),
|
||||
'date' => $item->get_date( 'U' ),
|
||||
'link' => $item->get_permalink(),
|
||||
);
|
||||
}
|
||||
set_transient( 'themeisle_sdk_feed_items', $items_normalized, 48 * HOUR_IN_SECONDS );
|
||||
}
|
||||
$this->items = $items_normalized;
|
||||
}
|
||||
|
||||
/**
|
||||
* Either the current product is installed or not.
|
||||
*
|
||||
* @param array $val The current recommended product.
|
||||
*
|
||||
* @return bool Either we should exclude the plugin or not.
|
||||
*/
|
||||
public function remove_current_products( $val ) {
|
||||
if ( 'theme' === $val['type'] ) {
|
||||
$exist = wp_get_theme( $val['slug'] );
|
||||
|
||||
return ! $exist->exists();
|
||||
} else {
|
||||
$all_plugins = array_keys( get_plugins() );
|
||||
foreach ( $all_plugins as $slug ) {
|
||||
if ( strpos( $slug, $val['slug'] ) !== false ) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Contact the API and fetch the recommended plugins/themes
|
||||
*/
|
||||
function recommend_plugin_or_theme() {
|
||||
$products = $this->get_product_from_api();
|
||||
if ( ! is_array( $products ) ) {
|
||||
$products = array();
|
||||
}
|
||||
$products = array_filter( $products, array( $this, 'remove_current_products' ) );
|
||||
$products = array_merge( $products );
|
||||
if ( count( $products ) > 1 ) {
|
||||
shuffle( $products );
|
||||
$products = array_slice( $products, 0, 1 );
|
||||
}
|
||||
$to_recommend = isset( $products[0] ) ? $products[0] : $products;
|
||||
|
||||
return $to_recommend;
|
||||
}
|
||||
|
||||
/**
|
||||
* Fetch products from the recomended section.
|
||||
*
|
||||
* @return array|mixed The list of products to use in recomended section.
|
||||
*/
|
||||
function get_product_from_api() {
|
||||
if ( false === ( $products = get_transient( 'themeisle_sdk_products' ) ) ) {
|
||||
$products = array();
|
||||
$all_themes = $this->get_themes_from_wporg( 'themeisle' );
|
||||
$all_plugins = $this->get_plugins_from_wporg( 'themeisle' );
|
||||
static $allowed_products = [
|
||||
'hestia' => true,
|
||||
'neve' => true,
|
||||
'visualizer' => true,
|
||||
'feedzy-rss-feeds' => true,
|
||||
'wp-product-review' => true,
|
||||
'otter-blocks' => true,
|
||||
'themeisle-companion' => true,
|
||||
];
|
||||
foreach ( $all_themes as $theme ) {
|
||||
if ( $theme->active_installs < 4999 ) {
|
||||
continue;
|
||||
}
|
||||
if ( ! isset( $allowed_products[ $theme->slug ] ) ) {
|
||||
continue;
|
||||
}
|
||||
$products[] = array(
|
||||
'name' => $theme->name,
|
||||
'type' => 'theme',
|
||||
'slug' => $theme->slug,
|
||||
'installs' => $theme->active_installs,
|
||||
);
|
||||
}
|
||||
foreach ( $all_plugins as $plugin ) {
|
||||
if ( $plugin->active_installs < 4999 ) {
|
||||
continue;
|
||||
}
|
||||
if ( ! isset( $allowed_products[ $plugin->slug ] ) ) {
|
||||
continue;
|
||||
}
|
||||
$products[] = array(
|
||||
'name' => $plugin->name,
|
||||
'type' => 'plugin',
|
||||
'slug' => $plugin->slug,
|
||||
'installs' => $plugin->active_installs,
|
||||
);
|
||||
}
|
||||
set_transient( 'themeisle_sdk_products', $products, 6 * HOUR_IN_SECONDS );
|
||||
}
|
||||
|
||||
return $products;
|
||||
}
|
||||
|
||||
/**
|
||||
* Fetch themes from wporg api.
|
||||
*
|
||||
* @param string $author The author name.
|
||||
*
|
||||
* @return array The list of themes.
|
||||
*/
|
||||
function get_themes_from_wporg( $author ) {
|
||||
$products = wp_remote_get(
|
||||
'https://api.wordpress.org/themes/info/1.1/?action=query_themes&request[author]=' . $author . '&request[per_page]=30&request[fields][active_installs]=true'
|
||||
);
|
||||
$products = json_decode( wp_remote_retrieve_body( $products ) );
|
||||
if ( is_object( $products ) ) {
|
||||
$products = isset( $products->themes ) ? $products->themes : array();
|
||||
} else {
|
||||
$products = array();
|
||||
}
|
||||
|
||||
return (array) $products;
|
||||
}
|
||||
|
||||
/**
|
||||
* Fetch plugin from wporg api.
|
||||
*
|
||||
* @param string $author The author slug.
|
||||
*
|
||||
* @return array The list of plugins for the selected author.
|
||||
*/
|
||||
function get_plugins_from_wporg( $author ) {
|
||||
$products = wp_remote_get(
|
||||
'https://api.wordpress.org/plugins/info/1.1/?action=query_plugins&request[author]=' . $author . '&request[per_page]=40&request[fields][active_installs]=true'
|
||||
);
|
||||
$products = json_decode( wp_remote_retrieve_body( $products ) );
|
||||
if ( is_object( $products ) ) {
|
||||
$products = isset( $products->plugins ) ? $products->plugins : array();
|
||||
} else {
|
||||
$products = array();
|
||||
}
|
||||
|
||||
return (array) $products;
|
||||
}
|
||||
}
|
358
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Endpoint.php
vendored
Normal file
358
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Endpoint.php
vendored
Normal file
@ -0,0 +1,358 @@
|
||||
<?php
|
||||
/**
|
||||
* The class that exposes endpoints.
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @subpackage Rollback
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-3.0.php GNU Public License
|
||||
* @since 1.0.0
|
||||
*/
|
||||
|
||||
namespace ThemeisleSDK\Modules;
|
||||
|
||||
// Exit if accessed directly.
|
||||
use ThemeisleSDK\Common\Abstract_Module;
|
||||
use ThemeisleSDK\Loader;
|
||||
use ThemeisleSDK\Product;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
/**
|
||||
* Expose endpoints for ThemeIsle SDK.
|
||||
*/
|
||||
class Endpoint extends Abstract_Module {
|
||||
/**
|
||||
* Endpoint slug.
|
||||
*/
|
||||
const SDK_ENDPOINT = 'themeisle-sdk';
|
||||
/**
|
||||
* Endpoint version.
|
||||
*/
|
||||
const SDK_ENDPOINT_VERSION = 1;
|
||||
/**
|
||||
* Hash file which contains the checksum.
|
||||
*/
|
||||
const HASH_FILE = 'themeisle-hash.json';
|
||||
|
||||
/*
|
||||
* If true, the endpoint will expect a product slug and will return the value only for that.
|
||||
*/
|
||||
const PRODUCT_SPECIFIC = false;
|
||||
|
||||
/**
|
||||
* Registers the endpoints.
|
||||
*/
|
||||
function rest_register() {
|
||||
register_rest_route(
|
||||
self::SDK_ENDPOINT . '/v' . self::SDK_ENDPOINT_VERSION,
|
||||
'/checksum/' . ( self::PRODUCT_SPECIFIC ? '(?P<slug>.*)/' : '' ),
|
||||
array(
|
||||
'methods' => 'GET',
|
||||
'callback' => array( $this, 'checksum' ),
|
||||
)
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* The checksum endpoint.
|
||||
*
|
||||
* @param \WP_REST_Request $data the request.
|
||||
*
|
||||
* @return \WP_REST_Response Response or the error
|
||||
*/
|
||||
function checksum( \WP_REST_Request $data ) {
|
||||
$products = Loader::get_products();
|
||||
if ( self::PRODUCT_SPECIFIC ) {
|
||||
$params = $this->validate_params( $data, array( 'slug' ) );
|
||||
foreach ( $products as $product ) {
|
||||
if ( $params['slug'] === $product->get_slug() ) {
|
||||
$products = array( $product );
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
$response = array();
|
||||
$custom_css = $this->has_custom_css();
|
||||
if ( is_bool( $custom_css ) ) {
|
||||
$response['custom_css'] = $custom_css;
|
||||
}
|
||||
|
||||
$response['child_theme'] = $this->get_theme_properties();
|
||||
|
||||
foreach ( $products as $product ) {
|
||||
$files = array();
|
||||
switch ( $product->get_type() ) {
|
||||
case 'plugin':
|
||||
$files = array();
|
||||
break;
|
||||
case 'theme':
|
||||
$files = array( 'style.css', 'functions.php' );
|
||||
break;
|
||||
}
|
||||
|
||||
$error = '';
|
||||
|
||||
// if any element in the $files array contains a '/', this would imply recursion is required.
|
||||
$diff = $this->generate_diff(
|
||||
$product,
|
||||
$files,
|
||||
array_reduce(
|
||||
$files,
|
||||
array(
|
||||
$this,
|
||||
'is_recursion_required',
|
||||
),
|
||||
false
|
||||
)
|
||||
);
|
||||
if ( is_wp_error( $diff ) ) {
|
||||
/**
|
||||
* Error returner by the diff checker method.
|
||||
*
|
||||
* @var \WP_Error $diff Error returned.
|
||||
*/
|
||||
$error = $diff->get_error_message();
|
||||
$diff = array();
|
||||
}
|
||||
|
||||
$response['products'][] = array(
|
||||
'slug' => $product->get_slug(),
|
||||
'version' => $product->get_version(),
|
||||
'diffs' => $diff,
|
||||
'error' => $error,
|
||||
);
|
||||
}
|
||||
|
||||
return new \WP_REST_Response( array( 'checksum' => $response ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Validates the parameters to the API
|
||||
*
|
||||
* @param \WP_REST_Request $data the request.
|
||||
* @param array $params the parameters to validate.
|
||||
*
|
||||
* @return array of parameter name=>value
|
||||
*/
|
||||
private function validate_params( \WP_REST_Request $data, $params ) {
|
||||
$collect = array();
|
||||
foreach ( $params as $param ) {
|
||||
$value = sanitize_text_field( $data[ $param ] );
|
||||
if ( empty( $value ) ) {
|
||||
return rest_ensure_response(
|
||||
new \WP_Error(
|
||||
'themeisle_' . $param . '_invalid',
|
||||
sprintf( 'Invalid %', $param ),
|
||||
array(
|
||||
'status' => 403,
|
||||
)
|
||||
)
|
||||
);
|
||||
} else {
|
||||
$collect[ $param ] = $value;
|
||||
}
|
||||
}
|
||||
|
||||
return $collect;
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if custom css has been added to the theme.
|
||||
*
|
||||
* @return bool Whether custom css has been added to the theme.
|
||||
*/
|
||||
private function has_custom_css() {
|
||||
$query = new \WP_Query(
|
||||
array(
|
||||
'post_type' => 'custom_css',
|
||||
'post_status' => 'publish',
|
||||
'numberposts' => 1,
|
||||
'update_post_meta_cache' => false,
|
||||
'update_post_term_cache' => false,
|
||||
)
|
||||
);
|
||||
|
||||
if ( $query->have_posts() ) {
|
||||
$query->the_post();
|
||||
$content = get_the_content();
|
||||
|
||||
// if the content contains a colon, a CSS rule has been added.
|
||||
return strpos( $content, ':' ) === false ? false : true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the current theme properties.
|
||||
*
|
||||
* @return mixed Properties of the current theme.
|
||||
*/
|
||||
function get_theme_properties() {
|
||||
if ( ! is_child_theme() ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$properties = array();
|
||||
$theme = wp_get_theme();
|
||||
// @codingStandardsIgnoreStart
|
||||
$properties['name'] = $theme->Name;
|
||||
// @codingStandardsIgnoreEnd
|
||||
|
||||
// get the files in the child theme.
|
||||
require_once( ABSPATH . 'wp-admin/includes/file.php' );
|
||||
WP_Filesystem();
|
||||
global $wp_filesystem;
|
||||
$path = str_replace( ABSPATH, $wp_filesystem->abspath(), get_stylesheet_directory() );
|
||||
$list = $wp_filesystem->dirlist( $path, false, false );
|
||||
if ( $list ) {
|
||||
$list = array_keys( self::flatten_dirlist( $list ) );
|
||||
$properties['files'] = $list;
|
||||
}
|
||||
|
||||
return $properties;
|
||||
}
|
||||
|
||||
/**
|
||||
* Flatten the results of WP_Filesystem::dirlist() for iterating over.
|
||||
*
|
||||
* @access private
|
||||
*
|
||||
* @param array $nested_files Array of files as returned by WP_Filesystem::dirlist().
|
||||
* @param string $path Relative path to prepend to child nodes. Optional.
|
||||
*
|
||||
* @return array $files A flattened array of the $nested_files specified.
|
||||
*/
|
||||
private static function flatten_dirlist( $nested_files, $path = '' ) {
|
||||
$files = array();
|
||||
foreach ( $nested_files as $name => $details ) {
|
||||
$files[ $path . $name ] = $details;
|
||||
// Append children recursively.
|
||||
if ( ! empty( $details['files'] ) ) {
|
||||
$children = self::flatten_dirlist( $details['files'], $path . $name . '/' );
|
||||
// Merge keeping possible numeric keys, which array_merge() will reindex from 0..n.
|
||||
$files = $files + $children;
|
||||
}
|
||||
}
|
||||
|
||||
return $files;
|
||||
}
|
||||
|
||||
/**
|
||||
* Generate the diff of the files.
|
||||
*
|
||||
* @param Product $product Themeisle Product.
|
||||
* @param array $files Array of files.
|
||||
* @param bool $recurse Whether to recurse or not.
|
||||
*
|
||||
* @return mixed Diff data.
|
||||
*/
|
||||
private function generate_diff( $product, $files, $recurse = false ) {
|
||||
require_once( ABSPATH . 'wp-admin/includes/file.php' );
|
||||
WP_Filesystem();
|
||||
global $wp_filesystem;
|
||||
|
||||
$diff = array();
|
||||
$path = str_replace( ABSPATH, $wp_filesystem->abspath(), plugin_dir_path( $product->get_basefile() ) );
|
||||
$list = $wp_filesystem->dirlist( $path, false, $recurse );
|
||||
// nothing found.
|
||||
if ( ! $list ) {
|
||||
return $diff;
|
||||
}
|
||||
$list = array_keys( self::flatten_dirlist( $list ) );
|
||||
|
||||
// now let's get the valid files that actually exist.
|
||||
if ( empty( $files ) ) {
|
||||
$files = $list;
|
||||
} else {
|
||||
$files = array_intersect( $files, $list );
|
||||
}
|
||||
|
||||
// fetch the calculated hashes.
|
||||
if ( ! $wp_filesystem->is_readable( $path . '/' . self::HASH_FILE ) ) {
|
||||
return new \WP_Error( 'themeisle_sdk_hash_not_found', sprintf( '%s not found', self::HASH_FILE ) );
|
||||
}
|
||||
|
||||
$hashes = json_decode( $wp_filesystem->get_contents( $path . '/' . self::HASH_FILE ), true );
|
||||
ksort( $hashes );
|
||||
|
||||
$diff = array();
|
||||
foreach ( $files as $file ) {
|
||||
// file does not exist in the hashes.
|
||||
if ( ! array_key_exists( $file, $hashes ) ) {
|
||||
continue;
|
||||
}
|
||||
$new = md5( $wp_filesystem->get_contents( $path . $file ) );
|
||||
$old = $hashes[ $file ];
|
||||
|
||||
// same hash, bail.
|
||||
if ( $new === $old ) {
|
||||
continue;
|
||||
}
|
||||
$diff[] = $file;
|
||||
}
|
||||
|
||||
return $diff;
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if recursion needs to be enabled on the WP_Filesystem by reducing the array of files to a boolean.
|
||||
*
|
||||
* @param string $carry Value of the previous iteration.
|
||||
* @param string $item Value of the current iteration.
|
||||
*
|
||||
* @return bool Whether to recurse or not.
|
||||
*/
|
||||
function is_recursion_required( $carry, $item ) {
|
||||
if ( ! $carry ) {
|
||||
return ( strpos( $item, '/' ) !== false );
|
||||
}
|
||||
|
||||
return $carry;
|
||||
}
|
||||
|
||||
/**
|
||||
* Load module for this product.
|
||||
*
|
||||
* @param Product $product Product to check.
|
||||
*
|
||||
* @return bool Should we load this?
|
||||
*/
|
||||
public function can_load( $product ) {
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Load module logic.
|
||||
*
|
||||
* @param Product $product Product to load.
|
||||
*/
|
||||
public function load( $product ) {
|
||||
$this->setup_endpoints();
|
||||
|
||||
return $this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Setup endpoints.
|
||||
*/
|
||||
private function setup_endpoints() {
|
||||
global $wp_version;
|
||||
if ( version_compare( $wp_version, '4.4', '<' ) ) {
|
||||
// no REST support.
|
||||
return;
|
||||
}
|
||||
|
||||
$this->setup_rest();
|
||||
}
|
||||
|
||||
/**
|
||||
* Setup REST endpoints.
|
||||
*/
|
||||
private function setup_rest() {
|
||||
add_action( 'rest_api_init', array( $this, 'rest_register' ) );
|
||||
}
|
||||
}
|
798
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Licenser.php
vendored
Normal file
798
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Licenser.php
vendored
Normal file
@ -0,0 +1,798 @@
|
||||
<?php
|
||||
/**
|
||||
* The main loader class for license handling.
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @subpackage Modules
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-3.0.php GNU Public License
|
||||
* @since 1.0.0
|
||||
*/
|
||||
|
||||
namespace ThemeisleSDK\Modules;
|
||||
|
||||
// Exit if accessed directly.
|
||||
use ThemeisleSDK\Common\Abstract_Module;
|
||||
use ThemeisleSDK\Product;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
/**
|
||||
* Licenser module for ThemeIsle SDK.
|
||||
*/
|
||||
class Licenser extends Abstract_Module {
|
||||
|
||||
/**
|
||||
* Number of max failed checks before showing the license message.
|
||||
*
|
||||
* @var int $max_failed Maximum failed checks allowed before show the notice
|
||||
*/
|
||||
private static $max_failed = 5;
|
||||
/**
|
||||
* License key string.
|
||||
*
|
||||
* @var string $license_key The license key string
|
||||
*/
|
||||
public $license_key;
|
||||
/**
|
||||
* This ensures that the custom API request only runs on the second time that WP fires the update check.
|
||||
*
|
||||
* @var bool $do_check Flag for request.
|
||||
*/
|
||||
private $do_check = false;
|
||||
/**
|
||||
* Number of failed checks to the api endpoint.
|
||||
*
|
||||
* @var bool $failed_checks
|
||||
*/
|
||||
private $failed_checks = 0;
|
||||
/**
|
||||
* The product update response key.
|
||||
*
|
||||
* @var string $product_key Product key.
|
||||
*/
|
||||
private $product_key;
|
||||
|
||||
/**
|
||||
* Disable wporg updates for premium products.
|
||||
*
|
||||
* @param string $r Update payload.
|
||||
* @param string $url The api url.
|
||||
*
|
||||
* @return mixed List of themes to check for update.
|
||||
*/
|
||||
function disable_wporg_update( $r, $url ) {
|
||||
|
||||
if ( 0 !== strpos( $url, 'https://api.wordpress.org/themes/update-check/' ) ) {
|
||||
return $r;
|
||||
}
|
||||
|
||||
// Decode the JSON response.
|
||||
$themes = json_decode( $r['body']['themes'] );
|
||||
|
||||
unset( $themes->themes->{$this->product->get_slug()} );
|
||||
|
||||
// Encode the updated JSON response.
|
||||
$r['body']['themes'] = json_encode( $themes );
|
||||
|
||||
return $r;
|
||||
}
|
||||
|
||||
/**
|
||||
* Register the setting for the license of the product.
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public function register_settings() {
|
||||
if ( ! is_admin() ) {
|
||||
return false;
|
||||
}
|
||||
if ( apply_filters( $this->product->get_key() . '_hide_license_field', false ) ) {
|
||||
return;
|
||||
}
|
||||
add_settings_field(
|
||||
$this->product->get_key() . '_license',
|
||||
$this->product->get_name() . ' license',
|
||||
array( $this, 'license_view' ),
|
||||
'general'
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* The license view field.
|
||||
*/
|
||||
public function license_view() {
|
||||
$status = $this->get_license_status();
|
||||
$value = $this->license_key;
|
||||
|
||||
$activate_string = apply_filters( $this->product->get_key() . '_lc_activate_string', 'Activate' );
|
||||
$deactivate_string = apply_filters( $this->product->get_key() . '_lc_deactivate_string', 'Deactivate' );
|
||||
$valid_string = apply_filters( $this->product->get_key() . '_lc_valid_string', 'Valid' );
|
||||
$invalid_string = apply_filters( $this->product->get_key() . '_lc_invalid_string', 'Invalid' );
|
||||
$license_message = apply_filters( $this->product->get_key() . '_lc_license_message', 'Enter your license from %s purchase history in order to get %s updates' );
|
||||
$error_message = $this->get_error();
|
||||
?>
|
||||
<style type="text/css">
|
||||
input.themeisle-sdk-text-input-valid {
|
||||
border: 1px solid #7ad03a;
|
||||
}
|
||||
|
||||
input.themeisle-sdk-license-input {
|
||||
width: 300px;
|
||||
padding: 0 8px;
|
||||
line-height: 2;
|
||||
min-height: 30px;
|
||||
}
|
||||
|
||||
.themeisle-sdk-license-deactivate-cta {
|
||||
color: #fff;
|
||||
background: #7ad03a;
|
||||
display: inline-block;
|
||||
text-decoration: none;
|
||||
font-size: 13px;
|
||||
line-height: 30px;
|
||||
height: 26px;
|
||||
margin-left: 5px;
|
||||
padding: 0 10px 3px;
|
||||
-webkit-border-radius: 3px;
|
||||
border-radius: 3px;
|
||||
}
|
||||
|
||||
.themeisle-sdk-license-activate-cta {
|
||||
color: #fff;
|
||||
background: #dd3d36;
|
||||
display: inline-block;
|
||||
text-decoration: none;
|
||||
font-size: 13px;
|
||||
line-height: 30px;
|
||||
height: 26px;
|
||||
margin-left: 5px;
|
||||
padding: 0 10px 3px;
|
||||
-webkit-border-radius: 3px;
|
||||
border-radius: 3px;
|
||||
}
|
||||
|
||||
button.button.themeisle-sdk-licenser-button-cta {
|
||||
line-height: 26px;
|
||||
height: 29px;
|
||||
vertical-align: top;
|
||||
}
|
||||
|
||||
</style>
|
||||
<?php
|
||||
echo sprintf(
|
||||
'<p>%s<input class="themeisle-sdk-license-input %s" type="text" id="%s_license" name="%s_license" value="%s" /><a class="%s">%s</a> <button name="%s_btn_trigger" class="button button-primary themeisle-sdk-licenser-button-cta" value="yes" type="submit" >%s</button></p><p class="description">%s</p>%s',
|
||||
( ( 'valid' === $status ) ? sprintf( '<input type="hidden" value="%s" name="%s_license" />', $value, $this->product->get_key() ) : '' ),
|
||||
( ( 'valid' === $status ) ? 'themeisle-sdk-text-input-valid' : '' ),
|
||||
$this->product->get_key(),
|
||||
( ( 'valid' === $status ) ? $this->product->get_key() . '_mask' : $this->product->get_key() ),
|
||||
( ( 'valid' === $status ) ? ( str_repeat( '*', 30 ) . substr( $value, - 5 ) ) : $value ),
|
||||
( 'valid' === $status ? 'themeisle-sdk-license-deactivate-cta' : 'themeisle-sdk-license-activate-cta' ),
|
||||
( 'valid' === $status ? $valid_string : $invalid_string ),
|
||||
$this->product->get_key(),
|
||||
( 'valid' === $status ? $deactivate_string : $activate_string ),
|
||||
sprintf( $license_message, '<a href="' . $this->get_api_url() . '">' . $this->get_distributor_name() . '</a> ', $this->product->get_type() ),
|
||||
empty( $error_message ) ? '' : sprintf( '<p style="color:#dd3d36">%s</p>', $error_message )
|
||||
);
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the license status.
|
||||
*
|
||||
* @return string The License status.
|
||||
*/
|
||||
public function get_license_status() {
|
||||
|
||||
$license_data = get_option( $this->product->get_key() . '_license_data', '' );
|
||||
|
||||
if ( '' === $license_data ) {
|
||||
return get_option( $this->product->get_key() . '_license_status', 'not_active' );
|
||||
}
|
||||
|
||||
return isset( $license_data->license ) ? $license_data->license : get_option( $this->product->get_key() . '_license_status', 'not_active' );
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Get remote api url.
|
||||
*
|
||||
* @return string Remote api url.
|
||||
*/
|
||||
public function get_api_url() {
|
||||
if ( $this->is_from_partner( $this->product ) ) {
|
||||
return 'https://themeisle.com';
|
||||
}
|
||||
|
||||
return $this->product->get_store_url();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get remote api url.
|
||||
*
|
||||
* @return string Remote api url.
|
||||
*/
|
||||
public function get_distributor_name() {
|
||||
if ( $this->is_from_partner( $this->product ) ) {
|
||||
return 'ThemeIsle';
|
||||
}
|
||||
|
||||
return $this->product->get_store_name();
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the admin notice regarding the license status.
|
||||
*
|
||||
* @return bool Should we show the notice ?
|
||||
*/
|
||||
function show_notice() {
|
||||
if ( ! is_admin() ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if ( apply_filters( $this->product->get_key() . '_hide_license_notices', false ) ) {
|
||||
return;
|
||||
}
|
||||
$status = $this->get_license_status();
|
||||
$no_activations_string = apply_filters( $this->product->get_key() . '_lc_no_activations_string', 'No activations left for %s !!!. You need to upgrade your plan in order to use %s on more websites. Please ask the %s Staff for more details.' );
|
||||
$no_valid_string = apply_filters( $this->product->get_key() . '_lc_no_valid_string', 'In order to benefit from updates and support for %s, please add your license code from your <a href="%s" target="_blank">purchase history</a> and validate it <a href="%s">here</a>. ' );
|
||||
|
||||
// No activations left for this license.
|
||||
if ( 'valid' != $status && $this->check_activation() ) {
|
||||
?>
|
||||
<div class="error">
|
||||
<p><strong>
|
||||
<?php
|
||||
echo sprintf(
|
||||
$no_activations_string,
|
||||
$this->product->get_name(),
|
||||
$this->product->get_name(),
|
||||
'<a href="' . $this->get_api_url() . '" target="_blank">' . $this->get_distributor_name() . '</a>'
|
||||
);
|
||||
?>
|
||||
</strong>
|
||||
</p>
|
||||
</div>
|
||||
<?php
|
||||
return false;
|
||||
}
|
||||
// Invalid license key.
|
||||
if ( 'valid' != $status ) {
|
||||
?>
|
||||
<div class="error">
|
||||
<p>
|
||||
<strong><?php echo sprintf( $no_valid_string, $this->product->get_name() . ' ' . $this->product->get_type(), $this->get_api_url(), admin_url( 'options-general.php' ) . '#' . $this->product->get_key() . '_license' ); ?> </strong>
|
||||
</p>
|
||||
</div>
|
||||
<?php
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if the license is active or not.
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public function check_activation() {
|
||||
$license_data = get_option( $this->product->get_key() . '_license_data', '' );
|
||||
if ( '' === $license_data ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return isset( $license_data->error ) ? ( 'no_activations_left' == $license_data->error ) : false;
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if the license is about to expire in the next month.
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
function check_expiration() {
|
||||
$license_data = get_option( $this->product->get_key() . '_license_data', '' );
|
||||
if ( '' === $license_data ) {
|
||||
return false;
|
||||
}
|
||||
if ( ! isset( $license_data->expires ) ) {
|
||||
return false;
|
||||
}
|
||||
if ( strtotime( $license_data->expires ) - time() > 30 * 24 * 3600 ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the renew url from the store used.
|
||||
*
|
||||
* @return string The renew url.
|
||||
*/
|
||||
function renew_url() {
|
||||
$license_data = get_option( $this->product->get_key() . '_license_data', '' );
|
||||
if ( '' === $license_data ) {
|
||||
return $this->get_api_url();
|
||||
}
|
||||
if ( ! isset( $license_data->download_id ) || ! isset( $license_data->key ) ) {
|
||||
return $this->get_api_url();
|
||||
}
|
||||
|
||||
return $this->get_api_url() . '/checkout/?edd_license_key=' . $license_data->key . '&download_id=' . $license_data->download_id;
|
||||
}
|
||||
|
||||
/**
|
||||
* Run the license check call.
|
||||
*/
|
||||
public function product_valid() {
|
||||
if ( false !== ( $license = get_transient( $this->product->get_key() . '_license_data' ) ) ) {
|
||||
return;
|
||||
}
|
||||
$license = $this->check_license();
|
||||
set_transient( $this->product->get_key() . '_license_data', $license, 12 * HOUR_IN_SECONDS );
|
||||
update_option( $this->product->get_key() . '_license_data', $license );
|
||||
}
|
||||
|
||||
/**
|
||||
* Check the license status.
|
||||
*
|
||||
* @return object The license data.
|
||||
*/
|
||||
public function check_license() {
|
||||
$status = $this->get_license_status();
|
||||
if ( 'not_active' == $status ) {
|
||||
$license_data = new \stdClass();
|
||||
$license_data->license = 'not_active';
|
||||
|
||||
return $license_data;
|
||||
}
|
||||
$license = trim( $this->license_key );
|
||||
$api_params = array(
|
||||
'edd_action' => 'check_license',
|
||||
'license' => $license,
|
||||
'item_name' => rawurlencode( $this->product->get_name() ),
|
||||
'url' => rawurlencode( home_url() ),
|
||||
);
|
||||
// Call the custom API.
|
||||
$response = wp_remote_get(
|
||||
add_query_arg( $api_params, $this->get_api_url() ),
|
||||
array(
|
||||
'timeout' => 15,
|
||||
'sslverify' => false,
|
||||
)
|
||||
);
|
||||
if ( is_wp_error( $response ) ) {
|
||||
$license_data = new \stdClass();
|
||||
$license_data->license = 'valid';
|
||||
|
||||
} else {
|
||||
$license_data = json_decode( wp_remote_retrieve_body( $response ) );
|
||||
if ( ! is_object( $license_data ) ) {
|
||||
$license_data = new \stdClass();
|
||||
$license_data->license = 'valid';
|
||||
}
|
||||
}
|
||||
$license_old = get_option( $this->product->get_key() . '_license_data', '' );
|
||||
if ( 'valid' == $license_old->license && ( $license_data->license != $license_old->license ) ) {
|
||||
$this->increment_failed_checks();
|
||||
} else {
|
||||
$this->reset_failed_checks();
|
||||
}
|
||||
|
||||
if ( $this->failed_checks <= self::$max_failed ) {
|
||||
return $license_old;
|
||||
}
|
||||
|
||||
if ( isset( $license_old->hide_valid ) ) {
|
||||
$license_data->hide_valid = true;
|
||||
}
|
||||
|
||||
if ( ! isset( $license_data->key ) ) {
|
||||
$license_data->key = isset( $license_old->key ) ? $license_old->key : '';
|
||||
}
|
||||
|
||||
if ( isset( $license_old->hide_expiration ) ) {
|
||||
$license_data->hide_expiration = true;
|
||||
}
|
||||
|
||||
if ( isset( $license_old->hide_activation ) ) {
|
||||
$license_data->hide_activation = true;
|
||||
}
|
||||
|
||||
return $license_data;
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Increment the failed checks.
|
||||
*/
|
||||
private function increment_failed_checks() {
|
||||
$this->failed_checks ++;
|
||||
update_option( $this->product->get_key() . '_failed_checks', $this->failed_checks );
|
||||
}
|
||||
|
||||
/**
|
||||
* Reset the failed checks
|
||||
*/
|
||||
private function reset_failed_checks() {
|
||||
$this->failed_checks = 1;
|
||||
update_option( $this->product->get_key() . '_failed_checks', $this->failed_checks );
|
||||
}
|
||||
|
||||
/**
|
||||
* Set license validation error message.
|
||||
*
|
||||
* @param string $message Error message.
|
||||
*/
|
||||
public function set_error( $message = '' ) {
|
||||
set_transient( $this->product->get_key() . 'act_err', $message, MINUTE_IN_SECONDS );
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the last error message.
|
||||
*
|
||||
* @return mixed Error message.
|
||||
*/
|
||||
public function get_error() {
|
||||
return get_transient( $this->product->get_key() . 'act_err' );
|
||||
}
|
||||
|
||||
/**
|
||||
* Activate the license remotely.
|
||||
*/
|
||||
function activate_license() {
|
||||
// listen for our activate button to be clicked.
|
||||
if ( ! isset( $_POST[ $this->product->get_key() . '_btn_trigger' ] ) ) {
|
||||
return;
|
||||
}
|
||||
$status = $this->get_license_status();
|
||||
// retrieve the license from the database.
|
||||
$license = $_POST[ $this->product->get_key() . '_license' ];
|
||||
$api_params = array(
|
||||
'license' => $license,
|
||||
'item_name' => rawurlencode( $this->product->get_name() ),
|
||||
'url' => rawurlencode( home_url() ),
|
||||
);
|
||||
if ( 'valid' != $status ) {
|
||||
// data to send in our API request.
|
||||
$api_params['edd_action'] = 'activate_license';
|
||||
} else {
|
||||
$api_params['edd_action'] = 'deactivate_license';
|
||||
}
|
||||
// Call the custom API.
|
||||
$response = wp_remote_get( add_query_arg( $api_params, $this->get_api_url() ) );
|
||||
// make sure the response came back okay.
|
||||
if ( is_wp_error( $response ) ) {
|
||||
$this->set_error( sprintf( 'ERROR: Failed to connect to the license service. Please try again later. Reason: %s', $response->get_error_message() ) );
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
$license_data = json_decode( wp_remote_retrieve_body( $response ) );
|
||||
|
||||
if ( ! is_object( $license_data ) ) {
|
||||
$this->set_error( 'ERROR: Failed to validate license. Please try again in one minute.' );
|
||||
|
||||
return;
|
||||
}
|
||||
if ( ! isset( $license_data->license ) ) {
|
||||
$license_data->license = 'invalid';
|
||||
}
|
||||
|
||||
if ( ! isset( $license_data->key ) ) {
|
||||
$license_data->key = $license;
|
||||
}
|
||||
if ( 'valid' == $license_data->license ) {
|
||||
$this->reset_failed_checks();
|
||||
}
|
||||
|
||||
$this->set_error( '' );
|
||||
|
||||
if ( 'deactivate_license' === $api_params['edd_action'] ) {
|
||||
|
||||
delete_option( $this->product->get_key() . '_license_data' );
|
||||
delete_option( $this->product->get_key() . '_license_plan' );
|
||||
delete_transient( $this->product->get_key() . '_license_data' );
|
||||
|
||||
return;
|
||||
}
|
||||
if ( isset( $license_data->plan ) ) {
|
||||
update_option( $this->product->get_key() . '_license_plan', $license_data->plan );
|
||||
}
|
||||
update_option( $this->product->get_key() . '_license_data', $license_data );
|
||||
set_transient( $this->product->get_key() . '_license_data', $license_data, 12 * HOUR_IN_SECONDS );
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Load the Themes screen.
|
||||
*/
|
||||
function load_themes_screen() {
|
||||
add_thickbox();
|
||||
add_action( 'admin_notices', array( &$this, 'update_nag' ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Alter the nag for themes update.
|
||||
*/
|
||||
function update_nag() {
|
||||
$theme = wp_get_theme( $this->product->get_slug() );
|
||||
$api_response = get_transient( $this->product_key );
|
||||
if ( false === $api_response || ! isset( $api_response->new_version ) ) {
|
||||
return;
|
||||
}
|
||||
$update_url = wp_nonce_url( 'update.php?action=upgrade-theme&theme=' . urlencode( $this->product->get_slug() ), 'upgrade-theme_' . $this->product->get_slug() );
|
||||
$update_message = apply_filters( 'themeisle_sdk_license_update_message', 'Updating this theme will lose any customizations you have made. Cancel to stop, OK to update.' );
|
||||
$update_onclick = ' onclick="if ( confirm(\'' . esc_js( $update_message ) . '\') ) {return true;}return false;"';
|
||||
if ( version_compare( $this->product->get_version(), $api_response->new_version, '<' ) ) {
|
||||
echo '<div id="update-nag">';
|
||||
printf(
|
||||
'<strong>%1$s %2$s</strong> is available. <a href="%3$s" class="thickbox" title="%4s">Check out what\'s new</a> or <a href="%5$s"%6$s>update now</a>.',
|
||||
$theme->get( 'Name' ),
|
||||
$api_response->new_version,
|
||||
sprintf( '%s&TB_iframe=true&width=1024&height=800', $this->product->get_changelog() ),
|
||||
$theme->get( 'Name' ),
|
||||
$update_url,
|
||||
$update_onclick
|
||||
);
|
||||
echo '</div>';
|
||||
echo '<div id="' . $this->product->get_slug() . '_' . 'changelog" style="display:none;">';
|
||||
echo wpautop( $api_response->sections['changelog'] );
|
||||
echo '</div>';
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Alter update transient.
|
||||
*
|
||||
* @param mixed $value The transient data.
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
function theme_update_transient( $value ) {
|
||||
$update_data = $this->check_for_update();
|
||||
if ( $update_data ) {
|
||||
$value->response[ $this->product->get_slug() ] = $update_data;
|
||||
}
|
||||
|
||||
return $value;
|
||||
}
|
||||
|
||||
/**
|
||||
* Check for updates
|
||||
*
|
||||
* @return array|bool Either the update data or false in case of failure.
|
||||
*/
|
||||
function check_for_update() {
|
||||
$update_data = get_transient( $this->product_key );
|
||||
|
||||
if ( false === $update_data ) {
|
||||
$failed = false;
|
||||
$update_data = $this->get_version_data();
|
||||
if ( empty( $update_data ) ) {
|
||||
$failed = true;
|
||||
}
|
||||
// If the response failed, try again in 30 minutes.
|
||||
if ( $failed ) {
|
||||
$data = new \stdClass();
|
||||
$data->new_version = $this->product->get_version();
|
||||
set_transient( $this->product_key, $data, 30 * MINUTE_IN_SECONDS );
|
||||
|
||||
return false;
|
||||
}
|
||||
$update_data->sections = isset( $update_data->sections ) ? maybe_unserialize( $update_data->sections ) : null;
|
||||
|
||||
set_transient( $this->product_key, $update_data, 12 * HOUR_IN_SECONDS );
|
||||
}
|
||||
if ( ! isset( $update_data->new_version ) ) {
|
||||
return false;
|
||||
}
|
||||
if ( version_compare( $this->product->get_version(), $update_data->new_version, '>=' ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return (array) $update_data;
|
||||
}
|
||||
|
||||
/**
|
||||
* Check remote api for latest version.
|
||||
*
|
||||
* @return bool|mixed Update api response.
|
||||
*/
|
||||
private function get_version_data() {
|
||||
$api_params = array(
|
||||
'edd_action' => 'get_version',
|
||||
'version' => $this->product->get_version(),
|
||||
'license' => empty( $this->license_key ) ? 'free' : $this->license_key,
|
||||
'name' => rawurlencode( $this->product->get_name() ),
|
||||
'slug' => $this->product->get_slug(),
|
||||
'author' => rawurlencode( $this->get_distributor_name() ),
|
||||
'url' => rawurlencode( home_url() ),
|
||||
);
|
||||
$response = wp_remote_get(
|
||||
add_query_arg( $api_params, $this->get_api_url() ),
|
||||
array(
|
||||
'timeout' => 15,
|
||||
'sslverify' => false,
|
||||
)
|
||||
);
|
||||
if ( is_wp_error( $response ) || 200 != wp_remote_retrieve_response_code( $response ) ) {
|
||||
return false;
|
||||
}
|
||||
$update_data = json_decode( wp_remote_retrieve_body( $response ) );
|
||||
if ( ! is_object( $update_data ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $update_data;
|
||||
}
|
||||
|
||||
/**
|
||||
* Delete the update transient
|
||||
*/
|
||||
function delete_theme_update_transient() {
|
||||
delete_transient( $this->product_key );
|
||||
}
|
||||
|
||||
/**
|
||||
* Check for Updates at the defined API endpoint and modify the update array.
|
||||
*
|
||||
* @param array $_transient_data Update array build by WordPress.
|
||||
*
|
||||
* @return mixed Modified update array with custom plugin data.
|
||||
*/
|
||||
public function pre_set_site_transient_update_plugins_filter( $_transient_data ) {
|
||||
if ( empty( $_transient_data ) || ! $this->do_check ) {
|
||||
$this->do_check = true;
|
||||
|
||||
return $_transient_data;
|
||||
}
|
||||
$api_response = $this->api_request();
|
||||
if ( false !== $api_response && is_object( $api_response ) && isset( $api_response->new_version ) ) {
|
||||
if ( version_compare( $this->product->get_version(), $api_response->new_version, '<' ) ) {
|
||||
$_transient_data->response[ $this->product->get_slug() . '/' . $this->product->get_file() ] = $api_response;
|
||||
}
|
||||
}
|
||||
|
||||
return $_transient_data;
|
||||
}
|
||||
|
||||
/**
|
||||
* Calls the API and, if successfull, returns the object delivered by the API.
|
||||
*
|
||||
* @param string $_action The requested action.
|
||||
* @param array $_data Parameters for the API action.
|
||||
*
|
||||
* @return false||object
|
||||
*/
|
||||
private function api_request( $_action = '', $_data = '' ) {
|
||||
$update_data = $this->get_version_data();
|
||||
if ( empty( $update_data ) ) {
|
||||
return false;
|
||||
}
|
||||
if ( $update_data && isset( $update_data->sections ) ) {
|
||||
$update_data->sections = maybe_unserialize( $update_data->sections );
|
||||
}
|
||||
|
||||
return $update_data;
|
||||
}
|
||||
|
||||
/**
|
||||
* Updates information on the "View version x.x details" page with custom data.
|
||||
*
|
||||
* @param mixed $_data Plugin data.
|
||||
* @param string $_action Action to send.
|
||||
* @param object $_args Arguments to use.
|
||||
*
|
||||
* @return object $_data
|
||||
*/
|
||||
public function plugins_api_filter( $_data, $_action = '', $_args = null ) {
|
||||
if ( ( 'plugin_information' != $_action ) || ! isset( $_args->slug ) || ( $_args->slug != $this->product->get_slug() ) ) {
|
||||
return $_data;
|
||||
}
|
||||
$api_response = $this->api_request();
|
||||
if ( false !== $api_response ) {
|
||||
$_data = $api_response;
|
||||
}
|
||||
|
||||
return $_data;
|
||||
}
|
||||
|
||||
/**
|
||||
* Disable SSL verification in order to prevent download update failures.
|
||||
*
|
||||
* @param array $args Http args.
|
||||
* @param string $url Url to check.
|
||||
*
|
||||
* @return array $array
|
||||
*/
|
||||
function http_request_args( $args, $url ) {
|
||||
// If it is an https request and we are performing a package download, disable ssl verification.
|
||||
if ( strpos( $url, 'https://' ) !== false && strpos( $url, 'edd_action=package_download' ) ) {
|
||||
$args['sslverify'] = false;
|
||||
}
|
||||
|
||||
return $args;
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if we should load the module for this product.
|
||||
*
|
||||
* @param Product $product Product data.
|
||||
*
|
||||
* @return bool Should we load the module?
|
||||
*/
|
||||
public function can_load( $product ) {
|
||||
|
||||
if ( $product->is_wordpress_available() ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return ( apply_filters( $product->get_key() . '_enable_licenser', true ) === true );
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Load module logic.
|
||||
*
|
||||
* @param Product $product Product to load the module for.
|
||||
*
|
||||
* @return Licenser Module object.
|
||||
*/
|
||||
public function load( $product ) {
|
||||
$this->product = $product;
|
||||
|
||||
$this->product_key = $this->product->get_key() . '-update-response';
|
||||
|
||||
$this->license_key = $this->product->get_license();
|
||||
if ( $this->product->requires_license() ) {
|
||||
$this->failed_checks = intval( get_option( $this->product->get_key() . '_failed_checks', 0 ) );
|
||||
$this->register_license_hooks();
|
||||
}
|
||||
|
||||
if ( $this->product->is_plugin() ) {
|
||||
add_filter(
|
||||
'pre_set_site_transient_update_plugins',
|
||||
[
|
||||
$this,
|
||||
'pre_set_site_transient_update_plugins_filter',
|
||||
]
|
||||
);
|
||||
add_filter( 'plugins_api', array( $this, 'plugins_api_filter' ), 10, 3 );
|
||||
add_filter( 'http_request_args', array( $this, 'http_request_args' ), 10, 2 );
|
||||
|
||||
return $this;
|
||||
}
|
||||
if ( $this->product->is_theme() ) {
|
||||
add_filter( 'site_transient_update_themes', array( &$this, 'theme_update_transient' ) );
|
||||
add_filter( 'delete_site_transient_update_themes', array( &$this, 'delete_theme_update_transient' ) );
|
||||
add_action( 'load-update-core.php', array( &$this, 'delete_theme_update_transient' ) );
|
||||
add_action( 'load-themes.php', array( &$this, 'delete_theme_update_transient' ) );
|
||||
add_action( 'load-themes.php', array( &$this, 'load_themes_screen' ) );
|
||||
add_filter( 'http_request_args', array( $this, 'disable_wporg_update' ), 5, 2 );
|
||||
|
||||
return $this;
|
||||
|
||||
}
|
||||
|
||||
return $this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Register license fields for the products.
|
||||
*/
|
||||
public function register_license_hooks() {
|
||||
add_action( 'admin_init', array( $this, 'register_settings' ) );
|
||||
add_action( 'admin_init', array( $this, 'activate_license' ) );
|
||||
add_action( 'admin_init', array( $this, 'product_valid' ), 99999999 );
|
||||
add_action( 'admin_notices', array( $this, 'show_notice' ) );
|
||||
add_filter( $this->product->get_key() . '_license_status', array( $this, 'get_license_status' ) );
|
||||
}
|
||||
}
|
177
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Logger.php
vendored
Normal file
177
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Logger.php
vendored
Normal file
@ -0,0 +1,177 @@
|
||||
<?php
|
||||
/**
|
||||
* The logger model class for ThemeIsle SDK
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @subpackage Modules
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-3.0.php GNU Public License
|
||||
* @since 1.0.0
|
||||
*/
|
||||
|
||||
namespace ThemeisleSDK\Modules;
|
||||
|
||||
use ThemeisleSDK\Common\Abstract_Module;
|
||||
use ThemeisleSDK\Loader;
|
||||
use ThemeisleSDK\Product;
|
||||
|
||||
// Exit if accessed directly.
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
/**
|
||||
* Logger module for ThemeIsle SDK.
|
||||
*/
|
||||
class Logger extends Abstract_Module {
|
||||
/**
|
||||
* Endpoint where to collect logs.
|
||||
*/
|
||||
const TRACKING_ENDPOINT = 'http://log.themeisle.com/wp-json/v1/logs/';
|
||||
|
||||
|
||||
/**
|
||||
* Check if we should load the module for this product.
|
||||
*
|
||||
* @param Product $product Product to load the module for.
|
||||
*
|
||||
* @return bool Should we load ?
|
||||
*/
|
||||
public function can_load( $product ) {
|
||||
|
||||
return apply_filters( $product->get_slug() . '_sdk_enable_logger', true );
|
||||
}
|
||||
|
||||
/**
|
||||
* Load module logic.
|
||||
*
|
||||
* @param Product $product Product to load.
|
||||
*
|
||||
* @return Logger Module object.
|
||||
*/
|
||||
public function load( $product ) {
|
||||
$this->product = $product;
|
||||
$this->setup_notification();
|
||||
$this->setup_actions();
|
||||
|
||||
return $this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Setup notification on admin.
|
||||
*/
|
||||
public function setup_notification() {
|
||||
if ( ! $this->product->is_wordpress_available() ) {
|
||||
return;
|
||||
}
|
||||
|
||||
add_filter( 'themeisle_sdk_registered_notifications', [ $this, 'add_notification' ] );
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Setup tracking actions.
|
||||
*/
|
||||
public function setup_actions() {
|
||||
if ( ! $this->is_logger_active() ) {
|
||||
return;
|
||||
}
|
||||
$action_key = $this->product->get_key() . '_log_activity';
|
||||
if ( ! wp_next_scheduled( $action_key ) ) {
|
||||
wp_schedule_single_event( time() + ( rand( 1, 24 ) * 3600 ), $action_key );
|
||||
}
|
||||
add_action( $action_key, array( $this, 'send_log' ) );
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if the logger is active.
|
||||
*
|
||||
* @return bool Is logger active?
|
||||
*/
|
||||
private function is_logger_active() {
|
||||
if ( ! $this->product->is_wordpress_available() ) {
|
||||
return true;
|
||||
}
|
||||
$pro_slug = $this->product->get_pro_slug();
|
||||
|
||||
if ( ! empty( $pro_slug ) ) {
|
||||
$all_products = Loader::get_products();
|
||||
if ( isset( $all_products[ $pro_slug ] ) ) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
return ( get_option( $this->product->get_key() . '_logger_flag', 'no' ) === 'yes' );
|
||||
}
|
||||
|
||||
/**
|
||||
* Add notification to queue.
|
||||
*
|
||||
* @param array $all_notifications Previous notification.
|
||||
*
|
||||
* @return array All notifications.
|
||||
*/
|
||||
public function add_notification( $all_notifications ) {
|
||||
|
||||
$message = apply_filters( $this->product->get_key() . '_logger_heading', 'Do you enjoy <b>{product}</b>? Become a contributor by opting in to our anonymous data tracking. We guarantee no sensitive data is collected.' );
|
||||
|
||||
$message = str_replace(
|
||||
array( '{product}' ),
|
||||
$this->product->get_friendly_name(),
|
||||
$message
|
||||
);
|
||||
$button_submit = apply_filters( $this->product->get_key() . '_logger_button_submit', 'Sure, I would love to help.' );
|
||||
$button_cancel = apply_filters( $this->product->get_key() . '_logger_button_cancel', 'No, thanks.' );
|
||||
|
||||
$all_notifications[] = [
|
||||
'id' => $this->product->get_key() . '_logger_flag',
|
||||
'message' => $message,
|
||||
'ctas' => [
|
||||
'confirm' => [
|
||||
'link' => '#',
|
||||
'text' => $button_submit,
|
||||
],
|
||||
'cancel' => [
|
||||
'link' => '#',
|
||||
'text' => $button_cancel,
|
||||
],
|
||||
],
|
||||
];
|
||||
|
||||
return $all_notifications;
|
||||
}
|
||||
|
||||
/**
|
||||
* Send the statistics to the api endpoint.
|
||||
*/
|
||||
public function send_log() {
|
||||
$environment = array();
|
||||
$theme = wp_get_theme();
|
||||
$environment['theme'] = array();
|
||||
$environment['theme']['name'] = $theme->get( 'Name' );
|
||||
$environment['theme']['author'] = $theme->get( 'Author' );
|
||||
$environment['plugins'] = get_option( 'active_plugins' );
|
||||
global $wp_version;
|
||||
wp_remote_post(
|
||||
self::TRACKING_ENDPOINT,
|
||||
array(
|
||||
'method' => 'POST',
|
||||
'timeout' => 3,
|
||||
'redirection' => 5,
|
||||
'headers' => array(
|
||||
'X-ThemeIsle-Event' => 'log_site',
|
||||
),
|
||||
'body' => array(
|
||||
'site' => get_site_url(),
|
||||
'slug' => $this->product->get_slug(),
|
||||
'version' => $this->product->get_version(),
|
||||
'wp_version' => $wp_version,
|
||||
'data' => apply_filters( $this->product->get_key() . '_logger_data', array() ),
|
||||
'environment' => $environment,
|
||||
'license' => apply_filters( $this->product->get_key() . '_license_status', '' ),
|
||||
),
|
||||
)
|
||||
);
|
||||
}
|
||||
}
|
459
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Notification.php
vendored
Normal file
459
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Notification.php
vendored
Normal file
@ -0,0 +1,459 @@
|
||||
<?php
|
||||
/**
|
||||
* The notification model class for ThemeIsle SDK
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @subpackage Modules
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-3.0.php GNU Public License
|
||||
* @since 1.0.0
|
||||
*/
|
||||
|
||||
namespace ThemeisleSDK\Modules;
|
||||
|
||||
use ThemeisleSDK\Common\Abstract_Module;
|
||||
use ThemeisleSDK\Product;
|
||||
|
||||
// Exit if accessed directly.
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
/**
|
||||
* Notification module for ThemeIsle SDK.
|
||||
*/
|
||||
class Notification extends Abstract_Module {
|
||||
/**
|
||||
* Show notifications only after the user has the product installed after this amount of time, in hours.
|
||||
*/
|
||||
const MIN_INSTALL_TIME = 100;
|
||||
/**
|
||||
* How much time should we show the notification, in days.
|
||||
*/
|
||||
const MAX_TIME_TO_LIVE = 7;
|
||||
|
||||
/**
|
||||
* Number of days between notifications.
|
||||
*/
|
||||
const TIME_BETWEEN_NOTIFICATIONS = 5;
|
||||
|
||||
/**
|
||||
* Holds a possible notification list.
|
||||
*
|
||||
* @var array Notifications list.
|
||||
*/
|
||||
private static $notifications = [];
|
||||
|
||||
/**
|
||||
* Show notification data.
|
||||
*/
|
||||
public static function show_notification() {
|
||||
|
||||
$current_notification = self::get_last_notification();
|
||||
|
||||
$notification_details = [];
|
||||
// Check if the saved notification is still present among the possible ones.
|
||||
if ( ! empty( $current_notification ) ) {
|
||||
$notification_details = self::get_notification_details( $current_notification );
|
||||
if ( empty( $notification_details ) ) {
|
||||
$current_notification = [];
|
||||
}
|
||||
}
|
||||
// Check if the notificatin is expired.
|
||||
if ( ! empty( $current_notification ) && self::is_notification_expired( $current_notification ) ) {
|
||||
update_option( $current_notification['id'], 'no' );
|
||||
self::set_last_active_notification_timestamp();
|
||||
$current_notification = [];
|
||||
}
|
||||
// If we don't have any saved notification, get a new one.
|
||||
if ( empty( $current_notification ) ) {
|
||||
$notification_details = self::get_random_notification();
|
||||
if ( empty( $notification_details ) ) {
|
||||
return;
|
||||
}
|
||||
self::set_active_notification(
|
||||
[
|
||||
'id' => $notification_details['id'],
|
||||
'display_at' => time(),
|
||||
]
|
||||
);
|
||||
}
|
||||
if ( empty( $notification_details ) ) {
|
||||
return;
|
||||
}
|
||||
$notification_html = self::get_notification_html( $notification_details );
|
||||
do_action( $notification_details['id'] . '_before_render' );
|
||||
|
||||
echo $notification_html;
|
||||
|
||||
do_action( $notification_details['id'] . '_after_render' );
|
||||
self::render_snippets();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get last notification details.
|
||||
*
|
||||
* @return array Last notification details.
|
||||
*/
|
||||
private static function get_last_notification() {
|
||||
$notification = self::get_notifications_metadata();
|
||||
|
||||
return isset( $notification['last_notification'] ) ? $notification['last_notification'] : [];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get notification center details.
|
||||
*
|
||||
* @return array Notification center details.
|
||||
*/
|
||||
private static function get_notifications_metadata() {
|
||||
|
||||
$data = get_option(
|
||||
'themeisle_sdk_notifications',
|
||||
[
|
||||
'last_notification' => [],
|
||||
'last_notification_active' => 0,
|
||||
]
|
||||
);
|
||||
|
||||
return $data;
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if the notification is still possible.
|
||||
*
|
||||
* @param array $notification Notification to check.
|
||||
*
|
||||
* @return array Either is still active or not.
|
||||
*/
|
||||
private static function get_notification_details( $notification ) {
|
||||
$notifications = array_filter(
|
||||
self::$notifications,
|
||||
function ( $value ) use ( $notification ) {
|
||||
if ( isset( $value['id'] ) && isset( $notification['id'] ) && $value['id'] === $notification['id'] ) {
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
);
|
||||
|
||||
return ! empty( $notifications ) ? reset( $notifications ) : [];
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if the notification is expired.
|
||||
*
|
||||
* @param array $notification Notification to check.
|
||||
*
|
||||
* @return bool Either the notification is due.
|
||||
*/
|
||||
private static function is_notification_expired( $notification ) {
|
||||
if ( ! isset( $notification['display_at'] ) ) {
|
||||
return true;
|
||||
}
|
||||
|
||||
$notifications = array_filter(
|
||||
self::$notifications,
|
||||
function ( $value ) use ( $notification ) {
|
||||
if ( isset( $value['id'] ) && isset( $notification['id'] ) && $value['id'] === $notification['id'] ) {
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
);
|
||||
|
||||
if ( empty( $notifications ) ) {
|
||||
return true;
|
||||
}
|
||||
$notification_definition = reset( $notifications );
|
||||
|
||||
$when_to_expire = isset( $notification_definition['expires_at'] )
|
||||
? $notification_definition['expires_at'] :
|
||||
( isset( $notification_definition['expires'] )
|
||||
? ( $notification['display_at'] + $notification_definition['expires'] ) :
|
||||
( $notification['display_at'] + self::MAX_TIME_TO_LIVE * DAY_IN_SECONDS )
|
||||
);
|
||||
|
||||
return ( $when_to_expire - time() ) < 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set last notification details.
|
||||
*/
|
||||
private static function set_last_active_notification_timestamp() {
|
||||
$metadata = self::get_notifications_metadata();
|
||||
$metadata['last_notification_active'] = time();
|
||||
update_option( 'themeisle_sdk_notifications', $metadata );
|
||||
}
|
||||
|
||||
/**
|
||||
* Return notification to show.
|
||||
*
|
||||
* @return array Notification data.
|
||||
*/
|
||||
public static function get_random_notification() {
|
||||
if ( ( time() - self::get_last_active_notification_timestamp() ) < self::TIME_BETWEEN_NOTIFICATIONS * DAY_IN_SECONDS ) {
|
||||
return [];
|
||||
}
|
||||
|
||||
$notifications = self::$notifications;
|
||||
$notifications = array_filter(
|
||||
$notifications,
|
||||
function ( $value ) {
|
||||
if ( isset( $value['sticky'] ) && true === $value['sticky'] ) {
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
);
|
||||
// No priority notifications, use all.
|
||||
if ( empty( $notifications ) ) {
|
||||
$notifications = self::$notifications;
|
||||
}
|
||||
if ( empty( $notifications ) ) {
|
||||
return [];
|
||||
}
|
||||
$notifications = array_values( $notifications );
|
||||
|
||||
return $notifications[ array_rand( $notifications, 1 ) ];
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Get last notification details.
|
||||
*
|
||||
* @return array Last notification details.
|
||||
*/
|
||||
private static function get_last_active_notification_timestamp() {
|
||||
$notification = self::get_notifications_metadata();
|
||||
|
||||
return isset( $notification['last_notification_active'] ) ? $notification['last_notification_active'] : 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get last notification details.
|
||||
*
|
||||
* @param array $notification Notification data.
|
||||
*/
|
||||
private static function set_active_notification( $notification ) {
|
||||
$metadata = self::get_notifications_metadata();
|
||||
$metadata['last_notification'] = $notification;
|
||||
update_option( 'themeisle_sdk_notifications', $metadata );
|
||||
}
|
||||
|
||||
/**
|
||||
* Get notification html.
|
||||
*
|
||||
* @param array $notification_details Notification details.
|
||||
*
|
||||
* @return string Html for notice.
|
||||
*/
|
||||
public static function get_notification_html( $notification_details ) {
|
||||
$default = [
|
||||
'id' => '',
|
||||
'heading' => '',
|
||||
'message' => '',
|
||||
'ctas' => [
|
||||
'confirm' => [
|
||||
'link' => '#',
|
||||
'text' => '',
|
||||
],
|
||||
'cancel' => [
|
||||
'link' => '#',
|
||||
'text' => '',
|
||||
],
|
||||
],
|
||||
];
|
||||
$notification_details = wp_parse_args( $notification_details, $default );
|
||||
|
||||
$notification_html = '<div class="notice notice-success is-dismissible themeisle-sdk-notice" data-notification-id="' . esc_attr( $notification_details['id'] ) . '" id="' . esc_attr( $notification_details['id'] ) . '-notification"> <div class="themeisle-sdk-notification-box">';
|
||||
|
||||
if ( ! empty( $notification_details['heading'] ) ) {
|
||||
$notification_html .= sprintf( '<h4>%s</h4>', wp_kses_post( $notification_details['heading'] ) );
|
||||
}
|
||||
if ( ! empty( $notification_details['message'] ) ) {
|
||||
$notification_html .= wp_kses_post( $notification_details['message'] );
|
||||
}
|
||||
$notification_html .= '<div class="actions">';
|
||||
|
||||
if ( ! empty( $notification_details['ctas']['confirm']['text'] ) ) {
|
||||
$notification_html .= sprintf(
|
||||
'<a href="%s" target="_blank" class=" button button-primary %s" data-confirm="yes" >%s</a>',
|
||||
esc_url( $notification_details['ctas']['confirm']['link'] ),
|
||||
esc_attr( $notification_details['id'] . '_confirm' ),
|
||||
wp_kses_post( $notification_details['ctas']['confirm']['text'] )
|
||||
);
|
||||
}
|
||||
|
||||
if ( ! empty( $notification_details['ctas']['cancel']['text'] ) ) {
|
||||
$notification_html .= sprintf(
|
||||
'<a href="%s" class=" button %s" data-confirm="no">%s</a>',
|
||||
esc_url( $notification_details['ctas']['cancel']['link'] ),
|
||||
esc_attr( $notification_details['id'] ) . '_cancel',
|
||||
wp_kses_post( $notification_details['ctas']['cancel']['text'] )
|
||||
);
|
||||
}
|
||||
|
||||
$notification_html .= '</div>';
|
||||
$notification_html .= ' </div>';
|
||||
$notification_html .= ' </div>';
|
||||
|
||||
return $notification_html;
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds js snippet for hiding the notice.
|
||||
*/
|
||||
public static function render_snippets() {
|
||||
|
||||
?>
|
||||
<style type="text/css">
|
||||
.themeisle-sdk-notification-box {
|
||||
padding: 3px;
|
||||
}
|
||||
|
||||
.themeisle-sdk-notification-box .actions {
|
||||
margin-top: 6px;
|
||||
margin-bottom: 4px;
|
||||
}
|
||||
|
||||
.themeisle-sdk-notification-box .button {
|
||||
margin-right: 5px;
|
||||
}
|
||||
</style>
|
||||
<script type="text/javascript">
|
||||
(function ($) {
|
||||
$(document).ready(function () {
|
||||
$('#wpbody-content').on('click', ".themeisle-sdk-notice a.button, .themeisle-sdk-notice .notice-dismiss", function (e) {
|
||||
|
||||
var container = $('.themeisle-sdk-notice');
|
||||
var link = $(this);
|
||||
var notification_id = container.attr('data-notification-id');
|
||||
var confirm = link.attr('data-confirm');
|
||||
if (typeof confirm === "undefined") {
|
||||
confirm = 'no';
|
||||
}
|
||||
$.post(
|
||||
ajaxurl,
|
||||
{
|
||||
'nonce': '<?php echo wp_create_nonce( (string) __CLASS__ ); ?>',
|
||||
'action': 'themeisle_sdk_dismiss_notice',
|
||||
'id': notification_id,
|
||||
'confirm': confirm
|
||||
}
|
||||
);
|
||||
if (confirm === 'yes') {
|
||||
$(this).trigger('themeisle-sdk:confirmed');
|
||||
} else {
|
||||
$(this).trigger('themeisle-sdk:canceled');
|
||||
}
|
||||
container.hide();
|
||||
if (link.attr('href') === '#') {
|
||||
return false;
|
||||
}
|
||||
});
|
||||
});
|
||||
})(jQuery);
|
||||
</script>
|
||||
<?php
|
||||
}
|
||||
|
||||
/**
|
||||
* Dismiss the notification.
|
||||
*/
|
||||
static function dismiss() {
|
||||
check_ajax_referer( (string) __CLASS__, 'nonce' );
|
||||
|
||||
$id = isset( $_POST['id'] ) ? sanitize_text_field( $_POST['id'] ) : '';
|
||||
$confirm = isset( $_POST['confirm'] ) ? sanitize_text_field( $_POST['confirm'] ) : 'no';
|
||||
|
||||
if ( empty( $id ) ) {
|
||||
wp_send_json( [] );
|
||||
}
|
||||
self::set_last_active_notification_timestamp();
|
||||
update_option( $id, $confirm );
|
||||
do_action( $id . '_process_confirm', $confirm );
|
||||
wp_send_json( [] );
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if we should load the notification module.
|
||||
*
|
||||
* @param Product $product Product to check.
|
||||
*
|
||||
* @return bool Should we load this?
|
||||
*/
|
||||
public function can_load( $product ) {
|
||||
|
||||
if ( $this->is_from_partner( $product ) ) {
|
||||
return false;
|
||||
}
|
||||
if ( ! current_user_can( 'manage_options' ) ) {
|
||||
return false;
|
||||
}
|
||||
if ( ( time() - $product->get_install_time() ) < ( self::MIN_INSTALL_TIME * HOUR_IN_SECONDS ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Setup notifications queue.
|
||||
*/
|
||||
public static function setup_notifications() {
|
||||
$notifications = apply_filters( 'themeisle_sdk_registered_notifications', [] );
|
||||
$notifications = array_filter(
|
||||
$notifications,
|
||||
function ( $value ) {
|
||||
if ( ! isset( $value['id'] ) ) {
|
||||
return false;
|
||||
}
|
||||
if ( get_option( $value['id'], '' ) !== '' ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return apply_filters( $value['id'] . '_should_show', true );
|
||||
}
|
||||
);
|
||||
self::$notifications = $notifications;
|
||||
}
|
||||
/**
|
||||
* Load the module logic.
|
||||
*
|
||||
* @param Product $product Product to load the module for.
|
||||
*
|
||||
* @return Notification Module instance.
|
||||
*/
|
||||
public function load( $product ) {
|
||||
if ( apply_filters( 'themeisle_sdk_hide_notifications', false ) ) {
|
||||
return;
|
||||
}
|
||||
$this->product = $product;
|
||||
|
||||
$notifications = apply_filters( 'themeisle_sdk_registered_notifications', [] );
|
||||
$notifications = array_filter(
|
||||
$notifications,
|
||||
function ( $value ) {
|
||||
if ( ! isset( $value['id'] ) ) {
|
||||
return false;
|
||||
}
|
||||
if ( get_option( $value['id'], '' ) !== '' ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return apply_filters( $value['id'] . '_should_show', true );
|
||||
}
|
||||
);
|
||||
self::$notifications = $notifications;
|
||||
add_action( 'admin_notices', array( __CLASS__, 'show_notification' ) );
|
||||
add_action( 'wp_ajax_themeisle_sdk_dismiss_notice', array( __CLASS__, 'dismiss' ) );
|
||||
add_action( 'admin_head', array( __CLASS__, 'setup_notifications' ) );
|
||||
|
||||
return $this;
|
||||
}
|
||||
}
|
374
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Recommendation.php
vendored
Normal file
374
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Recommendation.php
vendored
Normal file
@ -0,0 +1,374 @@
|
||||
<?php
|
||||
/**
|
||||
* The class that exposes hooks for recommend.
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @subpackage Rollback
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-3.0.php GNU Public License
|
||||
* @since 1.0.0
|
||||
*/
|
||||
|
||||
namespace ThemeisleSDK\Modules;
|
||||
|
||||
// Exit if accessed directly.
|
||||
use ThemeisleSDK\Common\Abstract_Module;
|
||||
use ThemeisleSDK\Product;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
/**
|
||||
* Expose endpoints for ThemeIsle SDK.
|
||||
*/
|
||||
class Recommendation extends Abstract_Module {
|
||||
|
||||
|
||||
/**
|
||||
* Load module logic.
|
||||
*
|
||||
* @param Product $product Product to load.
|
||||
*/
|
||||
public function load( $product ) {
|
||||
$this->product = $product;
|
||||
$this->setup_hooks();
|
||||
|
||||
return $this;
|
||||
}
|
||||
|
||||
/**
|
||||
* Setup endpoints.
|
||||
*/
|
||||
private function setup_hooks() {
|
||||
add_action( $this->product->get_key() . '_recommend_products', array( $this, 'render_products_box' ), 10, 4 );
|
||||
add_action( 'admin_head', array( $this, 'enqueue' ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if we should load the module for this product.
|
||||
*
|
||||
* @param Product $product Product data.
|
||||
*
|
||||
* @return bool Should we load the module?
|
||||
*/
|
||||
public function can_load( $product ) {
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Render products box content.
|
||||
*
|
||||
* @param array $plugins_list - list of useful plugins (in slug => nicename format).
|
||||
* @param array $themes_list - list of useful themes (in slug => nicename format).
|
||||
* @param array $strings - list of translated strings.
|
||||
* @param array $preferences - list of preferences.
|
||||
*/
|
||||
function render_products_box( $plugins_list, $themes_list, $strings, $preferences = array() ) {
|
||||
|
||||
if ( empty( $plugins_list ) && empty( $themes_list ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
if ( ! empty( $plugins_list ) && ! current_user_can( 'install_plugins' ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
if ( ! empty( $themes_list ) && ! current_user_can( 'install_themes' ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
add_thickbox();
|
||||
|
||||
if ( ! empty( $themes_list ) ) {
|
||||
$list = $this->get_themes( $themes_list, $preferences );
|
||||
|
||||
if ( has_action( $this->product->get_key() . '_recommend_products_theme_template' ) ) {
|
||||
do_action( $this->product->get_key() . '_recommend_products_theme_template', $list, $strings, $preferences );
|
||||
} else {
|
||||
echo '<div class="recommend-product">';
|
||||
|
||||
foreach ( $list as $theme ) {
|
||||
echo '<div class="plugin_box">';
|
||||
echo ' <img class="theme-banner" src="' . $theme->screenshot_url . '">';
|
||||
echo ' <div class="title-action-wrapper">';
|
||||
echo ' <span class="plugin-name">' . esc_html( $theme->custom_name ) . '</span>';
|
||||
if ( ! isset( $preferences['description'] ) || ( isset( $preferences['description'] ) && $preferences['description'] ) ) {
|
||||
echo '<span class="plugin-desc">' . esc_html( substr( $theme->description, 0, strpos( $theme->description, '.' ) ) ) . '.</span>';
|
||||
}
|
||||
echo ' </div>';
|
||||
echo '<div class="plugin-box-footer">';
|
||||
echo ' <div class="button-wrap">';
|
||||
echo ' <a class="button button-primary " href="' . esc_url( $theme->custom_url ) . '"><span class="dashicons dashicons-external"></span>' . esc_html( $strings['install'] ) . '</a>';
|
||||
echo ' </div>';
|
||||
echo ' </div>';
|
||||
echo '</div>';
|
||||
}
|
||||
|
||||
echo '</div>';
|
||||
}
|
||||
}
|
||||
if ( ! empty( $plugins_list ) ) {
|
||||
$list = $this->get_plugins( $plugins_list, $preferences );
|
||||
|
||||
if ( has_action( $this->product->get_key() . '_recommend_products_plugin_template' ) ) {
|
||||
do_action( $this->product->get_key() . '_recommend_products_plugin_template', $list, $strings, $preferences );
|
||||
} else {
|
||||
echo '<div class="recommend-product">';
|
||||
|
||||
foreach ( $list as $current_plugin ) {
|
||||
echo '<div class="plugin_box">';
|
||||
echo ' <img class="plugin-banner" src="' . $current_plugin->custom_image . '">';
|
||||
echo ' <div class="title-action-wrapper">';
|
||||
echo ' <span class="plugin-name">' . esc_html( $current_plugin->custom_name ) . '</span>';
|
||||
if ( ! isset( $preferences['description'] ) || ( isset( $preferences['description'] ) && $preferences['description'] ) ) {
|
||||
echo '<span class="plugin-desc">' . esc_html( substr( $current_plugin->short_description, 0, strpos( $current_plugin->short_description, '.' ) ) ) . '. </span>';
|
||||
}
|
||||
echo ' </div>';
|
||||
echo ' <div class="plugin-box-footer">';
|
||||
echo ' <a class="button button-primary thickbox open-plugin-details-modal" href="' . esc_url( $current_plugin->custom_url ) . '"><span class="dashicons dashicons-external"></span>' . esc_html( $strings['install'] ) . '</a>';
|
||||
echo ' </div>';
|
||||
echo '</div>';
|
||||
}
|
||||
|
||||
echo '</div>';
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Collect all the information for the themes list.
|
||||
*
|
||||
* @param array $themes_list - list of useful themes (in slug => nicename format).
|
||||
* @param array $preferences - list of preferences.
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
private function get_themes( $themes_list, $preferences ) {
|
||||
$list = array();
|
||||
foreach ( $themes_list as $slug => $nicename ) {
|
||||
$theme = $this->call_theme_api( $slug );
|
||||
if ( ! $theme ) {
|
||||
continue;
|
||||
}
|
||||
|
||||
$url = add_query_arg(
|
||||
array(
|
||||
'theme' => $theme->slug,
|
||||
),
|
||||
network_admin_url( 'theme-install.php' )
|
||||
);
|
||||
|
||||
$name = empty( $nicename ) ? $theme->name : $nicename;
|
||||
|
||||
$theme->custom_url = $url;
|
||||
$theme->custom_name = $name;
|
||||
|
||||
$list[] = $theme;
|
||||
}
|
||||
|
||||
return $list;
|
||||
}
|
||||
|
||||
/**
|
||||
* Call theme api
|
||||
*
|
||||
* @param string $slug theme slug.
|
||||
*
|
||||
* @return array|mixed|object
|
||||
*/
|
||||
private function call_theme_api( $slug ) {
|
||||
$theme = get_transient( 'ti_theme_info_' . $slug );
|
||||
|
||||
if ( false !== $theme ) {
|
||||
return $theme;
|
||||
}
|
||||
|
||||
$products = wp_remote_get(
|
||||
'https://api.wordpress.org/themes/info/1.1/?action=query_themes&request[theme]=' . $slug . '&request[per_page]=1'
|
||||
);
|
||||
$products = json_decode( wp_remote_retrieve_body( $products ) );
|
||||
if ( is_object( $products ) ) {
|
||||
$theme = $products->themes[0];
|
||||
set_transient( 'ti_theme_info_' . $slug, $theme, 6 * HOUR_IN_SECONDS );
|
||||
}
|
||||
|
||||
return $theme;
|
||||
}
|
||||
|
||||
/**
|
||||
* Collect all the information for the plugins list.
|
||||
*
|
||||
* @param array $plugins_list - list of useful plugins (in slug => nicename format).
|
||||
* @param array $preferences - list of preferences.
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
private function get_plugins( $plugins_list, $preferences ) {
|
||||
$list = array();
|
||||
foreach ( $plugins_list as $plugin => $nicename ) {
|
||||
$current_plugin = $this->call_plugin_api( $plugin );
|
||||
|
||||
$name = empty( $nicename ) ? $current_plugin->name : $nicename;
|
||||
|
||||
$image = $current_plugin->banners['low'];
|
||||
if ( isset( $preferences['image'] ) && 'icon' === $preferences['image'] ) {
|
||||
$image = $current_plugin->icons['1x'];
|
||||
}
|
||||
|
||||
$url = add_query_arg(
|
||||
array(
|
||||
'tab' => 'plugin-information',
|
||||
'plugin' => $current_plugin->slug,
|
||||
'TB_iframe' => true,
|
||||
'width' => 800,
|
||||
'height' => 800,
|
||||
),
|
||||
network_admin_url( 'plugin-install.php' )
|
||||
);
|
||||
|
||||
$current_plugin->custom_url = $url;
|
||||
$current_plugin->custom_name = $name;
|
||||
$current_plugin->custom_image = $image;
|
||||
|
||||
$list[] = $current_plugin;
|
||||
}
|
||||
|
||||
return $list;
|
||||
}
|
||||
|
||||
/**
|
||||
* Call plugin api
|
||||
*
|
||||
* @param string $slug plugin slug.
|
||||
*
|
||||
* @return array|mixed|object
|
||||
*/
|
||||
private function call_plugin_api( $slug ) {
|
||||
include_once( ABSPATH . 'wp-admin/includes/plugin-install.php' );
|
||||
|
||||
$call_api = get_transient( 'ti_plugin_info_' . $slug );
|
||||
|
||||
if ( false === $call_api ) {
|
||||
$call_api = plugins_api(
|
||||
'plugin_information',
|
||||
array(
|
||||
'slug' => $slug,
|
||||
'fields' => array(
|
||||
'downloaded' => false,
|
||||
'rating' => false,
|
||||
'description' => false,
|
||||
'short_description' => true,
|
||||
'donate_link' => false,
|
||||
'tags' => false,
|
||||
'sections' => true,
|
||||
'homepage' => true,
|
||||
'added' => false,
|
||||
'last_updated' => false,
|
||||
'compatibility' => false,
|
||||
'tested' => false,
|
||||
'requires' => false,
|
||||
'downloadlink' => false,
|
||||
'icons' => true,
|
||||
'banners' => true,
|
||||
),
|
||||
)
|
||||
);
|
||||
set_transient( 'ti_plugin_info_' . $slug, $call_api, 30 * MINUTE_IN_SECONDS );
|
||||
}
|
||||
|
||||
return $call_api;
|
||||
}
|
||||
|
||||
/**
|
||||
* Load css and scripts for the plugin recommend page.
|
||||
*/
|
||||
public function enqueue() {
|
||||
$screen = get_current_screen();
|
||||
|
||||
if ( ! isset( $screen->id ) ) {
|
||||
return;
|
||||
}
|
||||
if ( false === apply_filters( $this->product->get_key() . '_enqueue_recommend', false, $screen->id ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
?>
|
||||
<style type="text/css">
|
||||
.recommend-product {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
flex-wrap: wrap;
|
||||
}
|
||||
|
||||
.recommend-product .theme-banner {
|
||||
width:200px;
|
||||
margin: auto;
|
||||
}
|
||||
.recommend-product .plugin-banner {
|
||||
width: 100px;
|
||||
margin: auto;
|
||||
}
|
||||
|
||||
.recommend-product .plugin_box .button span{
|
||||
|
||||
margin-top: 2px;
|
||||
margin-right: 7px;
|
||||
}
|
||||
.recommend-product .plugin_box .button{
|
||||
margin-bottom:10px;
|
||||
}
|
||||
.recommend-product .plugin_box {
|
||||
margin-bottom: 20px;
|
||||
padding-top: 5px;
|
||||
display: flex;
|
||||
box-shadow: 0px 0px 10px -5px rgba(0,0,0,0.55);
|
||||
background: #fff;
|
||||
border-radius: 5px;
|
||||
flex-direction: column;
|
||||
justify-content: flex-start;
|
||||
width: 95%;
|
||||
}
|
||||
|
||||
.recommend-product .title-action-wrapper {
|
||||
padding: 15px 20px 5px 20px;
|
||||
}
|
||||
|
||||
.recommend-product .plugin-name {
|
||||
font-size: 18px;
|
||||
display: block;
|
||||
white-space: nowrap;
|
||||
text-overflow: ellipsis;
|
||||
margin-bottom: 10px;
|
||||
overflow: hidden;
|
||||
line-height: normal;
|
||||
}
|
||||
|
||||
|
||||
.recommend-product .plugin-desc {
|
||||
display: block;
|
||||
margin-bottom: 10px;
|
||||
font-size: 13px;
|
||||
color: #777;
|
||||
line-height: 1.6;
|
||||
}
|
||||
|
||||
.recommend-product .button-wrap > div {
|
||||
padding: 0;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.plugin-box-footer {
|
||||
display: flex;
|
||||
justify-content: space-around;
|
||||
vertical-align: middle;
|
||||
align-items: center;
|
||||
padding: 0px 10px 5px;
|
||||
flex: 1;
|
||||
margin-top: auto;
|
||||
}
|
||||
</style>
|
||||
<?php
|
||||
}
|
||||
}
|
117
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Review.php
vendored
Normal file
117
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Review.php
vendored
Normal file
@ -0,0 +1,117 @@
|
||||
<?php
|
||||
/**
|
||||
* The Review model class for ThemeIsle SDK
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @subpackage Modules
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-3.0.php GNU Public License
|
||||
* @since 1.0.0
|
||||
*/
|
||||
|
||||
namespace ThemeisleSDK\Modules;
|
||||
|
||||
use ThemeisleSDK\Common\Abstract_Module;
|
||||
use ThemeisleSDK\Product;
|
||||
|
||||
// Exit if accessed directly.
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
/**
|
||||
* Review module for ThemeIsle SDK.
|
||||
*/
|
||||
class Review extends Abstract_Module {
|
||||
|
||||
/**
|
||||
* Check if we should load module for this.
|
||||
*
|
||||
* @param Product $product Product to check.
|
||||
*
|
||||
* @return bool Should load ?
|
||||
*/
|
||||
public function can_load( $product ) {
|
||||
if ( $this->is_from_partner( $product ) ) {
|
||||
return false;
|
||||
}
|
||||
if ( ! $product->is_wordpress_available() ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return apply_filters( $product->get_slug() . '_sdk_should_review', true );
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Add notification to queue.
|
||||
*
|
||||
* @param array $all_notifications Previous notification.
|
||||
*
|
||||
* @return array All notifications.
|
||||
*/
|
||||
public function add_notification( $all_notifications ) {
|
||||
|
||||
$developers = [
|
||||
'Bogdan',
|
||||
'Marius',
|
||||
'Hardeep',
|
||||
'Rodica',
|
||||
'Stefan',
|
||||
'Uriahs',
|
||||
'Madalin',
|
||||
'Radu',
|
||||
'Silviu',
|
||||
'Andrei',
|
||||
];
|
||||
|
||||
$link = 'https://wordpress.org/support/' . $this->product->get_type() . '/' . $this->product->get_slug() . '/reviews/#wporg-footer';
|
||||
|
||||
$message = apply_filters( $this->product->get_key() . '_feedback_review_message', '<p>Hey, it’s great to see you have <b>{product}</b> active for a few days now. How is everything going? If you can spare a few moments to rate it on WordPress.org it would help us a lot (and boost my motivation). Cheers! <br/> <br/>~ {developer}, developer of {product}</p>' );
|
||||
|
||||
$button_submit = apply_filters( $this->product->get_key() . '_feedback_review_button_do', 'Ok, I will gladly help.' );
|
||||
$button_cancel = apply_filters( $this->product->get_key() . '_feedback_review_button_cancel', 'No, thanks.' );
|
||||
$message = str_replace(
|
||||
[ '{product}', '{developer}' ],
|
||||
[
|
||||
$this->product->get_friendly_name(),
|
||||
$developers[ strlen( get_site_url() ) % 10 ],
|
||||
],
|
||||
$message
|
||||
);
|
||||
|
||||
$all_notifications[] = [
|
||||
'id' => $this->product->get_key() . '_review_flag',
|
||||
'message' => $message,
|
||||
'ctas' => [
|
||||
'confirm' => [
|
||||
'link' => $link,
|
||||
'text' => $button_submit,
|
||||
],
|
||||
'cancel' => [
|
||||
'link' => '#',
|
||||
'text' => $button_cancel,
|
||||
],
|
||||
],
|
||||
];
|
||||
|
||||
return $all_notifications;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Load module logic.
|
||||
*
|
||||
* @param Product $product Product to load.
|
||||
*
|
||||
* @return Review Module instance.
|
||||
*/
|
||||
public function load( $product ) {
|
||||
|
||||
$this->product = $product;
|
||||
|
||||
add_filter( 'themeisle_sdk_registered_notifications', [ $this, 'add_notification' ] );
|
||||
|
||||
return $this;
|
||||
}
|
||||
}
|
376
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Rollback.php
vendored
Normal file
376
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Rollback.php
vendored
Normal file
@ -0,0 +1,376 @@
|
||||
<?php
|
||||
/**
|
||||
* The rollback class for ThemeIsle SDK.
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @subpackage Rollback
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-3.0.php GNU Public License
|
||||
* @since 1.0.0
|
||||
*/
|
||||
|
||||
namespace ThemeisleSDK\Modules;
|
||||
|
||||
// Exit if accessed directly.
|
||||
use ThemeisleSDK\Common\Abstract_Module;
|
||||
use ThemeisleSDK\Product;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
/**
|
||||
* Rollback for ThemeIsle SDK.
|
||||
*/
|
||||
class Rollback extends Abstract_Module {
|
||||
|
||||
/**
|
||||
* Add js scripts for themes rollback.
|
||||
*/
|
||||
public function add_footer() {
|
||||
$screen = get_current_screen();
|
||||
if ( ! isset( $screen->parent_file ) ) {
|
||||
return;
|
||||
}
|
||||
if ( 'themes.php' !== $screen->parent_file ) {
|
||||
return;
|
||||
}
|
||||
if ( ! $this->product->is_theme() ) {
|
||||
return;
|
||||
}
|
||||
$version = $this->get_rollback();
|
||||
if ( empty( $version ) ) {
|
||||
return;
|
||||
}
|
||||
?>
|
||||
<script type="text/javascript">
|
||||
jQuery(document).ready(function ($) {
|
||||
setInterval(checkTheme, 500);
|
||||
|
||||
function checkTheme() {
|
||||
var theme = '<?php echo esc_attr( $this->product->get_slug() ); ?>-action';
|
||||
|
||||
if (jQuery('#' + theme).length > 0) {
|
||||
if (jQuery('.theme-overlay.active').is(':visible')) {
|
||||
if (jQuery('#' + theme + '-rollback').length === 0) {
|
||||
jQuery('.theme-actions .active-theme').prepend('<a class="button" style="float:left" id="' + theme + '-rollback" href="<?php echo esc_url( wp_nonce_url( admin_url( 'admin-post.php?action=' . $this->product->get_key() . '_rollback' ), $this->product->get_key() . '_rollback' ) ); ?>">Rollback to v<?php echo esc_attr( $version['version'] ); ?></a>')
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
</script>
|
||||
<?php
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the last rollback for this product.
|
||||
*
|
||||
* @return array The rollback version.
|
||||
*/
|
||||
public function get_rollback() {
|
||||
$rollback = array();
|
||||
$versions = $this->get_api_versions();
|
||||
$versions = apply_filters( $this->product->get_key() . '_rollbacks', $versions );
|
||||
if ( empty( $versions ) ) {
|
||||
return $rollback;
|
||||
}
|
||||
if ( $versions ) {
|
||||
usort( $versions, array( $this, 'sort_rollback_array' ) );
|
||||
foreach ( $versions as $version ) {
|
||||
if ( isset( $version['version'] ) && isset( $version['url'] ) && version_compare( $this->product->get_version(), $version['version'], '>' ) ) {
|
||||
$rollback = $version;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return $rollback;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get versions array from wp.org
|
||||
*
|
||||
* @return array Array of versions.
|
||||
*/
|
||||
private function get_api_versions() {
|
||||
|
||||
$cache_key = $this->product->get_key() . '_' . preg_replace( '/[^0-9a-zA-Z ]/m', '', $this->product->get_version() ) . 'versions';
|
||||
$cache_versions = get_transient( $cache_key );
|
||||
if ( false === $cache_versions ) {
|
||||
$versions = $this->get_remote_versions();
|
||||
set_transient( $cache_key, $versions, 5 * DAY_IN_SECONDS );
|
||||
} else {
|
||||
$versions = is_array( $cache_versions ) ? $cache_versions : array();
|
||||
}
|
||||
|
||||
return $versions;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get remote versions zips.
|
||||
*
|
||||
* @return array Array of available versions.
|
||||
*/
|
||||
private function get_remote_versions() {
|
||||
$url = $this->get_versions_api_url();
|
||||
if ( empty( $url ) ) {
|
||||
return [];
|
||||
}
|
||||
$response = wp_remote_get( $url );
|
||||
if ( is_wp_error( $response ) ) {
|
||||
return array();
|
||||
}
|
||||
$response = wp_remote_retrieve_body( $response );
|
||||
|
||||
if ( is_serialized( $response ) ) {
|
||||
$response = maybe_unserialize( $response );
|
||||
} else {
|
||||
$response = json_decode( $response );
|
||||
}
|
||||
|
||||
if ( ! is_object( $response ) ) {
|
||||
return array();
|
||||
}
|
||||
if ( ! isset( $response->versions ) ) {
|
||||
return array();
|
||||
}
|
||||
|
||||
$versions = array();
|
||||
foreach ( $response->versions as $key => $value ) {
|
||||
$versions[] = array(
|
||||
'version' => is_object( $value ) ? $value->version : $key,
|
||||
'url' => is_object( $value ) ? $value->file : $value,
|
||||
);
|
||||
}
|
||||
|
||||
return $versions;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return url where to check for versions.
|
||||
*
|
||||
* @return string Url where to check for versions.
|
||||
*/
|
||||
private function get_versions_api_url() {
|
||||
if ( $this->product->is_wordpress_available() && $this->product->is_plugin() ) {
|
||||
return sprintf( 'https://api.wordpress.org/plugins/info/1.0/%s', $this->product->get_slug() );
|
||||
}
|
||||
if ( $this->product->is_wordpress_available() && $this->product->is_theme() ) {
|
||||
return sprintf( 'https://api.wordpress.org/themes/info/1.1/?action=theme_information&request[slug]=%s&request[fields][versions]=true', $this->product->get_slug() );
|
||||
}
|
||||
$license = $this->product->get_license();
|
||||
if ( $this->product->requires_license() && strlen( $license ) < 10 ) {
|
||||
return '';
|
||||
}
|
||||
|
||||
return sprintf( '%s?edd_action=get_versions&name=%s&url=%s&license=%s', $this->product->get_store_url(), urlencode( $this->product->get_name() ), urlencode( get_site_url() ), $license );
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the rollback links in the plugin page.
|
||||
*
|
||||
* @param array $links Plugin links.
|
||||
*
|
||||
* @return array $links Altered links.
|
||||
*/
|
||||
public function add_rollback_link( $links ) {
|
||||
$version = $this->get_rollback();
|
||||
if ( empty( $version ) ) {
|
||||
return $links;
|
||||
}
|
||||
$links[] = '<a href="' . wp_nonce_url( admin_url( 'admin-post.php?action=' . $this->product->get_key() . '_rollback' ), $this->product->get_key() . '_rollback' ) . '">' . sprintf( apply_filters( $this->product->get_key() . '_rollback_label', 'Rollback to v%s' ), $version['version'] ) . '</a>';
|
||||
|
||||
return $links;
|
||||
}
|
||||
|
||||
/**
|
||||
* Start the rollback operation.
|
||||
*/
|
||||
public function start_rollback() {
|
||||
if ( ! isset( $_GET['_wpnonce'] ) || ! wp_verify_nonce( $_GET['_wpnonce'], $this->product->get_key() . '_rollback' ) ) {
|
||||
wp_nonce_ays( '' );
|
||||
}
|
||||
|
||||
if ( $this->product->is_plugin() ) {
|
||||
$this->start_rollback_plugin();
|
||||
|
||||
return;
|
||||
}
|
||||
if ( $this->product->is_theme() ) {
|
||||
$this->start_rollback_theme();
|
||||
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Start the rollback operation for the plugin.
|
||||
*/
|
||||
private function start_rollback_plugin() {
|
||||
$rollback = $this->get_rollback();
|
||||
$plugin_transient = get_site_transient( 'update_plugins' );
|
||||
$plugin_folder = $this->product->get_slug();
|
||||
$plugin_file = $this->product->get_file();
|
||||
$version = $rollback['version'];
|
||||
$temp_array = array(
|
||||
'slug' => $plugin_folder,
|
||||
'new_version' => $version,
|
||||
'package' => $rollback['url'],
|
||||
);
|
||||
|
||||
$temp_object = (object) $temp_array;
|
||||
$plugin_transient->response[ $plugin_folder . '/' . $plugin_file ] = $temp_object;
|
||||
set_site_transient( 'update_plugins', $plugin_transient );
|
||||
|
||||
$transient = get_transient( $this->product->get_key() . '_warning_rollback' );
|
||||
|
||||
if ( false === $transient ) {
|
||||
set_transient( $this->product->get_key() . '_warning_rollback', 'in progress', 30 );
|
||||
require_once( ABSPATH . 'wp-admin/includes/class-wp-upgrader.php' );
|
||||
$title = sprintf( apply_filters( $this->product->get_key() . '_rollback_message', 'Rolling back %s to v%s' ), $this->product->get_name(), $version );
|
||||
$plugin = $plugin_folder . '/' . $plugin_file;
|
||||
$nonce = 'upgrade-plugin_' . $plugin;
|
||||
$url = 'update.php?action=upgrade-plugin&plugin=' . urlencode( $plugin );
|
||||
$upgrader_skin = new \Plugin_Upgrader_Skin( compact( 'title', 'nonce', 'url', 'plugin' ) );
|
||||
$upgrader = new \Plugin_Upgrader( $upgrader_skin );
|
||||
$upgrader->upgrade( $plugin );
|
||||
delete_transient( $this->product->get_key() . '_warning_rollback' );
|
||||
wp_die(
|
||||
'',
|
||||
$title,
|
||||
array(
|
||||
'response' => 200,
|
||||
)
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Start the rollback operation for the theme.
|
||||
*/
|
||||
private function start_rollback_theme() {
|
||||
add_filter( 'update_theme_complete_actions', array( $this, 'alter_links_theme_upgrade' ) );
|
||||
$rollback = $this->get_rollback();
|
||||
$transient = get_site_transient( 'update_themes' );
|
||||
$folder = $this->product->get_slug();
|
||||
$version = $rollback['version'];
|
||||
$temp_array = array(
|
||||
'new_version' => $version,
|
||||
'package' => $rollback['url'],
|
||||
);
|
||||
|
||||
$transient->response[ $folder . '/style.css' ] = $temp_array;
|
||||
set_site_transient( 'update_themes', $transient );
|
||||
|
||||
$transient = get_transient( $this->product->get_key() . '_warning_rollback' );
|
||||
|
||||
if ( false === $transient ) {
|
||||
set_transient( $this->product->get_key() . '_warning_rollback', 'in progress', 30 );
|
||||
require_once( ABSPATH . 'wp-admin/includes/class-wp-upgrader.php' );
|
||||
$title = sprintf( apply_filters( $this->product->get_key() . '_rollback_message', 'Rolling back %s to v%s' ), $this->product->get_name(), $version );
|
||||
$theme = $folder . '/style.css';
|
||||
$nonce = 'upgrade-theme_' . $theme;
|
||||
$url = 'update.php?action=upgrade-theme&theme=' . urlencode( $theme );
|
||||
|
||||
$upgrader = new \Theme_Upgrader( new \Theme_Upgrader_Skin( compact( 'title', 'nonce', 'url', 'theme' ) ) );
|
||||
$upgrader->upgrade( $theme );
|
||||
delete_transient( $this->product->get_key() . '_warning_rollback' );
|
||||
wp_die(
|
||||
'',
|
||||
$title,
|
||||
array(
|
||||
'response' => 200,
|
||||
)
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Alter links and remove duplicate customize message.
|
||||
*
|
||||
* @param array $links Array of old links.
|
||||
*
|
||||
* @return mixed Array of links.
|
||||
*/
|
||||
public function alter_links_theme_upgrade( $links ) {
|
||||
if ( isset( $links['preview'] ) ) {
|
||||
$links['preview'] = str_replace( '<span aria-hidden="true">Customize</span>', '', $links['preview'] );
|
||||
}
|
||||
|
||||
return $links;
|
||||
}
|
||||
|
||||
/**
|
||||
* Loads product object.
|
||||
*
|
||||
* @param Product $product Product object.
|
||||
*
|
||||
* @return bool Should we load the module?
|
||||
*/
|
||||
public function can_load( $product ) {
|
||||
if ( $this->is_from_partner( $product ) ) {
|
||||
return false;
|
||||
}
|
||||
if ( $product->is_theme() && ! current_user_can( 'switch_themes' ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if ( $product->is_plugin() && ! current_user_can( 'install_plugins' ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Sort the rollbacks array in descending order.
|
||||
*
|
||||
* @param mixed $a First version to compare.
|
||||
* @param mixed $b Second version to compare.
|
||||
*
|
||||
* @return bool Which version is greater?
|
||||
*/
|
||||
public function sort_rollback_array( $a, $b ) {
|
||||
return version_compare( $a['version'], $b['version'], '<' ) > 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Load module logic.
|
||||
*
|
||||
* @param Product $product Product object.
|
||||
*
|
||||
* @return $this Module object.
|
||||
*/
|
||||
public function load( $product ) {
|
||||
$this->product = $product;
|
||||
$this->show_link();
|
||||
$this->add_hooks();
|
||||
|
||||
return $this;
|
||||
}
|
||||
|
||||
/**
|
||||
* If product can be rolled back, show the link to rollback.
|
||||
*/
|
||||
private function show_link() {
|
||||
add_filter(
|
||||
'plugin_action_links_' . plugin_basename( $this->product->get_basefile() ),
|
||||
array(
|
||||
$this,
|
||||
'add_rollback_link',
|
||||
)
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the rollback hook. Strangely, this does not work if placed in the ThemeIsle_SDK_Rollback class, so it is being called from there instead.
|
||||
*/
|
||||
public function add_hooks() {
|
||||
add_action( 'admin_post_' . $this->product->get_key() . '_rollback', array( $this, 'start_rollback' ) );
|
||||
add_action( 'admin_footer', array( $this, 'add_footer' ) );
|
||||
}
|
||||
}
|
918
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Translate.php
vendored
Normal file
918
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Translate.php
vendored
Normal file
@ -0,0 +1,918 @@
|
||||
<?php
|
||||
/**
|
||||
* The translate model class for ThemeIsle SDK
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @subpackage Modules
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-3.0.php GNU Public License
|
||||
* @since 1.0.0
|
||||
*/
|
||||
|
||||
namespace ThemeisleSDK\Modules;
|
||||
|
||||
use ThemeisleSDK\Common\Abstract_Module;
|
||||
use ThemeisleSDK\Product;
|
||||
|
||||
// Exit if accessed directly.
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
/**
|
||||
* Translate module for ThemeIsle SDK.
|
||||
*/
|
||||
class Translate extends Abstract_Module {
|
||||
/**
|
||||
* List of available locales.
|
||||
*
|
||||
* @var array Array of available locals.
|
||||
*/
|
||||
private static $locales = array(
|
||||
'af' => array(
|
||||
'slug' => 'af',
|
||||
'name' => 'Afrikaans',
|
||||
),
|
||||
'ak' => array(
|
||||
'slug' => 'ak',
|
||||
'name' => 'Akan',
|
||||
),
|
||||
'am' => array(
|
||||
'slug' => 'am',
|
||||
'name' => 'Amharic',
|
||||
),
|
||||
'ar' => array(
|
||||
'slug' => 'ar',
|
||||
'name' => 'Arabic',
|
||||
),
|
||||
'arq' => array(
|
||||
'slug' => 'arq',
|
||||
'name' => 'Algerian Arabic',
|
||||
),
|
||||
'ary' => array(
|
||||
'slug' => 'ary',
|
||||
'name' => 'Moroccan Arabic',
|
||||
),
|
||||
'as' => array(
|
||||
'slug' => 'as',
|
||||
'name' => 'Assamese',
|
||||
),
|
||||
'ast' => array(
|
||||
'slug' => 'ast',
|
||||
'name' => 'Asturian',
|
||||
),
|
||||
'az' => array(
|
||||
'slug' => 'az',
|
||||
'name' => 'Azerbaijani',
|
||||
),
|
||||
'azb' => array(
|
||||
'slug' => 'azb',
|
||||
'name' => 'South Azerbaijani',
|
||||
),
|
||||
'az_TR' => array(
|
||||
'slug' => 'az-tr',
|
||||
'name' => 'Azerbaijani (Turkey)',
|
||||
),
|
||||
'ba' => array(
|
||||
'slug' => 'ba',
|
||||
'name' => 'Bashkir',
|
||||
),
|
||||
'bal' => array(
|
||||
'slug' => 'bal',
|
||||
'name' => 'Catalan (Balear)',
|
||||
),
|
||||
'bcc' => array(
|
||||
'slug' => 'bcc',
|
||||
'name' => 'Balochi Southern',
|
||||
),
|
||||
'bel' => array(
|
||||
'slug' => 'bel',
|
||||
'name' => 'Belarusian',
|
||||
),
|
||||
'bg_BG' => array(
|
||||
'slug' => 'bg',
|
||||
'name' => 'Bulgarian',
|
||||
),
|
||||
'bn_BD' => array(
|
||||
'slug' => 'bn',
|
||||
'name' => 'Bengali',
|
||||
),
|
||||
'bo' => array(
|
||||
'slug' => 'bo',
|
||||
'name' => 'Tibetan',
|
||||
),
|
||||
'bre' => array(
|
||||
'slug' => 'br',
|
||||
'name' => 'Breton',
|
||||
),
|
||||
'bs_BA' => array(
|
||||
'slug' => 'bs',
|
||||
'name' => 'Bosnian',
|
||||
),
|
||||
'ca' => array(
|
||||
'slug' => 'ca',
|
||||
'name' => 'Catalan',
|
||||
),
|
||||
'ceb' => array(
|
||||
'slug' => 'ceb',
|
||||
'name' => 'Cebuano',
|
||||
),
|
||||
'ckb' => array(
|
||||
'slug' => 'ckb',
|
||||
'name' => 'Kurdish (Sorani)',
|
||||
),
|
||||
'co' => array(
|
||||
'slug' => 'co',
|
||||
'name' => 'Corsican',
|
||||
),
|
||||
'cs_CZ' => array(
|
||||
'slug' => 'cs',
|
||||
'name' => 'Czech',
|
||||
),
|
||||
'cy' => array(
|
||||
'slug' => 'cy',
|
||||
'name' => 'Welsh',
|
||||
),
|
||||
'da_DK' => array(
|
||||
'slug' => 'da',
|
||||
'name' => 'Danish',
|
||||
),
|
||||
'de_DE' => array(
|
||||
'slug' => 'de',
|
||||
'name' => 'German',
|
||||
),
|
||||
'de_CH' => array(
|
||||
'slug' => 'de-ch',
|
||||
'name' => 'German (Switzerland)',
|
||||
),
|
||||
'dv' => array(
|
||||
'slug' => 'dv',
|
||||
'name' => 'Dhivehi',
|
||||
),
|
||||
'dzo' => array(
|
||||
'slug' => 'dzo',
|
||||
'name' => 'Dzongkha',
|
||||
),
|
||||
'el' => array(
|
||||
'slug' => 'el',
|
||||
'name' => 'Greek',
|
||||
),
|
||||
'art_xemoji' => array(
|
||||
'slug' => 'art-xemoji',
|
||||
'name' => 'Emoji',
|
||||
),
|
||||
'en_US' => array(
|
||||
'slug' => 'en',
|
||||
'name' => 'English',
|
||||
),
|
||||
'en_AU' => array(
|
||||
'slug' => 'en-au',
|
||||
'name' => 'English (Australia)',
|
||||
),
|
||||
'en_CA' => array(
|
||||
'slug' => 'en-ca',
|
||||
'name' => 'English (Canada)',
|
||||
),
|
||||
'en_GB' => array(
|
||||
'slug' => 'en-gb',
|
||||
'name' => 'English (UK)',
|
||||
),
|
||||
'en_NZ' => array(
|
||||
'slug' => 'en-nz',
|
||||
'name' => 'English (New Zealand)',
|
||||
),
|
||||
'en_ZA' => array(
|
||||
'slug' => 'en-za',
|
||||
'name' => 'English (South Africa)',
|
||||
),
|
||||
'eo' => array(
|
||||
'slug' => 'eo',
|
||||
'name' => 'Esperanto',
|
||||
),
|
||||
'es_ES' => array(
|
||||
'slug' => 'es',
|
||||
'name' => 'Spanish (Spain)',
|
||||
),
|
||||
'es_AR' => array(
|
||||
'slug' => 'es-ar',
|
||||
'name' => 'Spanish (Argentina)',
|
||||
),
|
||||
'es_CL' => array(
|
||||
'slug' => 'es-cl',
|
||||
'name' => 'Spanish (Chile)',
|
||||
),
|
||||
'es_CO' => array(
|
||||
'slug' => 'es-co',
|
||||
'name' => 'Spanish (Colombia)',
|
||||
),
|
||||
'es_CR' => array(
|
||||
'slug' => 'es-cr',
|
||||
'name' => 'Spanish (Costa Rica)',
|
||||
),
|
||||
'es_GT' => array(
|
||||
'slug' => 'es-gt',
|
||||
'name' => 'Spanish (Guatemala)',
|
||||
),
|
||||
'es_MX' => array(
|
||||
'slug' => 'es-mx',
|
||||
'name' => 'Spanish (Mexico)',
|
||||
),
|
||||
'es_PE' => array(
|
||||
'slug' => 'es-pe',
|
||||
'name' => 'Spanish (Peru)',
|
||||
),
|
||||
'es_PR' => array(
|
||||
'slug' => 'es-pr',
|
||||
'name' => 'Spanish (Puerto Rico)',
|
||||
),
|
||||
'es_VE' => array(
|
||||
'slug' => 'es-ve',
|
||||
'name' => 'Spanish (Venezuela)',
|
||||
),
|
||||
'et' => array(
|
||||
'slug' => 'et',
|
||||
'name' => 'Estonian',
|
||||
),
|
||||
'eu' => array(
|
||||
'slug' => 'eu',
|
||||
'name' => 'Basque',
|
||||
),
|
||||
'fa_IR' => array(
|
||||
'slug' => 'fa',
|
||||
'name' => 'Persian',
|
||||
),
|
||||
'fa_AF' => array(
|
||||
'slug' => 'fa-af',
|
||||
'name' => 'Persian (Afghanistan)',
|
||||
),
|
||||
'fuc' => array(
|
||||
'slug' => 'fuc',
|
||||
'name' => 'Fulah',
|
||||
),
|
||||
'fi' => array(
|
||||
'slug' => 'fi',
|
||||
'name' => 'Finnish',
|
||||
),
|
||||
'fo' => array(
|
||||
'slug' => 'fo',
|
||||
'name' => 'Faroese',
|
||||
),
|
||||
'fr_FR' => array(
|
||||
'slug' => 'fr',
|
||||
'name' => 'French (France)',
|
||||
),
|
||||
'fr_BE' => array(
|
||||
'slug' => 'fr-be',
|
||||
'name' => 'French (Belgium)',
|
||||
),
|
||||
'fr_CA' => array(
|
||||
'slug' => 'fr-ca',
|
||||
'name' => 'French (Canada)',
|
||||
),
|
||||
'frp' => array(
|
||||
'slug' => 'frp',
|
||||
'name' => 'Arpitan',
|
||||
),
|
||||
'fur' => array(
|
||||
'slug' => 'fur',
|
||||
'name' => 'Friulian',
|
||||
),
|
||||
'fy' => array(
|
||||
'slug' => 'fy',
|
||||
'name' => 'Frisian',
|
||||
),
|
||||
'ga' => array(
|
||||
'slug' => 'ga',
|
||||
'name' => 'Irish',
|
||||
),
|
||||
'gd' => array(
|
||||
'slug' => 'gd',
|
||||
'name' => 'Scottish Gaelic',
|
||||
),
|
||||
'gl_ES' => array(
|
||||
'slug' => 'gl',
|
||||
'name' => 'Galician',
|
||||
),
|
||||
'gn' => array(
|
||||
'slug' => 'gn',
|
||||
'name' => 'Guaraní',
|
||||
),
|
||||
'gsw' => array(
|
||||
'slug' => 'gsw',
|
||||
'name' => 'Swiss German',
|
||||
),
|
||||
'gu' => array(
|
||||
'slug' => 'gu',
|
||||
'name' => 'Gujarati',
|
||||
),
|
||||
'hat' => array(
|
||||
'slug' => 'hat',
|
||||
'name' => 'Haitian Creole',
|
||||
),
|
||||
'hau' => array(
|
||||
'slug' => 'hau',
|
||||
'name' => 'Hausa',
|
||||
),
|
||||
'haw_US' => array(
|
||||
'slug' => 'haw',
|
||||
'name' => 'Hawaiian',
|
||||
),
|
||||
'haz' => array(
|
||||
'slug' => 'haz',
|
||||
'name' => 'Hazaragi',
|
||||
),
|
||||
'he_IL' => array(
|
||||
'slug' => 'he',
|
||||
'name' => 'Hebrew',
|
||||
),
|
||||
'hi_IN' => array(
|
||||
'slug' => 'hi',
|
||||
'name' => 'Hindi',
|
||||
),
|
||||
'hr' => array(
|
||||
'slug' => 'hr',
|
||||
'name' => 'Croatian',
|
||||
),
|
||||
'hu_HU' => array(
|
||||
'slug' => 'hu',
|
||||
'name' => 'Hungarian',
|
||||
),
|
||||
'hy' => array(
|
||||
'slug' => 'hy',
|
||||
'name' => 'Armenian',
|
||||
),
|
||||
'id_ID' => array(
|
||||
'slug' => 'id',
|
||||
'name' => 'Indonesian',
|
||||
),
|
||||
'ido' => array(
|
||||
'slug' => 'ido',
|
||||
'name' => 'Ido',
|
||||
),
|
||||
'is_IS' => array(
|
||||
'slug' => 'is',
|
||||
'name' => 'Icelandic',
|
||||
),
|
||||
'it_IT' => array(
|
||||
'slug' => 'it',
|
||||
'name' => 'Italian',
|
||||
),
|
||||
'ja' => array(
|
||||
'slug' => 'ja',
|
||||
'name' => 'Japanese',
|
||||
),
|
||||
'jv_ID' => array(
|
||||
'slug' => 'jv',
|
||||
'name' => 'Javanese',
|
||||
),
|
||||
'ka_GE' => array(
|
||||
'slug' => 'ka',
|
||||
'name' => 'Georgian',
|
||||
),
|
||||
'kab' => array(
|
||||
'slug' => 'kab',
|
||||
'name' => 'Kabyle',
|
||||
),
|
||||
'kal' => array(
|
||||
'slug' => 'kal',
|
||||
'name' => 'Greenlandic',
|
||||
),
|
||||
'kin' => array(
|
||||
'slug' => 'kin',
|
||||
'name' => 'Kinyarwanda',
|
||||
),
|
||||
'kk' => array(
|
||||
'slug' => 'kk',
|
||||
'name' => 'Kazakh',
|
||||
),
|
||||
'km' => array(
|
||||
'slug' => 'km',
|
||||
'name' => 'Khmer',
|
||||
),
|
||||
'kn' => array(
|
||||
'slug' => 'kn',
|
||||
'name' => 'Kannada',
|
||||
),
|
||||
'ko_KR' => array(
|
||||
'slug' => 'ko',
|
||||
'name' => 'Korean',
|
||||
),
|
||||
'kir' => array(
|
||||
'slug' => 'kir',
|
||||
'name' => 'Kyrgyz',
|
||||
),
|
||||
'lb_LU' => array(
|
||||
'slug' => 'lb',
|
||||
'name' => 'Luxembourgish',
|
||||
),
|
||||
'li' => array(
|
||||
'slug' => 'li',
|
||||
'name' => 'Limburgish',
|
||||
),
|
||||
'lin' => array(
|
||||
'slug' => 'lin',
|
||||
'name' => 'Lingala',
|
||||
),
|
||||
'lo' => array(
|
||||
'slug' => 'lo',
|
||||
'name' => 'Lao',
|
||||
),
|
||||
'lt_LT' => array(
|
||||
'slug' => 'lt',
|
||||
'name' => 'Lithuanian',
|
||||
),
|
||||
'lv' => array(
|
||||
'slug' => 'lv',
|
||||
'name' => 'Latvian',
|
||||
),
|
||||
'me_ME' => array(
|
||||
'slug' => 'me',
|
||||
'name' => 'Montenegrin',
|
||||
),
|
||||
'mg_MG' => array(
|
||||
'slug' => 'mg',
|
||||
'name' => 'Malagasy',
|
||||
),
|
||||
'mk_MK' => array(
|
||||
'slug' => 'mk',
|
||||
'name' => 'Macedonian',
|
||||
),
|
||||
'ml_IN' => array(
|
||||
'slug' => 'ml',
|
||||
'name' => 'Malayalam',
|
||||
),
|
||||
'mlt' => array(
|
||||
'slug' => 'mlt',
|
||||
'name' => 'Maltese',
|
||||
),
|
||||
'mn' => array(
|
||||
'slug' => 'mn',
|
||||
'name' => 'Mongolian',
|
||||
),
|
||||
'mr' => array(
|
||||
'slug' => 'mr',
|
||||
'name' => 'Marathi',
|
||||
),
|
||||
'mri' => array(
|
||||
'slug' => 'mri',
|
||||
'name' => 'Maori',
|
||||
),
|
||||
'ms_MY' => array(
|
||||
'slug' => 'ms',
|
||||
'name' => 'Malay',
|
||||
),
|
||||
'my_MM' => array(
|
||||
'slug' => 'mya',
|
||||
'name' => 'Myanmar (Burmese)',
|
||||
),
|
||||
'ne_NP' => array(
|
||||
'slug' => 'ne',
|
||||
'name' => 'Nepali',
|
||||
),
|
||||
'nb_NO' => array(
|
||||
'slug' => 'nb',
|
||||
'name' => 'Norwegian (Bokmål)',
|
||||
),
|
||||
'nl_NL' => array(
|
||||
'slug' => 'nl',
|
||||
'name' => 'Dutch',
|
||||
),
|
||||
'nl_BE' => array(
|
||||
'slug' => 'nl-be',
|
||||
'name' => 'Dutch (Belgium)',
|
||||
),
|
||||
'nn_NO' => array(
|
||||
'slug' => 'nn',
|
||||
'name' => 'Norwegian (Nynorsk)',
|
||||
),
|
||||
'oci' => array(
|
||||
'slug' => 'oci',
|
||||
'name' => 'Occitan',
|
||||
),
|
||||
'ory' => array(
|
||||
'slug' => 'ory',
|
||||
'name' => 'Oriya',
|
||||
),
|
||||
'os' => array(
|
||||
'slug' => 'os',
|
||||
'name' => 'Ossetic',
|
||||
),
|
||||
'pa_IN' => array(
|
||||
'slug' => 'pa',
|
||||
'name' => 'Punjabi',
|
||||
),
|
||||
'pl_PL' => array(
|
||||
'slug' => 'pl',
|
||||
'name' => 'Polish',
|
||||
),
|
||||
'pt_BR' => array(
|
||||
'slug' => 'pt-br',
|
||||
'name' => 'Portuguese (Brazil)',
|
||||
),
|
||||
'pt_PT' => array(
|
||||
'slug' => 'pt',
|
||||
'name' => 'Portuguese (Portugal)',
|
||||
),
|
||||
'ps' => array(
|
||||
'slug' => 'ps',
|
||||
'name' => 'Pashto',
|
||||
),
|
||||
'rhg' => array(
|
||||
'slug' => 'rhg',
|
||||
'name' => 'Rohingya',
|
||||
),
|
||||
'ro_RO' => array(
|
||||
'slug' => 'ro',
|
||||
'name' => 'Romanian',
|
||||
),
|
||||
'roh' => array(
|
||||
'slug' => 'roh',
|
||||
'name' => 'Romansh',
|
||||
),
|
||||
'ru_RU' => array(
|
||||
'slug' => 'ru',
|
||||
'name' => 'Russian',
|
||||
),
|
||||
'rue' => array(
|
||||
'slug' => 'rue',
|
||||
'name' => 'Rusyn',
|
||||
),
|
||||
'rup_MK' => array(
|
||||
'slug' => 'rup',
|
||||
'name' => 'Aromanian',
|
||||
),
|
||||
'sah' => array(
|
||||
'slug' => 'sah',
|
||||
'name' => 'Sakha',
|
||||
),
|
||||
'sa_IN' => array(
|
||||
'slug' => 'sa-in',
|
||||
'name' => 'Sanskrit',
|
||||
),
|
||||
'scn' => array(
|
||||
'slug' => 'scn',
|
||||
'name' => 'Sicilian',
|
||||
),
|
||||
'si_LK' => array(
|
||||
'slug' => 'si',
|
||||
'name' => 'Sinhala',
|
||||
),
|
||||
'sk_SK' => array(
|
||||
'slug' => 'sk',
|
||||
'name' => 'Slovak',
|
||||
),
|
||||
'sl_SI' => array(
|
||||
'slug' => 'sl',
|
||||
'name' => 'Slovenian',
|
||||
),
|
||||
'sna' => array(
|
||||
'slug' => 'sna',
|
||||
'name' => 'Shona',
|
||||
),
|
||||
'snd' => array(
|
||||
'slug' => 'snd',
|
||||
'name' => 'Sindhi',
|
||||
),
|
||||
'so_SO' => array(
|
||||
'slug' => 'so',
|
||||
'name' => 'Somali',
|
||||
),
|
||||
'sq' => array(
|
||||
'slug' => 'sq',
|
||||
'name' => 'Albanian',
|
||||
),
|
||||
'sq_XK' => array(
|
||||
'slug' => 'sq-xk',
|
||||
'name' => 'Shqip (Kosovo)',
|
||||
),
|
||||
'sr_RS' => array(
|
||||
'slug' => 'sr',
|
||||
'name' => 'Serbian',
|
||||
),
|
||||
'srd' => array(
|
||||
'slug' => 'srd',
|
||||
'name' => 'Sardinian',
|
||||
),
|
||||
'su_ID' => array(
|
||||
'slug' => 'su',
|
||||
'name' => 'Sundanese',
|
||||
),
|
||||
'sv_SE' => array(
|
||||
'slug' => 'sv',
|
||||
'name' => 'Swedish',
|
||||
),
|
||||
'sw' => array(
|
||||
'slug' => 'sw',
|
||||
'name' => 'Swahili',
|
||||
),
|
||||
'syr' => array(
|
||||
'slug' => 'syr',
|
||||
'name' => 'Syriac',
|
||||
),
|
||||
'szl' => array(
|
||||
'slug' => 'szl',
|
||||
'name' => 'Silesian',
|
||||
),
|
||||
'ta_IN' => array(
|
||||
'slug' => 'ta',
|
||||
'name' => 'Tamil',
|
||||
),
|
||||
'ta_LK' => array(
|
||||
'slug' => 'ta-lk',
|
||||
'name' => 'Tamil (Sri Lanka)',
|
||||
),
|
||||
'tah' => array(
|
||||
'slug' => 'tah',
|
||||
'name' => 'Tahitian',
|
||||
),
|
||||
'te' => array(
|
||||
'slug' => 'te',
|
||||
'name' => 'Telugu',
|
||||
),
|
||||
'tg' => array(
|
||||
'slug' => 'tg',
|
||||
'name' => 'Tajik',
|
||||
),
|
||||
'th' => array(
|
||||
'slug' => 'th',
|
||||
'name' => 'Thai',
|
||||
),
|
||||
'tir' => array(
|
||||
'slug' => 'tir',
|
||||
'name' => 'Tigrinya',
|
||||
),
|
||||
'tl' => array(
|
||||
'slug' => 'tl',
|
||||
'name' => 'Tagalog',
|
||||
),
|
||||
'tr_TR' => array(
|
||||
'slug' => 'tr',
|
||||
'name' => 'Turkish',
|
||||
),
|
||||
'tt_RU' => array(
|
||||
'slug' => 'tt',
|
||||
'name' => 'Tatar',
|
||||
),
|
||||
'tuk' => array(
|
||||
'slug' => 'tuk',
|
||||
'name' => 'Turkmen',
|
||||
),
|
||||
'twd' => array(
|
||||
'slug' => 'twd',
|
||||
'name' => 'Tweants',
|
||||
),
|
||||
'tzm' => array(
|
||||
'slug' => 'tzm',
|
||||
'name' => 'Tamazight (Central Atlas)',
|
||||
),
|
||||
'ug_CN' => array(
|
||||
'slug' => 'ug',
|
||||
'name' => 'Uighur',
|
||||
),
|
||||
'uk' => array(
|
||||
'slug' => 'uk',
|
||||
'name' => 'Ukrainian',
|
||||
),
|
||||
'ur' => array(
|
||||
'slug' => 'ur',
|
||||
'name' => 'Urdu',
|
||||
),
|
||||
'uz_UZ' => array(
|
||||
'slug' => 'uz',
|
||||
'name' => 'Uzbek',
|
||||
),
|
||||
'vi' => array(
|
||||
'slug' => 'vi',
|
||||
'name' => 'Vietnamese',
|
||||
),
|
||||
'wa' => array(
|
||||
'slug' => 'wa',
|
||||
'name' => 'Walloon',
|
||||
),
|
||||
'xho' => array(
|
||||
'slug' => 'xho',
|
||||
'name' => 'Xhosa',
|
||||
),
|
||||
'xmf' => array(
|
||||
'slug' => 'xmf',
|
||||
'name' => 'Mingrelian',
|
||||
),
|
||||
'yor' => array(
|
||||
'slug' => 'yor',
|
||||
'name' => 'Yoruba',
|
||||
),
|
||||
'zh_CN' => array(
|
||||
'slug' => 'zh-cn',
|
||||
'name' => 'Chinese (China)',
|
||||
),
|
||||
'zh_HK' => array(
|
||||
'slug' => 'zh-hk',
|
||||
'name' => 'Chinese (Hong Kong)',
|
||||
),
|
||||
'zh_TW' => array(
|
||||
'slug' => 'zh-tw',
|
||||
'name' => 'Chinese (Taiwan)',
|
||||
),
|
||||
'de_DE_formal' => array(
|
||||
'slug' => 'de/formal',
|
||||
'name' => 'German (Formal)',
|
||||
),
|
||||
'nl_NL_formal' => array(
|
||||
'slug' => 'nl/formal',
|
||||
'name' => 'Dutch (Formal)',
|
||||
),
|
||||
'de_CH_informal' => array(
|
||||
'slug' => 'de-ch/informal',
|
||||
'name' => 'Chinese (Taiwan)',
|
||||
),
|
||||
'pt_PT_ao90' => array(
|
||||
'slug' => 'pt/ao90',
|
||||
'name' => 'Portuguese (Portugal, AO90)',
|
||||
),
|
||||
);
|
||||
|
||||
/**
|
||||
* Check if we should load module for this.
|
||||
*
|
||||
* @param Product $product Product to check.
|
||||
*
|
||||
* @return bool Should load ?
|
||||
*/
|
||||
public function can_load( $product ) {
|
||||
if ( $this->is_from_partner( $product ) ) {
|
||||
return false;
|
||||
}
|
||||
if ( ! $product->is_wordpress_available() ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$lang = $this->get_user_locale();
|
||||
|
||||
if ( 'en_US' === $lang ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$languages = $this->get_translations( $product );
|
||||
|
||||
if ( ! is_array( $languages ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if ( ! isset( $languages['translations'] ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$languages = $languages['translations'];
|
||||
|
||||
$available = wp_list_pluck( $languages, 'language' );
|
||||
|
||||
if ( in_array( $lang, $available ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if ( ! isset( self::$locales[ $lang ] ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return apply_filters( $product->get_slug() . '_sdk_enable_translate', true );
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the user's locale.
|
||||
*/
|
||||
private function get_user_locale() {
|
||||
global $wp_version;
|
||||
if ( version_compare( $wp_version, '4.7.0', '>=' ) ) {
|
||||
return get_user_locale();
|
||||
}
|
||||
$user = wp_get_current_user();
|
||||
if ( $user ) {
|
||||
$locale = $user->locale;
|
||||
}
|
||||
|
||||
return $locale ? $locale : get_locale();
|
||||
}
|
||||
|
||||
/**
|
||||
* Fetch translations from api.
|
||||
*
|
||||
* @param Product $product Product to check.
|
||||
*
|
||||
* @return mixed Translation array.
|
||||
*/
|
||||
private function get_translations( $product ) {
|
||||
$cache_key = $product->get_key() . '_all_languages';
|
||||
$translations = get_transient( $cache_key );
|
||||
|
||||
if ( false === $translations ) {
|
||||
require_once( ABSPATH . 'wp-admin/includes/translation-install.php' );
|
||||
$translations = translations_api(
|
||||
$product->get_type() . 's',
|
||||
array(
|
||||
'slug' => $product->get_slug(),
|
||||
'version' => $product->get_version(),
|
||||
)
|
||||
);
|
||||
set_transient( $cache_key, $translations, WEEK_IN_SECONDS );
|
||||
}
|
||||
|
||||
return $translations;
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Add notification to queue.
|
||||
*
|
||||
* @param array $all_notifications Previous notification.
|
||||
*
|
||||
* @return array All notifications.
|
||||
*/
|
||||
public function add_notification( $all_notifications ) {
|
||||
|
||||
$lang = $this->get_user_locale();
|
||||
$link = $this->get_locale_paths( $lang );
|
||||
$language_meta = self::$locales[ $lang ];
|
||||
|
||||
$heading = apply_filters( $this->product->get_key() . '_feedback_translate_heading', 'Improve {product}' );
|
||||
$heading = str_replace(
|
||||
array( '{product}' ),
|
||||
$this->product->get_friendly_name(),
|
||||
$heading
|
||||
);
|
||||
$message = apply_filters(
|
||||
$this->product->get_key() . '_feedback_translation',
|
||||
'Translating <b>{product}</b> into as many languages as possible is a huge project. We still need help with a lot of them, so if you are good at translating into <b>{language}</b>, it would be greatly appreciated.
|
||||
The process is easy, and you can join by following the link below!'
|
||||
);
|
||||
|
||||
$message = str_replace(
|
||||
[ '{product}', '{language}' ],
|
||||
[
|
||||
$this->product->get_friendly_name(),
|
||||
$language_meta['name'],
|
||||
],
|
||||
$message
|
||||
);
|
||||
|
||||
$button_submit = apply_filters( $this->product->get_key() . '_feedback_translate_button_do', 'Ok, I will gladly help.' );
|
||||
$button_cancel = apply_filters( $this->product->get_key() . '_feedback_translate_button_cancel', 'No, thanks.' );
|
||||
|
||||
$all_notifications[] = [
|
||||
'id' => $this->product->get_key() . '_translate_flag',
|
||||
'heading' => $heading,
|
||||
'message' => $message,
|
||||
'ctas' => [
|
||||
'confirm' => [
|
||||
'link' => $link,
|
||||
'text' => $button_submit,
|
||||
],
|
||||
'cancel' => [
|
||||
'link' => '#',
|
||||
'text' => $button_cancel,
|
||||
],
|
||||
],
|
||||
];
|
||||
|
||||
return $all_notifications;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the locale path.
|
||||
*
|
||||
* @param string $locale Locale code.
|
||||
*
|
||||
* @return string Locale path.
|
||||
*/
|
||||
private function get_locale_paths( $locale ) {
|
||||
if ( empty( $locale ) ) {
|
||||
return '';
|
||||
}
|
||||
|
||||
$slug = isset( self::$locales[ $locale ] ) ? self::$locales[ $locale ]['slug'] : '';
|
||||
if ( empty( $slug ) ) {
|
||||
return '';
|
||||
}
|
||||
if ( strpos( $slug, '/' ) === false ) {
|
||||
$slug .= '/default';
|
||||
}
|
||||
$url = 'https://translate.wordpress.org/projects/wp-' . $this->product->get_type() . 's/' . $this->product->get_slug() . '/' . ( $this->product->get_type() === 'plugin' ? 'dev/' : '' ) . $slug . '?filters%5Bstatus%5D=untranslated&sort%5Bby%5D=random';
|
||||
|
||||
return $url;
|
||||
}
|
||||
|
||||
/**
|
||||
* Load module logic.
|
||||
*
|
||||
* @param Product $product Product to load.
|
||||
*
|
||||
* @return Translate Module instance.
|
||||
*/
|
||||
public function load( $product ) {
|
||||
|
||||
$this->product = $product;
|
||||
|
||||
add_filter( 'themeisle_sdk_registered_notifications', [ $this, 'add_notification' ] );
|
||||
|
||||
return $this;
|
||||
}
|
||||
}
|
850
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Uninstall_feedback.php
vendored
Normal file
850
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Modules/Uninstall_feedback.php
vendored
Normal file
@ -0,0 +1,850 @@
|
||||
<?php
|
||||
/**
|
||||
* The deactivate feedback model class for ThemeIsle SDK
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @subpackage Feedback
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-3.0.php GNU Public License
|
||||
* @since 1.0.0
|
||||
*/
|
||||
|
||||
namespace ThemeisleSDK\Modules;
|
||||
|
||||
use ThemeisleSDK\Common\Abstract_Module;
|
||||
use ThemeisleSDK\Product;
|
||||
|
||||
// Exit if accessed directly.
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
/**
|
||||
* Uninstall feedback module for ThemeIsle SDK.
|
||||
*/
|
||||
class Uninstall_Feedback extends Abstract_Module {
|
||||
/**
|
||||
* How many seconds before the deactivation window is triggered for themes?
|
||||
*
|
||||
* @var int Number of days.
|
||||
*/
|
||||
const AUTO_TRIGGER_DEACTIVATE_WINDOW_SECONDS = 3;
|
||||
/**
|
||||
* How many days before the deactivation window pops up again for the theme?
|
||||
*
|
||||
* @var int Number of days.
|
||||
*/
|
||||
const PAUSE_DEACTIVATE_WINDOW_DAYS = 100;
|
||||
/**
|
||||
* Where to send the data.
|
||||
*
|
||||
* @var string Endpoint url.
|
||||
*/
|
||||
const FEEDBACK_ENDPOINT = 'http://feedback.themeisle.com/wordpress/wp-json/__pirate_feedback_/v1/feedback';
|
||||
|
||||
/**
|
||||
* Default options for plugins.
|
||||
*
|
||||
* @var array $options_plugin The main options list for plugins.
|
||||
*/
|
||||
private $options_plugin = array(
|
||||
'I found a better plugin' => array(
|
||||
'id' => 3,
|
||||
'type' => 'text',
|
||||
'placeholder' => 'What\'s the plugin\'s name?',
|
||||
),
|
||||
'I could not get the plugin to work' => array(
|
||||
'type' => 'textarea',
|
||||
'placeholder' => 'What problem are you experiencing?',
|
||||
'id' => 4,
|
||||
),
|
||||
'I no longer need the plugin' => array(
|
||||
'id' => 5,
|
||||
'type' => 'textarea',
|
||||
'placeholder' => 'If you could improve one thing about our product, what would it be?',
|
||||
),
|
||||
'It\'s a temporary deactivation. I\'m just debugging an issue.' => array(
|
||||
'type' => 'textarea',
|
||||
'placeholder' => 'What problem are you experiencing?',
|
||||
'id' => 6,
|
||||
),
|
||||
);
|
||||
/**
|
||||
* Default options for theme.
|
||||
*
|
||||
* @var array $options_theme The main options list for themes.
|
||||
*/
|
||||
private $options_theme = array(
|
||||
'I don\'t know how to make it look like demo' => array(
|
||||
'id' => 7,
|
||||
),
|
||||
'It lacks options' => array(
|
||||
'placeholder' => 'What option is missing?',
|
||||
'type' => 'text',
|
||||
'id' => 8,
|
||||
),
|
||||
'Is not working with a plugin that I need' => array(
|
||||
'id' => 9,
|
||||
'type' => 'text',
|
||||
'placeholder' => 'What is the name of the plugin',
|
||||
),
|
||||
'I want to try a new design, I don\'t like {theme} style' => array(
|
||||
'id' => 10,
|
||||
),
|
||||
);
|
||||
/**
|
||||
* Default other option.
|
||||
*
|
||||
* @var array $other The other option
|
||||
*/
|
||||
private $other = array(
|
||||
'Other' => array(
|
||||
'id' => 999,
|
||||
'type' => 'textarea',
|
||||
'placeholder' => 'What can we do better?',
|
||||
),
|
||||
);
|
||||
/**
|
||||
* Default heading for plugin.
|
||||
*
|
||||
* @var string $heading_plugin The heading of the modal
|
||||
*/
|
||||
private $heading_plugin = 'What’s wrong?';
|
||||
/**
|
||||
* Default heading for theme.
|
||||
*
|
||||
* @var string $heading_theme The heading of the modal
|
||||
*/
|
||||
private $heading_theme = 'What does not work for you in {theme}?';
|
||||
/**
|
||||
* Default submit button action text.
|
||||
*
|
||||
* @var string $button_submit The text of the deactivate button
|
||||
*/
|
||||
private $button_submit = 'Submit & Deactivate';
|
||||
/**
|
||||
* Default cancel button.
|
||||
*
|
||||
* @var string $button_cancel The text of the cancel button
|
||||
*/
|
||||
private $button_cancel = 'Skip & Deactivate';
|
||||
|
||||
/**
|
||||
* Loads the additional resources
|
||||
*/
|
||||
function load_resources() {
|
||||
$screen = get_current_screen();
|
||||
|
||||
if ( ! $screen || ! in_array( $screen->id, array( 'theme-install', 'plugins' ) ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
$this->add_feedback_popup_style();
|
||||
|
||||
if ( $this->product->get_type() === 'theme' ) {
|
||||
$this->add_theme_feedback_drawer_js();
|
||||
$this->render_theme_feedback_popup();
|
||||
|
||||
return;
|
||||
}
|
||||
$this->add_plugin_feedback_popup_js();
|
||||
$this->render_plugin_feedback_popup();
|
||||
}
|
||||
|
||||
/**
|
||||
* Render theme feedback drawer.
|
||||
*/
|
||||
private function render_theme_feedback_popup() {
|
||||
$heading = str_replace( '{theme}', $this->product->get_name(), $this->heading_theme );
|
||||
$button_submit = apply_filters( $this->product->get_key() . '_feedback_deactivate_button_submit', 'Submit' );
|
||||
$options = $this->options_theme;
|
||||
$options = $this->randomize_options( apply_filters( $this->product->get_key() . '_feedback_deactivate_options', $options ) );
|
||||
$info_disclosure_link = '<a href="#" class="info-disclosure-link">' . apply_filters( $this->product->get_slug() . '_themeisle_sdk_info_collect_cta', 'What info do we collect?' ) . '</a>';
|
||||
|
||||
$options += $this->other;
|
||||
|
||||
?>
|
||||
<div class="ti-theme-uninstall-feedback-drawer ti-feedback">
|
||||
<div class="popup--header">
|
||||
<h5><?php echo wp_kses( $heading, array( 'span' => true ) ); ?> </h5>
|
||||
<button class="toggle"><span>×</span></button>
|
||||
</div><!--/.popup--header-->
|
||||
<div class="popup--body">
|
||||
<?php $this->render_options_list( $options ); ?>
|
||||
</div><!--/.popup--body-->
|
||||
<div class="popup--footer">
|
||||
<div class="actions">
|
||||
<?php
|
||||
echo wp_kses_post( $info_disclosure_link );
|
||||
echo wp_kses_post( $this->get_disclosure_labels() );
|
||||
echo '<div class="buttons">';
|
||||
echo get_submit_button(
|
||||
$button_submit,
|
||||
'secondary',
|
||||
$this->product->get_key() . 'ti-deactivate-yes',
|
||||
false,
|
||||
array(
|
||||
'data-after-text' => $button_submit,
|
||||
'disabled' => true,
|
||||
)
|
||||
);
|
||||
echo '</div>';
|
||||
?>
|
||||
</div><!--/.actions-->
|
||||
</div><!--/.popup--footer-->
|
||||
</div>
|
||||
<?php
|
||||
}
|
||||
|
||||
/**
|
||||
* Add feedback styles.
|
||||
*/
|
||||
private function add_feedback_popup_style() {
|
||||
?>
|
||||
<style>
|
||||
.ti-feedback {
|
||||
background: #fff;
|
||||
max-width: 400px;
|
||||
z-index: 10000;
|
||||
box-shadow: 0 0 15px -5px rgba(0, 0, 0, .5);
|
||||
transition: all .3s ease-out;
|
||||
}
|
||||
|
||||
|
||||
.ti-feedback .popup--header {
|
||||
position: relative;
|
||||
background-color: #23A1CE;
|
||||
}
|
||||
|
||||
.ti-feedback .popup--header h5 {
|
||||
margin: 0;
|
||||
font-size: 16px;
|
||||
padding: 15px;
|
||||
color: #fff;
|
||||
font-weight: 600;
|
||||
text-align: center;
|
||||
letter-spacing: .3px;
|
||||
}
|
||||
|
||||
.ti-feedback .popup--body {
|
||||
padding: 15px;
|
||||
}
|
||||
|
||||
.ti-feedback .popup--form {
|
||||
margin: 0;
|
||||
font-size: 13px;
|
||||
}
|
||||
|
||||
.ti-feedback .popup--form input[type="radio"] {
|
||||
margin: 0 10px 0 0;
|
||||
}
|
||||
|
||||
.ti-feedback .popup--form input[type="radio"]:checked ~ textarea {
|
||||
display: block;
|
||||
}
|
||||
|
||||
.ti-feedback .popup--form textarea {
|
||||
width: 100%;
|
||||
margin: 10px 0 0;
|
||||
display: none;
|
||||
max-height: 150px;
|
||||
}
|
||||
|
||||
.ti-feedback li {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
margin-bottom: 15px;
|
||||
flex-wrap: wrap;
|
||||
}
|
||||
|
||||
.ti-feedback li label {
|
||||
max-width: 90%;
|
||||
}
|
||||
|
||||
.ti-feedback li:last-child {
|
||||
margin-bottom: 0;
|
||||
}
|
||||
|
||||
.ti-feedback .popup--footer {
|
||||
padding: 0 15px 15px;
|
||||
}
|
||||
|
||||
.ti-feedback .actions {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
}
|
||||
|
||||
.info-disclosure-link {
|
||||
width: 100%;
|
||||
margin-bottom: 15px;
|
||||
}
|
||||
|
||||
.ti-feedback .info-disclosure-content {
|
||||
max-height: 0;
|
||||
overflow: hidden;
|
||||
width: 100%;
|
||||
transition: .3s ease;
|
||||
}
|
||||
|
||||
.ti-feedback .info-disclosure-content.active {
|
||||
max-height: 300px;
|
||||
}
|
||||
|
||||
.ti-feedback .info-disclosure-content p {
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.ti-feedback .info-disclosure-content ul {
|
||||
margin: 10px 0;
|
||||
border-radius: 3px;
|
||||
}
|
||||
|
||||
.ti-feedback .info-disclosure-content ul li {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: space-between;
|
||||
margin-bottom: 0;
|
||||
padding: 5px 0;
|
||||
border-bottom: 1px solid #ccc;
|
||||
}
|
||||
|
||||
.ti-feedback .buttons {
|
||||
display: flex;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.ti-feedback .buttons input:last-child {
|
||||
margin-left: auto;
|
||||
}
|
||||
|
||||
.ti-theme-uninstall-feedback-drawer {
|
||||
border-top-left-radius: 5px;
|
||||
position: fixed;
|
||||
top: 100%;
|
||||
right: 15px;
|
||||
}
|
||||
|
||||
.ti-theme-uninstall-feedback-drawer.active {
|
||||
transform: translateY(-100%);
|
||||
}
|
||||
|
||||
.ti-theme-uninstall-feedback-drawer .popup--header {
|
||||
border-top-left-radius: 5px;
|
||||
}
|
||||
|
||||
.ti-theme-uninstall-feedback-drawer .popup--header .toggle {
|
||||
position: absolute;
|
||||
padding: 3px 0;
|
||||
width: 30px;
|
||||
top: -26px;
|
||||
right: 0;
|
||||
cursor: pointer;
|
||||
border-top-left-radius: 5px;
|
||||
border-top-right-radius: 5px;
|
||||
font-size: 20px;
|
||||
background-color: #23A1CE;
|
||||
color: #fff;
|
||||
border: none;
|
||||
line-height: 20px;
|
||||
}
|
||||
|
||||
.ti-theme-uninstall-feedback-drawer .toggle span {
|
||||
margin: 0;
|
||||
display: inline-block;
|
||||
}
|
||||
|
||||
.ti-theme-uninstall-feedback-drawer:not(.active) .toggle span {
|
||||
transform: rotate(45deg);
|
||||
}
|
||||
|
||||
.ti-theme-uninstall-feedback-drawer .popup--header .toggle:hover {
|
||||
background-color: #1880a5;
|
||||
}
|
||||
|
||||
|
||||
.ti-plugin-uninstall-feedback-popup .popup--header:before {
|
||||
content: "";
|
||||
display: block;
|
||||
position: absolute;
|
||||
border: 20px solid #23A1CE;
|
||||
left: -10px;
|
||||
top: 50%;
|
||||
border-top: 20px solid transparent;
|
||||
border-bottom: 20px solid transparent;
|
||||
border-left: 0;
|
||||
transform: translateY(-50%);
|
||||
}
|
||||
|
||||
.ti-plugin-uninstall-feedback-popup {
|
||||
display: none;
|
||||
position: absolute;
|
||||
white-space: normal;
|
||||
width: 400px;
|
||||
left: 100%;
|
||||
top: -15px;
|
||||
}
|
||||
|
||||
.ti-plugin-uninstall-feedback-popup.sending-feedback .popup--body i {
|
||||
animation: rotation 2s infinite linear;
|
||||
display: block;
|
||||
float: none;
|
||||
align-items: center;
|
||||
width: 100%;
|
||||
margin: 0 auto;
|
||||
height: 100%;
|
||||
background: transparent;
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
.ti-plugin-uninstall-feedback-popup.sending-feedback .popup--body i:before {
|
||||
padding: 0;
|
||||
background: transparent;
|
||||
box-shadow: none;
|
||||
color: #b4b9be
|
||||
}
|
||||
|
||||
|
||||
.ti-plugin-uninstall-feedback-popup.active {
|
||||
display: block;
|
||||
}
|
||||
|
||||
tr[data-plugin^="<?php echo $this->product->get_slug(); ?>"] .deactivate {
|
||||
position: relative;
|
||||
}
|
||||
|
||||
body.ti-feedback-open .ti-feedback-overlay {
|
||||
content: "";
|
||||
display: block;
|
||||
background-color: rgba(0, 0, 0, 0.5);
|
||||
top: 0;
|
||||
bottom: 0;
|
||||
right: 0;
|
||||
left: 0;
|
||||
z-index: 10000;
|
||||
position: fixed;
|
||||
}
|
||||
|
||||
@media (max-width: 768px) {
|
||||
.ti-plugin-uninstall-feedback-popup {
|
||||
position: fixed;
|
||||
max-width: 100%;
|
||||
margin: 0 auto;
|
||||
left: 50%;
|
||||
top: 50px;
|
||||
transform: translateX(-50%);
|
||||
}
|
||||
|
||||
.ti-plugin-uninstall-feedback-popup .popup--header:before {
|
||||
display: none;
|
||||
}
|
||||
}
|
||||
</style>
|
||||
<?php
|
||||
}
|
||||
|
||||
/**
|
||||
* Theme feedback drawer JS.
|
||||
*/
|
||||
private function add_theme_feedback_drawer_js() {
|
||||
$key = $this->product->get_key();
|
||||
?>
|
||||
<script type="text/javascript" id="ti-deactivate-js">
|
||||
(function ($) {
|
||||
$(document).ready(function () {
|
||||
setTimeout(function () {
|
||||
$('.ti-theme-uninstall-feedback-drawer').addClass('active');
|
||||
}, <?php echo absint( self::AUTO_TRIGGER_DEACTIVATE_WINDOW_SECONDS * 1000 ); ?> );
|
||||
|
||||
$('.ti-theme-uninstall-feedback-drawer .toggle').on('click', function (e) {
|
||||
e.preventDefault();
|
||||
$('.ti-theme-uninstall-feedback-drawer').toggleClass('active');
|
||||
});
|
||||
|
||||
$('.info-disclosure-link').on('click', function (e) {
|
||||
e.preventDefault();
|
||||
$('.info-disclosure-content').toggleClass('active');
|
||||
});
|
||||
|
||||
$('.ti-theme-uninstall-feedback-drawer input[type="radio"]').on('change', function () {
|
||||
var radio = $(this);
|
||||
if (radio.parent().find('textarea').length > 0 &&
|
||||
radio.parent().find('textarea').val().length === 0) {
|
||||
$('#<?php echo $key; ?>ti-deactivate-yes').attr('disabled', 'disabled');
|
||||
radio.parent().find('textarea').on('keyup', function (e) {
|
||||
if ($(this).val().length === 0) {
|
||||
$('#<?php echo $key; ?>ti-deactivate-yes').attr('disabled', 'disabled');
|
||||
} else {
|
||||
$('#<?php echo $key; ?>ti-deactivate-yes').removeAttr('disabled');
|
||||
}
|
||||
});
|
||||
} else {
|
||||
$('#<?php echo $key; ?>ti-deactivate-yes').removeAttr('disabled');
|
||||
}
|
||||
});
|
||||
|
||||
$('#<?php echo $key; ?>ti-deactivate-yes').on('click', function (e) {
|
||||
e.preventDefault();
|
||||
e.stopPropagation();
|
||||
|
||||
var selectedOption = $(
|
||||
'.ti-theme-uninstall-feedback-drawer input[name="ti-deactivate-option"]:checked');
|
||||
$.post(ajaxurl, {
|
||||
'action': '<?php echo esc_attr( $key ) . '_uninstall_feedback'; ?>',
|
||||
'nonce': '<?php echo wp_create_nonce( (string) __CLASS__ ); ?>',
|
||||
'id': selectedOption.parent().attr('ti-option-id'),
|
||||
'msg': selectedOption.parent().find('textarea').val(),
|
||||
'type': 'theme',
|
||||
'key': '<?php echo esc_attr( $key ); ?>'
|
||||
});
|
||||
$('.ti-theme-uninstall-feedback-drawer').fadeOut();
|
||||
});
|
||||
});
|
||||
})(jQuery);
|
||||
|
||||
</script>
|
||||
<?php
|
||||
do_action( $this->product->get_key() . '_uninstall_feedback_after_js' );
|
||||
}
|
||||
|
||||
/**
|
||||
* Render the options list.
|
||||
*
|
||||
* @param array $options the options for the feedback form.
|
||||
*/
|
||||
private function render_options_list( $options ) {
|
||||
$key = $this->product->get_key();
|
||||
$inputs_row_map = [
|
||||
'text' => 1,
|
||||
'textarea' => 2,
|
||||
];
|
||||
?>
|
||||
<ul class="popup--form">
|
||||
<?php foreach ( $options as $title => $attributes ) { ?>
|
||||
<li ti-option-id="<?php echo esc_attr( $attributes['id'] ); ?>">
|
||||
<input type="radio" name="ti-deactivate-option" id="<?php echo esc_attr( $key . $attributes['id'] ); ?>">
|
||||
<label for="<?php echo esc_attr( $key . $attributes['id'] ); ?>">
|
||||
<?php echo str_replace( '{theme}', $this->product->get_name(), $title ); ?>
|
||||
</label>
|
||||
<?php
|
||||
if ( array_key_exists( 'type', $attributes ) ) {
|
||||
$placeholder = array_key_exists( 'placeholder', $attributes ) ? $attributes['placeholder'] : '';
|
||||
echo '<textarea width="100%" rows="' . $inputs_row_map[ $attributes['type'] ] . '" name="comments" placeholder="' . esc_attr( $placeholder ) . '"></textarea>';
|
||||
}
|
||||
?>
|
||||
</li>
|
||||
<?php } ?>
|
||||
</ul>
|
||||
<?php
|
||||
}
|
||||
|
||||
/**
|
||||
* Render plugin feedback popup.
|
||||
*/
|
||||
private function render_plugin_feedback_popup() {
|
||||
$button_cancel = apply_filters( $this->product->get_key() . '_feedback_deactivate_button_cancel', $this->button_cancel );
|
||||
$button_submit = apply_filters( $this->product->get_key() . '_feedback_deactivate_button_submit', $this->button_submit );
|
||||
$options = $this->randomize_options( apply_filters( $this->product->get_key() . '_feedback_deactivate_options', $this->options_plugin ) );
|
||||
$info_disclosure_link = '<a href="#" class="info-disclosure-link">' . apply_filters( $this->product->get_slug() . '_themeisle_sdk_info_collect_cta', 'What info do we collect?' ) . '</a>';
|
||||
|
||||
$options += $this->other;
|
||||
?>
|
||||
<div class="ti-plugin-uninstall-feedback-popup ti-feedback" id="<?php echo esc_attr( $this->product->get_slug() . '_uninstall_feedback_popup' ); ?>">
|
||||
<div class="popup--header">
|
||||
<h5><?php echo wp_kses( $this->heading_plugin, array( 'span' => true ) ); ?> </h5>
|
||||
</div><!--/.popup--header-->
|
||||
<div class="popup--body">
|
||||
<?php $this->render_options_list( $options ); ?>
|
||||
</div><!--/.popup--body-->
|
||||
<div class="popup--footer">
|
||||
<div class="actions">
|
||||
<?php
|
||||
echo wp_kses_post( $info_disclosure_link );
|
||||
echo wp_kses_post( $this->get_disclosure_labels() );
|
||||
echo '<div class="buttons">';
|
||||
echo get_submit_button(
|
||||
$button_cancel,
|
||||
'secondary',
|
||||
$this->product->get_key() . 'ti-deactivate-no',
|
||||
false
|
||||
);
|
||||
echo get_submit_button(
|
||||
$button_submit,
|
||||
'primary',
|
||||
$this->product->get_key() . 'ti-deactivate-yes',
|
||||
false,
|
||||
array(
|
||||
'data-after-text' => $button_submit,
|
||||
'disabled' => true,
|
||||
)
|
||||
);
|
||||
echo '</div>';
|
||||
?>
|
||||
</div><!--/.actions-->
|
||||
</div><!--/.popup--footer-->
|
||||
</div>
|
||||
|
||||
<?php
|
||||
}
|
||||
|
||||
/**
|
||||
* Add plugin feedback popup JS
|
||||
*/
|
||||
private function add_plugin_feedback_popup_js() {
|
||||
$popup_id = '#' . $this->product->get_slug() . '_uninstall_feedback_popup';
|
||||
$key = $this->product->get_key();
|
||||
?>
|
||||
<script type="text/javascript" id="ti-deactivate-js">
|
||||
(function ($) {
|
||||
$(document).ready(function () {
|
||||
var targetElement = 'tr[data-plugin^="<?php echo $this->product->get_slug(); ?>/"] span.deactivate a';
|
||||
var redirectUrl = $(targetElement).attr('href');
|
||||
if ($('.ti-feedback-overlay').length === 0) {
|
||||
$('body').prepend('<div class="ti-feedback-overlay"></div>');
|
||||
}
|
||||
$('<?php echo esc_attr( $popup_id ); ?> ').appendTo($(targetElement).parent());
|
||||
|
||||
$(targetElement).on('click', function (e) {
|
||||
e.preventDefault();
|
||||
$('<?php echo esc_attr( $popup_id ); ?> ').addClass('active');
|
||||
$('body').addClass('ti-feedback-open');
|
||||
$('.ti-feedback-overlay').on('click', function () {
|
||||
$('<?php echo esc_attr( $popup_id ); ?> ').removeClass('active');
|
||||
$('body').removeClass('ti-feedback-open');
|
||||
});
|
||||
});
|
||||
|
||||
$('<?php echo esc_attr( $popup_id ); ?> .info-disclosure-link').on('click', function (e) {
|
||||
e.preventDefault();
|
||||
$(this).parent().find('.info-disclosure-content').toggleClass('active');
|
||||
});
|
||||
|
||||
$('<?php echo esc_attr( $popup_id ); ?> input[type="radio"]').on('change', function () {
|
||||
var radio = $(this);
|
||||
if (radio.parent().find('textarea').length > 0 &&
|
||||
radio.parent().find('textarea').val().length === 0) {
|
||||
$('<?php echo esc_attr( $popup_id ); ?> #<?php echo $key; ?>ti-deactivate-yes').attr('disabled', 'disabled');
|
||||
radio.parent().find('textarea').on('keyup', function (e) {
|
||||
if ($(this).val().length === 0) {
|
||||
$('<?php echo esc_attr( $popup_id ); ?> #<?php echo $key; ?>ti-deactivate-yes').attr('disabled', 'disabled');
|
||||
} else {
|
||||
$('<?php echo esc_attr( $popup_id ); ?> #<?php echo $key; ?>ti-deactivate-yes').removeAttr('disabled');
|
||||
}
|
||||
});
|
||||
} else {
|
||||
$('<?php echo esc_attr( $popup_id ); ?> #<?php echo $key; ?>ti-deactivate-yes').removeAttr('disabled');
|
||||
}
|
||||
});
|
||||
|
||||
$('<?php echo esc_attr( $popup_id ); ?> #<?php echo $key; ?>ti-deactivate-no').on('click', function (e) {
|
||||
e.preventDefault();
|
||||
e.stopPropagation();
|
||||
$(targetElement).unbind('click');
|
||||
$('body').removeClass('ti-feedback-open');
|
||||
$('<?php echo esc_attr( $popup_id ); ?>').remove();
|
||||
if (redirectUrl !== '') {
|
||||
location.href = redirectUrl;
|
||||
}
|
||||
});
|
||||
|
||||
$('<?php echo esc_attr( $popup_id ); ?> #<?php echo $key; ?>ti-deactivate-yes').on('click', function (e) {
|
||||
e.preventDefault();
|
||||
e.stopPropagation();
|
||||
$(targetElement).unbind('click');
|
||||
var selectedOption = $(
|
||||
'<?php echo esc_attr( $popup_id ); ?> input[name="ti-deactivate-option"]:checked');
|
||||
var data = {
|
||||
'action': '<?php echo esc_attr( $key ) . '_uninstall_feedback'; ?>',
|
||||
'nonce': '<?php echo wp_create_nonce( (string) __CLASS__ ); ?>',
|
||||
'id': selectedOption.parent().attr('ti-option-id'),
|
||||
'msg': selectedOption.parent().find('textarea').val(),
|
||||
'type': 'plugin',
|
||||
'key': '<?php echo esc_attr( $key ); ?>'
|
||||
};
|
||||
$.ajax({
|
||||
type: 'POST',
|
||||
url: ajaxurl,
|
||||
data: data,
|
||||
complete() {
|
||||
$('body').removeClass('ti-feedback-open');
|
||||
$('<?php echo esc_attr( $popup_id ); ?>').remove();
|
||||
if (redirectUrl !== '') {
|
||||
location.href = redirectUrl;
|
||||
}
|
||||
},
|
||||
beforeSend() {
|
||||
$('<?php echo esc_attr( $popup_id ); ?>').addClass('sending-feedback');
|
||||
$('<?php echo esc_attr( $popup_id ); ?> .popup--footer').remove();
|
||||
$('<?php echo esc_attr( $popup_id ); ?> .popup--body').html('<i class="dashicons dashicons-update-alt"></i>');
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
})(jQuery);
|
||||
|
||||
</script>
|
||||
<?php
|
||||
do_action( $this->product->get_key() . '_uninstall_feedback_after_js' );
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the disclosure labels markup.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
private function get_disclosure_labels() {
|
||||
$disclosure_new_labels = apply_filters( $this->product->get_slug() . '_themeisle_sdk_disclosure_content_labels', [], $this->product );
|
||||
$disclosure_labels = array_merge(
|
||||
[
|
||||
'title' => 'Below is a detailed view of all data that ThemeIsle will receive if you fill in this survey. No domain name, email address or IP addresses are transmited after you submit the survey.',
|
||||
'items' => [
|
||||
sprintf( '%s %s version %s %s %s %s', '<strong>', ucwords( $this->product->get_type() ), '</strong>', '<code>', $this->product->get_version(), '</code>' ),
|
||||
sprintf( '%s Uninstall reason %s %s Selected reason from the above survey %s ', '<strong>', '</strong>', '<i>', '</i>' ),
|
||||
],
|
||||
],
|
||||
$disclosure_new_labels
|
||||
);
|
||||
|
||||
$info_disclosure_content = '<div class="info-disclosure-content"><p>' . wp_kses_post( $disclosure_labels['title'] ) . '</p><ul>';
|
||||
foreach ( $disclosure_labels['items'] as $disclosure_item ) {
|
||||
$info_disclosure_content .= sprintf( '<li>%s</li>', wp_kses_post( $disclosure_item ) );
|
||||
}
|
||||
$info_disclosure_content .= '</ul></div>';
|
||||
|
||||
return $info_disclosure_content;
|
||||
}
|
||||
|
||||
/**
|
||||
* Randomizes the options array.
|
||||
*
|
||||
* @param array $options The options array.
|
||||
*/
|
||||
function randomize_options( $options ) {
|
||||
$new = array();
|
||||
$keys = array_keys( $options );
|
||||
shuffle( $keys );
|
||||
|
||||
foreach ( $keys as $key ) {
|
||||
$new[ $key ] = $options[ $key ];
|
||||
}
|
||||
|
||||
return $new;
|
||||
}
|
||||
|
||||
/**
|
||||
* Called when the deactivate button is clicked.
|
||||
*/
|
||||
function post_deactivate() {
|
||||
check_ajax_referer( (string) __CLASS__, 'nonce' );
|
||||
|
||||
$this->post_deactivate_or_cancel();
|
||||
|
||||
if ( empty( $_POST['id'] ) ) {
|
||||
|
||||
wp_send_json( [] );
|
||||
|
||||
return;
|
||||
}
|
||||
$this->call_api(
|
||||
array(
|
||||
'type' => 'deactivate',
|
||||
'id' => $_POST['id'],
|
||||
'comment' => isset( $_POST['msg'] ) ? $_POST['msg'] : '',
|
||||
)
|
||||
);
|
||||
wp_send_json( [] );
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Called when the deactivate/cancel button is clicked.
|
||||
*/
|
||||
private function post_deactivate_or_cancel() {
|
||||
if ( ! isset( $_POST['type'] ) || ! isset( $_POST['key'] ) ) {
|
||||
return;
|
||||
}
|
||||
if ( 'theme' !== $_POST['type'] ) {
|
||||
return;
|
||||
}
|
||||
|
||||
set_transient( 'ti_sdk_pause_' . $_POST['key'], true, self::PAUSE_DEACTIVATE_WINDOW_DAYS * DAY_IN_SECONDS );
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Calls the API
|
||||
*
|
||||
* @param array $attributes The attributes of the post body.
|
||||
*
|
||||
* @return bool Is the request succesfull?
|
||||
*/
|
||||
protected function call_api( $attributes ) {
|
||||
$slug = $this->product->get_slug();
|
||||
$version = $this->product->get_version();
|
||||
$attributes['slug'] = $slug;
|
||||
$attributes['version'] = $version;
|
||||
|
||||
$response = wp_remote_post(
|
||||
self::FEEDBACK_ENDPOINT,
|
||||
array(
|
||||
'body' => $attributes,
|
||||
)
|
||||
);
|
||||
|
||||
return is_wp_error( $response );
|
||||
}
|
||||
|
||||
/**
|
||||
* Should we load this object?.
|
||||
*
|
||||
* @param Product $product Product object.
|
||||
*
|
||||
* @return bool Should we load the module?
|
||||
*/
|
||||
public function can_load( $product ) {
|
||||
if ( $this->is_from_partner( $product ) ) {
|
||||
return false;
|
||||
}
|
||||
if ( $product->is_theme() && ( false !== get_transient( 'ti_sdk_pause_' . $product->get_key(), false ) ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if ( defined( 'DOING_AJAX' ) && DOING_AJAX ) {
|
||||
return true;
|
||||
}
|
||||
global $pagenow;
|
||||
|
||||
if ( ! isset( $pagenow ) || empty( $pagenow ) ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if ( $product->is_plugin() && 'plugins.php' !== $pagenow ) {
|
||||
return false;
|
||||
|
||||
}
|
||||
if ( $product->is_theme() && 'theme-install.php' !== $pagenow ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Loads module hooks.
|
||||
*
|
||||
* @param Product $product Product details.
|
||||
*
|
||||
* @return Uninstall_Feedback Current module instance.
|
||||
*/
|
||||
public function load( $product ) {
|
||||
|
||||
if ( apply_filters( $product->get_key() . '_hide_uninstall_feedback', false ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
$this->product = $product;
|
||||
add_action( 'admin_head', array( $this, 'load_resources' ) );
|
||||
add_action( 'wp_ajax_' . $this->product->get_key() . '_uninstall_feedback', array( $this, 'post_deactivate' ) );
|
||||
|
||||
return $this;
|
||||
}
|
||||
}
|
418
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Product.php
vendored
Normal file
418
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/src/Product.php
vendored
Normal file
@ -0,0 +1,418 @@
|
||||
<?php
|
||||
/**
|
||||
* The product model class for ThemeIsle SDK
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @subpackage Product
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-3.0.php GNU Public License
|
||||
* @since 1.0.0
|
||||
*/
|
||||
|
||||
namespace ThemeisleSDK;
|
||||
|
||||
// Exit if accessed directly.
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
/**
|
||||
* Product model for ThemeIsle SDK.
|
||||
*/
|
||||
class Product {
|
||||
/**
|
||||
* Define plugin type string.
|
||||
*/
|
||||
const PLUGIN_TYPE = 'plugin';
|
||||
/**
|
||||
* Define theme type string.
|
||||
*/
|
||||
const THEME_TYPE = 'theme';
|
||||
/**
|
||||
* If the product has a pro version, contains the pro slug.
|
||||
*
|
||||
* @var string $pro_slug Pro slug, if available.
|
||||
*/
|
||||
public $pro_slug;
|
||||
/**
|
||||
* Current product slug.
|
||||
*
|
||||
* @var string $slug THe product slug.
|
||||
*/
|
||||
private $slug;
|
||||
/**
|
||||
* Product basefile, with the proper metadata.
|
||||
*
|
||||
* @var string $basefile The file with headers.
|
||||
*/
|
||||
private $basefile;
|
||||
/**
|
||||
* Type of the product.
|
||||
*
|
||||
* @var string $type The product type ( plugin | theme ).
|
||||
*/
|
||||
private $type;
|
||||
/**
|
||||
* The file name.
|
||||
*
|
||||
* @var string $file The file name.
|
||||
*/
|
||||
private $file;
|
||||
/**
|
||||
* Product name, fetched from the file headers.
|
||||
*
|
||||
* @var string $name The product name.
|
||||
*/
|
||||
private $name;
|
||||
/**
|
||||
* Product normalized key.
|
||||
*
|
||||
* @var string $key The product ready key.
|
||||
*/
|
||||
private $key;
|
||||
/**
|
||||
* Product store url.
|
||||
*
|
||||
* @var string $store_url The store url.
|
||||
*/
|
||||
private $store_url;
|
||||
/**
|
||||
* Product install timestamp.
|
||||
*
|
||||
* @var int $install The date of install.
|
||||
*/
|
||||
private $install;
|
||||
/**
|
||||
* Product store/author name.
|
||||
*
|
||||
* @var string $store_name The store name.
|
||||
*/
|
||||
private $store_name;
|
||||
/**
|
||||
* Does the product requires license.
|
||||
*
|
||||
* @var bool $requires_license Either user needs to activate it with license.
|
||||
*/
|
||||
private $requires_license;
|
||||
/**
|
||||
* Is the product available on wordpress.org
|
||||
*
|
||||
* @var bool $wordpress_available Either is available on WordPress or not.
|
||||
*/
|
||||
private $wordpress_available;
|
||||
/**
|
||||
* Current version of the product.
|
||||
*
|
||||
* @var string $version The product version.
|
||||
*/
|
||||
private $version;
|
||||
|
||||
/**
|
||||
* ThemeIsle_SDK_Product constructor.
|
||||
*
|
||||
* @param string $basefile Product basefile.
|
||||
*/
|
||||
public function __construct( $basefile ) {
|
||||
if ( ! empty( $basefile ) ) {
|
||||
if ( is_file( $basefile ) ) {
|
||||
$this->basefile = $basefile;
|
||||
$this->setup_from_path();
|
||||
$this->setup_from_fileheaders();
|
||||
}
|
||||
}
|
||||
$install = get_option( $this->get_key() . '_install', 0 );
|
||||
if ( 0 === $install ) {
|
||||
$install = time();
|
||||
update_option( $this->get_key() . '_install', time() );
|
||||
}
|
||||
$this->install = $install;
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Setup props from path.
|
||||
*/
|
||||
public function setup_from_path() {
|
||||
$this->file = basename( $this->basefile );
|
||||
$dir = dirname( $this->basefile );
|
||||
$this->slug = basename( $dir );
|
||||
$exts = explode( '.', $this->basefile );
|
||||
$ext = $exts[ count( $exts ) - 1 ];
|
||||
if ( 'css' === $ext ) {
|
||||
$this->type = 'theme';
|
||||
}
|
||||
if ( 'php' === $ext ) {
|
||||
$this->type = 'plugin';
|
||||
}
|
||||
$this->key = self::key_ready_name( $this->slug );
|
||||
}
|
||||
|
||||
/**
|
||||
* Normalize string.
|
||||
*
|
||||
* @param string $string the String to be normalized for cron handler.
|
||||
*
|
||||
* @return string $name The normalized string.
|
||||
*/
|
||||
static function key_ready_name( $string ) {
|
||||
return str_replace( '-', '_', strtolower( trim( $string ) ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Setup props from fileheaders.
|
||||
*/
|
||||
public function setup_from_fileheaders() {
|
||||
$file_headers = array(
|
||||
'Requires License' => 'Requires License',
|
||||
'WordPress Available' => 'WordPress Available',
|
||||
'Pro Slug' => 'Pro Slug',
|
||||
'Version' => 'Version',
|
||||
);
|
||||
if ( 'plugin' === $this->type ) {
|
||||
$file_headers['Name'] = 'Plugin Name';
|
||||
$file_headers['AuthorName'] = 'Author';
|
||||
$file_headers['AuthorURI'] = 'Author URI';
|
||||
}
|
||||
if ( 'theme' === $this->type ) {
|
||||
$file_headers['Name'] = 'Theme Name';
|
||||
$file_headers['AuthorName'] = 'Author';
|
||||
$file_headers['AuthorURI'] = 'Author URI';
|
||||
}
|
||||
$file_headers = get_file_data( $this->basefile, $file_headers );
|
||||
|
||||
$this->name = $file_headers['Name'];
|
||||
$this->store_name = $file_headers['AuthorName'];
|
||||
$this->author_url = $file_headers['AuthorURI'];
|
||||
$this->store_url = $file_headers['AuthorURI'];
|
||||
|
||||
$this->requires_license = ( 'yes' === $file_headers['Requires License'] ) ? true : false;
|
||||
$this->wordpress_available = ( 'yes' === $file_headers['WordPress Available'] ) ? true : false;
|
||||
$this->pro_slug = ! empty( $file_headers['Pro Slug'] ) ? $file_headers['Pro Slug'] : '';
|
||||
$this->version = $file_headers['Version'];
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the product key.
|
||||
*
|
||||
* @return string The product key.
|
||||
*/
|
||||
public function get_key() {
|
||||
return $this->key;
|
||||
}
|
||||
|
||||
/**
|
||||
* Check if the product is either theme or plugin.
|
||||
*
|
||||
* @return string Product type.
|
||||
*/
|
||||
public function get_type() {
|
||||
return $this->type;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return if the product is used as a plugin.
|
||||
*
|
||||
* @return bool Is plugin?
|
||||
*/
|
||||
public function is_plugin() {
|
||||
return self::PLUGIN_TYPE === $this->type;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return if the product is used as a theme.
|
||||
*
|
||||
* @return bool Is theme ?
|
||||
*/
|
||||
public function is_theme() {
|
||||
return self::THEME_TYPE === $this->type;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the product slug.
|
||||
*
|
||||
* @return string The product slug.
|
||||
*/
|
||||
public function get_slug() {
|
||||
return $this->slug;
|
||||
}
|
||||
|
||||
/**
|
||||
* The magic var_dump info method.
|
||||
*
|
||||
* @return array Debug info.
|
||||
*/
|
||||
public function __debugInfo() {
|
||||
return array(
|
||||
'name' => $this->name,
|
||||
'slug' => $this->slug,
|
||||
'version' => $this->version,
|
||||
'basefile' => $this->basefile,
|
||||
'key' => $this->key,
|
||||
'type' => $this->type,
|
||||
'store_name' => $this->store_name,
|
||||
'store_url' => $this->store_url,
|
||||
'wordpress_available' => $this->wordpress_available,
|
||||
'requires_license' => $this->requires_license,
|
||||
);
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Getter for product version.
|
||||
*
|
||||
* @return string The product version.
|
||||
*/
|
||||
public function get_version() {
|
||||
return $this->version;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns current product license, if available.
|
||||
*
|
||||
* @return string Return license key, if available.
|
||||
*/
|
||||
public function get_license() {
|
||||
|
||||
if ( ! $this->requires_license() && ! $this->is_wordpress_available() ) {
|
||||
return 'free';
|
||||
}
|
||||
$license_data = get_option( $this->get_key() . '_license_data', '' );
|
||||
|
||||
if ( empty( $license_data ) ) {
|
||||
return get_option( $this->get_key() . '_license', '' );
|
||||
}
|
||||
if ( ! isset( $license_data->key ) ) {
|
||||
return get_option( $this->get_key() . '_license', '' );
|
||||
}
|
||||
|
||||
return $license_data->key;
|
||||
}
|
||||
|
||||
/**
|
||||
* Either the product requires license or not.
|
||||
*
|
||||
* @return bool Either requires license or not.
|
||||
*/
|
||||
public function requires_license() {
|
||||
return $this->requires_license;
|
||||
}
|
||||
|
||||
/**
|
||||
* If product is available on wordpress.org or not.
|
||||
*
|
||||
* @return bool Either is wp available or not.
|
||||
*/
|
||||
public function is_wordpress_available() {
|
||||
return $this->wordpress_available;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return friendly name.
|
||||
*
|
||||
* @return string Friendly name.
|
||||
*/
|
||||
public function get_friendly_name() {
|
||||
$name = apply_filters( $this->get_key() . '_friendly_name', trim( str_replace( 'Lite', '', $this->get_name() ) ) );
|
||||
$name = rtrim( $name, '- ()' );
|
||||
|
||||
return $name;
|
||||
}
|
||||
|
||||
/**
|
||||
* Getter for product name.
|
||||
*
|
||||
* @return string The product name.
|
||||
*/
|
||||
public function get_name() {
|
||||
return $this->name;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the Store name.
|
||||
*
|
||||
* @return string Store name.
|
||||
*/
|
||||
public function get_store_name() {
|
||||
return $this->store_name;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the store url.
|
||||
*
|
||||
* @return string The store url.
|
||||
*/
|
||||
public function get_store_url() {
|
||||
|
||||
if ( strpos( $this->store_url, '/themeisle.com' ) !== false ) {
|
||||
return 'https://store.themeisle.com/';
|
||||
}
|
||||
|
||||
return $this->store_url;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns product basefile, which holds the metaheaders.
|
||||
*
|
||||
* @return string The product basefile.
|
||||
*/
|
||||
public function get_basefile() {
|
||||
return $this->basefile;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get changelog url.
|
||||
*
|
||||
* @return string Changelog url.
|
||||
*/
|
||||
public function get_changelog() {
|
||||
return add_query_arg(
|
||||
[
|
||||
'name' => rawurlencode( $this->get_name() ),
|
||||
'edd_action' => 'view_changelog',
|
||||
],
|
||||
$this->get_store_url()
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns product filename.
|
||||
*
|
||||
* @return string The product filename.
|
||||
*/
|
||||
public function get_file() {
|
||||
return $this->file;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the pro slug, if available.
|
||||
*
|
||||
* @return string The pro slug.
|
||||
*/
|
||||
public function get_pro_slug() {
|
||||
return $this->pro_slug;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the install timestamp.
|
||||
*
|
||||
* @return int The install timestamp.
|
||||
*/
|
||||
public function get_install_time() {
|
||||
return $this->install;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the URL of the product base file.
|
||||
*
|
||||
* @param string $path The path to the file.
|
||||
*
|
||||
* @return string The URL of the product base file.
|
||||
*/
|
||||
public function get_base_url( $path = '/' ) {
|
||||
if ( $this->type ) {
|
||||
return plugins_url( $path, $this->basefile );
|
||||
}
|
||||
}
|
||||
|
||||
}
|
49
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/start.php
vendored
Normal file
49
wp-content/plugins/menu-icons/vendor/codeinwp/themeisle-sdk/start.php
vendored
Normal file
@ -0,0 +1,49 @@
|
||||
<?php
|
||||
/**
|
||||
* File responsible for sdk files loading.
|
||||
*
|
||||
* @package ThemeIsleSDK
|
||||
* @copyright Copyright (c) 2017, Marius Cristea
|
||||
* @license http://opensource.org/licenses/gpl-2.0.php GNU Public License
|
||||
* @since 1.1.0
|
||||
*/
|
||||
|
||||
namespace ThemeisleSDK;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit;
|
||||
}
|
||||
$products = apply_filters( 'themeisle_sdk_products', array() );
|
||||
$path = dirname( __FILE__ );
|
||||
$files_to_load = [
|
||||
$path . '/src/' . 'Loader.php',
|
||||
$path . '/src/' . 'Product.php',
|
||||
|
||||
$path . '/src/' . 'Common/Abstract_module.php',
|
||||
$path . '/src/' . 'Common/Module_factory.php',
|
||||
|
||||
$path . '/src/' . 'Modules/Dashboard_widget.php',
|
||||
$path . '/src/' . 'Modules/Rollback.php',
|
||||
$path . '/src/' . 'Modules/Uninstall_feedback.php',
|
||||
$path . '/src/' . 'Modules/Licenser.php',
|
||||
$path . '/src/' . 'Modules/Endpoint.php',
|
||||
$path . '/src/' . 'Modules/Notification.php',
|
||||
$path . '/src/' . 'Modules/Logger.php',
|
||||
$path . '/src/' . 'Modules/Translate.php',
|
||||
$path . '/src/' . 'Modules/Review.php',
|
||||
$path . '/src/' . 'Modules/Recommendation.php',
|
||||
];
|
||||
|
||||
$files_to_load = array_merge( $files_to_load, apply_filters( 'themeisle_sdk_required_files', [] ) );
|
||||
|
||||
foreach ( $files_to_load as $file ) {
|
||||
if ( is_file( $file ) ) {
|
||||
require_once $file;
|
||||
}
|
||||
}
|
||||
|
||||
Loader::init();
|
||||
|
||||
foreach ( $products as $product ) {
|
||||
Loader::add_product( $product );
|
||||
}
|
Reference in New Issue
Block a user