Repo created

This commit is contained in:
Fr4nz D13trich 2025-11-20 16:34:49 +01:00
parent 21de94943c
commit 4e2998210b
143 changed files with 10606 additions and 2 deletions

674
LICENSE.md Normal file
View file

@ -0,0 +1,674 @@
GNU GENERAL PUBLIC LICENSE
Version 3, 29 June 2007
Copyright (C) 2007 Free Software Foundation, Inc. <https://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 <https://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:
<program> Copyright (C) <year> <name of author>
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
<https://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
<https://www.gnu.org/licenses/why-not-lgpl.html>.

103
README.md
View file

@ -1,3 +1,102 @@
# de-bloater
# De-Bloater
Android Application Cleaner
![De-Bloater](app/src/main/res/mipmap-xxxhdpi/ic_launcher.png?raw=true)
[![](https://img.shields.io/badge/De--Bloater-v0.30-green)](https://play.google.com/store/apps/details?id=com.sunilpaulmathew.debloater)
![](https://img.shields.io/github/downloads/sunilpaulmathew/De-Bloater/total)
![](https://img.shields.io/github/languages/top/sunilpaulmathew/De-Bloater)
![](https://img.shields.io/github/contributors/sunilpaulmathew/De-Bloater)
### De-Bloater is an application using the power of Magisk/Kernel SU/APatch to de-bloat unwanted applications systemless-ly.
## Download
[<img src="https://play.google.com/intl/en_us/badges/images/generic/en-play-badge.png"
alt=""
height="80">](https://play.google.com/store/apps/details?id=com.sunilpaulmathew.debloater)
[<img src="https://fdroid.gitlab.io/artwork/badge/get-it-on.png"
alt=""
height="80">](https://f-droid.org/packages/com.sunilpaulmathew.debloater)
[<img src="https://gitlab.com/IzzyOnDroid/repo/-/raw/master/assets/IzzyOnDroid.png"
alt=""
height="80">](https://apt.izzysoft.de/fdroid/index/apk/com.sunilpaulmathew.debloater)
[<img src="https://i.ibb.co/q0mdc4Z/get-it-on-github.png"
alt=""
height="80">](https://github.com/sunilpaulmathew/De-Bloater/releases/download/v0.30/app-release.apk)
## Features
* Easily remove system apps from "/system", "/vendor", and "/product" directories.
## Requirement
De-Bloater requires Root Access and a fully functional Magisk or Kernel SU or APatch environment, including modules, for proper working. As a result, De-Bloater won't work with other rooting solutions as well as in Magisk core-only mode.
## How to Use
Open the app, click the remove button on each app you want to remove. The selected apps will be removed systemless-ly after a reboot. To restore an app, either Reset Module (on the top menu) or selectively restore from the second page. Please note that a restart is necessary to get any of the changes in effect.
## How it works
The app will systemless-ly replace the selected APKs by making a Magisk/Kernel SU/APatch module. As a result, you will see a new Module (name: De-bloater).
## Troubleshooting
In case, if you accidentally remove some important apps and your phone bootloops, please delete "/data/adb/modules/De-bloater" via recovery.
## Translations
Please help me to translate this application via [POEditor](https://poeditor.com/join/project?hash=BZS89Ev3WG). You may also translate after downloading the original language string available [here](app/src/main/res/values/strings.xml).
## Donations
If you like to appreciate my work, please consider donating to me (either via [Liberapay](https://liberapay.com/sunilpaulmathew/donate), [PayPal](https://www.paypal.me/menacherry/), [Ko-fi](https://ko-fi.com/sunilpaulmathew/), or by purchasing the [SmartPack Donation Package](https://play.google.com/store/apps/details?id=com.smartpack.donate) from playstore) as it is helpful to continue my projects more active, although it is not at all necessary.
[<img src="https://liberapay.com/assets/widgets/donate.svg"
alt=""
height="80">](https://liberapay.com/sunilpaulmathew/donate/)
[<img src="https://raw.githubusercontent.com/SmartPack/SmartPack.github.io/master/asset/pic005.png"
alt=""
height="80">](https://www.paypal.me/menacherry/)
[<img src="https://raw.githubusercontent.com/SmartPack/SmartPack.github.io/master/asset/pic010.png"
alt=""
height="80">](https://ko-fi.com/sunilpaulmathew/)
[<img src="https://play.google.com/intl/en_us/badges/images/generic/en-play-badge.png"
alt=""
height="80">](https://play.google.com/store/apps/details?id=com.smartpack.donate)
## Credits
* [Grarak](https://github.com/Grarak/), Code contributions (I took some code from [Kernel Adiutor](https://github.com/Grarak/KernelAdiutor/))
* [John Wu](https://github.com/topjohnwu), libsu & Magisk
* [weishu](https://github.com/tiann), KernelSU
* [MONSTER_PC](https://t.me/MONSTER_PC), Russian & Ukrainian Translations
* [Emre](https://t.me/xcooLwastaken), Turkish Translations
* [Firerust96](https://github.com/Firerust96), Spanish Translations
* lay4play, Italian Translations
* Axel Schaab, German Translations
* alex, Ktosspl & [Valdnet](https://github.com/Valdnet), Polish Translations
* Reno & Ebolateam, French Translations
* Hoa Gia Đại Thiếu & ひきたり, Vietnamese Translations
* Hongle & qiaoxin, Chinese - Hong Kong (Simplified & Traditional) Translations
* [MMETMA](https://github.com/MMETMA), Arabic Translations
* Many other people contributed via [POEditor](https://poeditor.com/join/project?hash=BZS89Ev3WG)
* Guima Teixeira, French (Belgian) Translations
* Yadi & 蔡承佑, Chinese (Traditional) Translations
* Geovanni, Portuguese (Brazilian) Translations
* Lw201811, Japanese Translations
* Chong & Lw201811, Chinese (Simplified) Translations
* Ignác Czébán, Hungarian Translations
* mx. sony, Slovakian Translations
* Leudy R. Villa Calcaño, Dominican Spanish Translations
* Many other people contributed via [POEditor](https://poeditor.com/join/project?hash=BZS89Ev3WG)
_If you think I missed your name, please let me know._
## License
Copyright (C) 2020-2025 sunilpaulmathew <sunil.kde@gmail.com>
De-Bloater is a free softwares: 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.
De-Bloater 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 De-Bloater. If not, see <http://www.gnu.org/licenses/>.

3
app/.gitignore vendored Normal file
View file

@ -0,0 +1,3 @@
/build
/release
*.jks

79
app/build.gradle Normal file
View file

@ -0,0 +1,79 @@
plugins {
alias(libs.plugins.androidApplication)
}
def keystoreFile = rootProject.file("app/sp.jks")
android {
if (keystoreFile.exists()) {
signingConfigs {
release {
storeFile file("sp.jks")
storePassword "smartpack"
keyAlias "sp_key1"
keyPassword "smartpack"
}
}
}
dependenciesInfo {
// Disables dependency metadata when building APKs.
includeInApk = false
// Disables dependency metadata when building Android App Bundles.
includeInBundle = false
}
compileSdk 36
namespace 'com.sunilpaulmathew.debloater'
defaultConfig {
applicationId "com.sunilpaulmathew.debloater"
minSdkVersion 23
targetSdk 35
versionCode 30
versionName "v0.30"
vectorDrawables.useSupportLibrary = true
testFunctionalTest = false
testHandleProfiling = false
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
if (keystoreFile.exists()) {
signingConfig signingConfigs.release
}
minifyEnabled true
shrinkResources true
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
buildFeatures {
buildConfig = true
}
lint {
abortOnError false
}
}
dependencies {
implementation libs.rootfilepicker
implementation libs.adapters
implementation libs.apkutils
implementation libs.credits
implementation libs.fileutils
implementation libs.jsonutils
implementation libs.packageutils
implementation libs.permissionutils
implementation libs.themeutils
implementation libs.translatorutils
implementation libs.libsu
implementation libs.material
}
java {
toolchain {
languageVersion = JavaLanguageVersion.of(17)
}
}

21
app/proguard-rules.pro vendored Normal file
View file

@ -0,0 +1,21 @@
# Add project specific ProGuard rules here.
# You can control the set of applied configuration files using the
# proguardFiles setting in build.gradle.
#
# For more details, see
# http://developer.android.com/guide/developing/tools/proguard.html
# If your project uses WebView with JS, uncomment the following
# and specify the fully qualified class name to the JavaScript interface
# class:
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
# public *;
#}
# Uncomment this to preserve the line number information for
# debugging stack traces.
#-keepattributes SourceFile,LineNumberTable
# If you keep the line number information, uncomment this to
# hide the original source file name.
#-renamesourcefileattribute SourceFile

View file

@ -0,0 +1,51 @@
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools">
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.READ_PHONE_STATE"
tools:node="remove" />
<uses-permission android:name="android.permission.REQUEST_DELETE_PACKAGES" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"
tools:ignore="ScopedStorage" />
<uses-permission android:name="android.permission.QUERY_ALL_PACKAGES"
tools:ignore="QueryAllPackagesPermission" />
<application
android:allowBackup="true"
android:fullBackupContent="true"
android:icon="@mipmap/ic_launcher"
android:roundIcon="@mipmap/ic_launcher_round"
android:label="@string/app_name"
android:theme="@style/AppTheme"
android:supportsRtl="true" >
<activity android:name=".activities.StartActivity"
android:exported="true" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity android:name=".MainActivity"
android:exported="false" />
<activity android:name=".activities.ChangeLogActivity"
android:exported="false" />
<activity android:name=".activities.TomatotActivity"
android:exported="false" />
<activity android:name=".activities.UADActivity"
android:exported="false" />
<provider
android:name="androidx.core.content.FileProvider"
android:authorities="com.sunilpaulmathew.debloater.provider"
android:grantUriPermissions="true"
android:exported="false" >
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/provider_paths"/>
</provider>
</application>
</manifest>

File diff suppressed because one or more lines are too long

Binary file not shown.

After

Width:  |  Height:  |  Size: 51 KiB

View file

@ -0,0 +1,91 @@
package com.sunilpaulmathew.debloater;
import android.annotation.SuppressLint;
import android.os.Bundle;
import android.view.View;
import androidx.appcompat.app.AppCompatActivity;
import androidx.fragment.app.Fragment;
import com.google.android.material.bottomnavigation.BottomNavigationView;
import com.google.android.material.textview.MaterialTextView;
import com.sunilpaulmathew.debloater.fragments.AboutFragment;
import com.sunilpaulmathew.debloater.fragments.ActivePackagesFragment;
import com.sunilpaulmathew.debloater.fragments.InactivePackagesFragment;
import com.sunilpaulmathew.debloater.utils.UpdateCheck;
import com.sunilpaulmathew.debloater.utils.Utils;
import in.sunilpaulmathew.sCommon.Adapters.sPagerAdapter;
import in.sunilpaulmathew.sCommon.CommonUtils.sCommonUtils;
import in.sunilpaulmathew.sCommon.PackageUtils.sPackageUtils;
import in.sunilpaulmathew.sCommon.ThemeUtils.sThemeUtils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on October 27, 2020
*/
public class MainActivity extends AppCompatActivity {
private Fragment mFragment;
@SuppressLint("NonConstantResourceId")
@Override
protected void onCreate(Bundle savedInstanceState) {
//Initialize App Theme
sThemeUtils.initializeAppTheme(this);
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
BottomNavigationView mBottomNav = findViewById(R.id.bottom_navigation);
MaterialTextView mUnSupported = findViewById(R.id.unsupported);
if (!Utils.rootAccess()) {
mUnSupported.setText(R.string.no_root);
mUnSupported.setVisibility(View.VISIBLE);
return;
} else if (!Utils.magiskSupported()) {
mUnSupported.setText(R.string.no_magisk);
mUnSupported.setVisibility(View.VISIBLE);
return;
}
sPagerAdapter adapter = new sPagerAdapter(getSupportFragmentManager());
adapter.AddFragment(new ActivePackagesFragment(), null);
adapter.AddFragment(new InactivePackagesFragment(), null);
adapter.AddFragment(new AboutFragment(), null);
mBottomNav.setOnItemSelectedListener(
menuItem -> {
if (menuItem.getItemId() == R.id.nav_active) {
mFragment = new ActivePackagesFragment();
} else if (menuItem.getItemId() == R.id.nav_inactive) {
mFragment = new InactivePackagesFragment();
} else if (menuItem.getItemId() == R.id.nav_about) {
mFragment = new AboutFragment();
}
getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container,
mFragment).commit();
return true;
}
);
mBottomNav.setVisibility(View.VISIBLE);
if (savedInstanceState == null) {
getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container,
new ActivePackagesFragment()).commit();
}
}
@Override
public void onStart() {
super.onStart();
if (Utils.rootAccess() && Utils.magiskSupported() && !sPackageUtils.isPackageInstalled("com.android.vending",
this) && sCommonUtils.getInt("update_enabled", 2, this) == 0 && UpdateCheck.isSignatureMatched(this)) {
new UpdateCheck().initialize(1, this);
}
}
}

View file

@ -0,0 +1,44 @@
package com.sunilpaulmathew.debloater.activities;
import android.annotation.SuppressLint;
import android.os.Bundle;
import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;
import com.google.android.material.textview.MaterialTextView;
import com.sunilpaulmathew.debloater.BuildConfig;
import com.sunilpaulmathew.debloater.R;
import java.io.IOException;
import in.sunilpaulmathew.sCommon.FileUtils.sFileUtils;
import in.sunilpaulmathew.sCommon.JsonUtils.sJSONUtils;
import in.sunilpaulmathew.sCommon.PackageUtils.sPackageUtils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on December 28, 2020
*/
public class ChangeLogActivity extends AppCompatActivity {
@SuppressLint("SetTextI18n")
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_changelog);
MaterialTextView mChangeLog = findViewById(R.id.change_log);
MaterialTextView mTitle = findViewById(R.id.app_title);
MaterialTextView mCancel = findViewById(R.id.cancel_button);
mTitle.setText(getString(R.string.app_name) + (sPackageUtils.isPackageInstalled("com.android.vending",
this) ? " Pro " : " ") + BuildConfig.VERSION_NAME);
try {
mChangeLog.setText(sJSONUtils.getString(sJSONUtils.getJSONObject(sFileUtils.readAssetFile(
"release.json", this)), "fullReleaseNotes"));
} catch (IOException ignored) {
}
mCancel.setOnClickListener(v -> finish());
}
}

View file

@ -0,0 +1,78 @@
package com.sunilpaulmathew.debloater.activities;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.ProgressBar;
import androidx.appcompat.app.AppCompatActivity;
import com.google.android.material.card.MaterialCardView;
import com.google.android.material.textview.MaterialTextView;
import com.sunilpaulmathew.debloater.MainActivity;
import com.sunilpaulmathew.debloater.R;
import com.sunilpaulmathew.debloater.utils.Common;
import com.sunilpaulmathew.debloater.utils.PackageTasks;
import in.sunilpaulmathew.sCommon.CommonUtils.sCommonUtils;
import in.sunilpaulmathew.sCommon.CommonUtils.sExecutor;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on November 1, 2020
*/
public class StartActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_start);
MaterialCardView mStartCard = findViewById(R.id.start_card);
MaterialTextView mWarning = findViewById(R.id.warning);
ProgressBar mProgress = findViewById(R.id.progress);
if (!sCommonUtils.getBoolean("warning_message", false, this)) {
mProgress.setVisibility(View.GONE);
mWarning.setVisibility(View.VISIBLE);
mStartCard.setVisibility(View.VISIBLE);
} else {
loadUI(StartActivity.this);
}
mStartCard.setOnClickListener(v -> {
mProgress.setVisibility(View.VISIBLE);
mWarning.setVisibility(View.GONE);
mStartCard.setVisibility(View.GONE);
loadUI(StartActivity.this);
});
}
private static void loadUI(Activity activity) {
new sExecutor() {
@Override
public void onPreExecute() {
if (!sCommonUtils.getBoolean("warning_message", false, activity)) {
sCommonUtils.saveBoolean("warning_message", true, activity);
}
}
@Override
public void doInBackground() {
// Acquire information about installed apps
Common.setRawData(PackageTasks.getRawData(activity));
}
@Override
public void onPostExecute() {
// Launch MainActivity
Intent mainActivity = new Intent(activity, MainActivity.class);
activity.startActivity(mainActivity);
activity.finish();
}
}.execute();
}
}

View file

@ -0,0 +1,62 @@
package com.sunilpaulmathew.debloater.activities;
import android.graphics.Color;
import android.os.Bundle;
import android.view.View;
import android.widget.FrameLayout;
import android.widget.LinearLayout;
import android.widget.ProgressBar;
import androidx.appcompat.app.AppCompatActivity;
import com.sunilpaulmathew.debloater.R;
import com.sunilpaulmathew.debloater.fragments.TomatotDebloaterFragment;
import com.sunilpaulmathew.debloater.utils.Tomatot;
import in.sunilpaulmathew.sCommon.CommonUtils.sExecutor;
import in.sunilpaulmathew.sCommon.ThemeUtils.sThemeUtils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on November 4, 2020
*/
public class TomatotActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_custom_scripts);
FrameLayout mFrameLayout = findViewById(R.id.fragment_container);
LinearLayout mLinearLayout = findViewById(R.id.layout_main);
ProgressBar mProgressBar = findViewById(R.id.progress);
new sExecutor() {
@Override
public void onPreExecute() {
if (sThemeUtils.isDarkTheme(TomatotActivity.this)) {
mLinearLayout.setBackgroundColor(Color.BLACK);
} else {
mLinearLayout.setBackgroundColor(Color.WHITE);
}
}
@Override
public void doInBackground() {
Tomatot.setInvisibleData(TomatotActivity.this);
Tomatot.setLightData(TomatotActivity.this);
Tomatot.setExtremeData(TomatotActivity.this);
}
@Override
public void onPostExecute() {
mProgressBar.setVisibility(View.GONE);
mFrameLayout.setVisibility(View.VISIBLE);
getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container,
new TomatotDebloaterFragment()).commit();
}
}.execute();
}
}

View file

@ -0,0 +1,75 @@
package com.sunilpaulmathew.debloater.activities;
import android.graphics.Color;
import android.os.Bundle;
import android.view.View;
import android.widget.FrameLayout;
import android.widget.LinearLayout;
import android.widget.ProgressBar;
import androidx.appcompat.app.AppCompatActivity;
import com.sunilpaulmathew.debloater.R;
import com.sunilpaulmathew.debloater.fragments.UADFragment;
import com.sunilpaulmathew.debloater.utils.Common;
import com.sunilpaulmathew.debloater.utils.UAD;
import in.sunilpaulmathew.sCommon.CommonUtils.sExecutor;
import in.sunilpaulmathew.sCommon.ThemeUtils.sThemeUtils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on January 26, 2020
*/
public class UADActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_custom_scripts);
FrameLayout mFrameLayout = findViewById(R.id.fragment_container);
LinearLayout mLinearLayout = findViewById(R.id.layout_main);
ProgressBar mProgressBar = findViewById(R.id.progress);
new sExecutor() {
@Override
public void onPreExecute() {
if (sThemeUtils.isDarkTheme(UADActivity.this)) {
mLinearLayout.setBackgroundColor(Color.BLACK);
} else {
mLinearLayout.setBackgroundColor(Color.WHITE);
}
}
@Override
public void doInBackground() {
UAD.setUADData(UAD.getCarrier(), Common.getCarrier(), UADActivity.this);
UAD.setUADData(UAD.getHuawei(), Common.getHuawei(), UADActivity.this);
UAD.setUADData(UAD.getLG(), Common.getLG(), UADActivity.this);
UAD.setUADData(UAD.getMiscellaneous(), Common.getMisc(), UADActivity.this);
UAD.setUADData(UAD.getMotorola(), Common.getMoto(), UADActivity.this);
UAD.setUADData(UAD.getNokia(), Common.getNokia(), UADActivity.this);
UAD.setUADData(UAD.getOppo(), Common.getOppo(), UADActivity.this);
UAD.setUADData(UAD.getSamsung(), Common.getSamsung(), UADActivity.this);
UAD.setUADData(UAD.getSony(), Common.getSony(), UADActivity.this);
UAD.setUADData(UAD.getXiaomi(), Common.getXiaomi(), UADActivity.this);
UAD.setUADData(UAD.getZTE(), Common.getZTE(), UADActivity.this);
UAD.setUADData(UAD.getAOSP(), Common.getAOSP(), UADActivity.this);
UAD.setUADData(UAD.getGoogle(), Common.getGoogle(), UADActivity.this);
UAD.setUADData(UAD.getASUS(), Common.getAsus(), UADActivity.this);
UAD.setUADData(UAD.getOnePlus(), Common.getOnePlus(), UADActivity.this);
}
@Override
public void onPostExecute() {
mProgressBar.setVisibility(View.GONE);
mFrameLayout.setVisibility(View.VISIBLE);
getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container,
new UADFragment()).commit();
}
}.execute();
}
}

View file

@ -0,0 +1,123 @@
package com.sunilpaulmathew.debloater.adapters;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.content.Intent;
import android.graphics.Color;
import android.net.Uri;
import android.provider.Settings;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.LinearLayout;
import androidx.annotation.NonNull;
import androidx.appcompat.widget.AppCompatImageButton;
import androidx.recyclerview.widget.RecyclerView;
import com.google.android.material.textview.MaterialTextView;
import com.sunilpaulmathew.debloater.BuildConfig;
import com.sunilpaulmathew.debloater.R;
import com.sunilpaulmathew.debloater.activities.ChangeLogActivity;
import com.sunilpaulmathew.debloater.utils.Common;
import com.sunilpaulmathew.debloater.utils.UpdateCheck;
import com.sunilpaulmathew.debloater.utils.Utils;
import java.util.List;
import in.sunilpaulmathew.sCommon.CommonUtils.sCommonUtils;
import in.sunilpaulmathew.sCommon.CommonUtils.sSerializableItems;
import in.sunilpaulmathew.sCommon.Credits.sCreditsUtils;
import in.sunilpaulmathew.sCommon.ThemeUtils.sThemeUtils;
import in.sunilpaulmathew.sCommon.TranslatorUtils.sTranslatorUtils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on February 03, 2021
*/
public class AboutAdapter extends RecyclerView.Adapter<AboutAdapter.ViewHolder> {
private final List<sSerializableItems> data;
public AboutAdapter(List<sSerializableItems> data) {
this.data = data;
}
@NonNull
@Override
public AboutAdapter.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View rowItem = LayoutInflater.from(parent.getContext()).inflate(R.layout.recycle_view_about, parent, false);
return new AboutAdapter.ViewHolder(rowItem);
}
@SuppressLint("UseCompatLoadingForDrawables")
@Override
public void onBindViewHolder(@NonNull AboutAdapter.ViewHolder holder, int position) {
holder.Title.setText(this.data.get(position).getTextOne());
if (sThemeUtils.isDarkTheme(holder.Title.getContext())) {
holder.Title.setTextColor(Utils.getThemeAccentColor(holder.Title.getContext()));
} else if (position != 0 && !this.data.get(position).getTextOne().equals(holder.Title.getContext()
.getString(R.string.fdroid)) && !this.data.get(position).getTextTwo().equals(holder.Title
.getContext().getString(R.string.translations))) {
holder.mIcon.setColorFilter(Color.BLACK);
}
holder.Description.setText(this.data.get(position).getTextTwo());
holder.mIcon.setImageDrawable(this.data.get(position).getIcon());
holder.mRVLayout.setOnClickListener(v -> {
if (this.data.get(position).getTextThree() != null) {
sCommonUtils.launchUrl(this.data.get(position).getTextThree(), (Activity) holder.mRVLayout.getContext());
} else if (position == 0) {
Intent settings = new Intent(Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
settings.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
Uri uri = Uri.fromParts("package", BuildConfig.APPLICATION_ID, null);
settings.setData(uri);
holder.mRVLayout.getContext().startActivity(settings);
} else if (position == 4) {
Intent changeLog = new Intent(holder.mRVLayout.getContext(), ChangeLogActivity.class);
holder.mRVLayout.getContext().startActivity(changeLog);
} else if (position == 7) {
UpdateCheck.isManualUpdate(true);
new UpdateCheck().initialize(0, (Activity) holder.mRVLayout.getContext());
} else if (position == 8) {
new sTranslatorUtils(v.getContext().getString(R.string.app_name), "https://poeditor.com/join/project?hash=BZS89Ev3WG",
(Activity) v.getContext()).show();
} else if (position == 9) {
new sCreditsUtils(Common.getCredits(),
sCommonUtils.getDrawable(R.mipmap.ic_launcher, v.getContext()),
sCommonUtils.getDrawable(R.drawable.ic_back, v.getContext()),
holder.Title.getCurrentTextColor(), 20, v.getContext().getString(R.string.app_name),
"2020-2025, sunilpaulmathew", BuildConfig.VERSION_NAME)
.launchCredits(v.getContext());
} else if (position == 10) {
Intent shareapp = new Intent();
shareapp.setAction(Intent.ACTION_SEND);
shareapp.putExtra(Intent.EXTRA_SUBJECT, holder.mRVLayout.getContext().getString(R.string.app_name));
shareapp.putExtra(Intent.EXTRA_TEXT, holder.mRVLayout.getContext().getString(R.string.share_app_message, BuildConfig.VERSION_NAME) + Utils.getAppStoreURL(holder.mRVLayout.getContext()));
shareapp.setType("text/plain");
Intent shareIntent = Intent.createChooser(shareapp, null);
holder.mRVLayout.getContext().startActivity(shareIntent);
}
});
}
@Override
public int getItemCount() {
return this.data.size();
}
public static class ViewHolder extends RecyclerView.ViewHolder {
private final AppCompatImageButton mIcon;
private final MaterialTextView Title;
private final MaterialTextView Description;
private final LinearLayout mRVLayout;
public ViewHolder(View view) {
super(view);
this.mIcon = view.findViewById(R.id.icon);
this.Title = view.findViewById(R.id.title);
this.Description = view.findViewById(R.id.description);
this.mRVLayout = view.findViewById(R.id.rv_about);
}
}
}

View file

@ -0,0 +1,137 @@
package com.sunilpaulmathew.debloater.adapters;
import android.annotation.SuppressLint;
import android.content.Intent;
import android.graphics.Color;
import android.net.Uri;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.FrameLayout;
import androidx.annotation.NonNull;
import androidx.appcompat.widget.AppCompatImageButton;
import androidx.recyclerview.widget.RecyclerView;
import com.google.android.material.dialog.MaterialAlertDialogBuilder;
import com.google.android.material.textview.MaterialTextView;
import com.sunilpaulmathew.debloater.R;
import com.sunilpaulmathew.debloater.utils.Common;
import com.sunilpaulmathew.debloater.utils.PackageItem;
import com.sunilpaulmathew.debloater.utils.PackageTasks;
import com.sunilpaulmathew.debloater.utils.Utils;
import java.util.List;
import in.sunilpaulmathew.sCommon.CommonUtils.sCommonUtils;
import in.sunilpaulmathew.sCommon.ThemeUtils.sThemeUtils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on February 03, 2021
*/
public class ActivePackagesAdapter extends RecyclerView.Adapter<ActivePackagesAdapter.ViewHolder> {
private final List<PackageItem> data;
private final String searchText;
public ActivePackagesAdapter(List<PackageItem> data, String searchText) {
this.data = data;
this.searchText = searchText;
}
@NonNull
@Override
public ActivePackagesAdapter.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View rowItem = LayoutInflater.from(parent.getContext()).inflate(R.layout.recycle_view_layout, parent, false);
return new ActivePackagesAdapter.ViewHolder(rowItem);
}
@SuppressLint("UseCompatLoadingForDrawables")
@Override
public void onBindViewHolder(@NonNull ActivePackagesAdapter.ViewHolder holder, int position) {
try {
holder.mIcon.setImageDrawable(this.data.get(position).getAppIcon());
if (this.data.get(position).getPackageName() != null) {
holder.mPackageName.setText(this.data.get(position).getPackageName());
holder.mPackageName.setVisibility(View.VISIBLE);
holder.mPackageName.setTextColor(Color.RED);
} else {
holder.mPackageName.setVisibility(View.GONE);
}
holder.mPath.setText(this.data.get(position).getAPKPath());
if (searchText != null && Common.isTextMatched(this.data.get(position).getAppName(), searchText)) {
holder.mName.setText(Utils.fromHtml(this.data.get(position).getAppName().replace(searchText,
"<b><i><font color=\"" + Color.RED + "\">" + searchText + "</font></i></b>")));
} else {
holder.mName.setText(this.data.get(position).getAppName());
}
if (sThemeUtils.isDarkTheme(holder.mName.getContext())) {
holder.mName.setTextColor(Utils.getThemeAccentColor(holder.mName.getContext()));
}
if (Utils.exist(PackageTasks.getModulePath() + this.data.get(position).getAPKPath()) || Utils.exist(PackageTasks.getModulePath() + PackageTasks.getAdjAPKPath(this.data.get(position).getAPKPath()))) {
holder.actionMessage.setText(holder.actionLayout.getContext().getString(R.string.restore));
holder.mActionIcon.setImageDrawable(sCommonUtils.getDrawable(R.drawable.ic_restore, holder.actionLayout.getContext()));
holder.statusMessage.setTextColor(Color.RED);
holder.statusMessage.setVisibility(View.VISIBLE);
holder.actionMessage.setTextColor(Color.GREEN);
holder.mActionIcon.setColorFilter(Color.GREEN);
holder.statusMessage.setText(holder.actionLayout.getContext().getString(R.string.status_message_remove));
} else {
holder.actionMessage.setText(holder.actionLayout.getContext().getString(R.string.remove));
holder.mActionIcon.setImageDrawable(sCommonUtils.getDrawable(R.drawable.ic_delete, holder.actionLayout.getContext()));
holder.statusMessage.setTextColor(Color.GREEN);
holder.statusMessage.setVisibility(View.GONE);
holder.actionMessage.setTextColor(Color.RED);
holder.mActionIcon.setColorFilter(Color.RED);
holder.statusMessage.setText(null);
}
holder.actionLayout.setOnClickListener(v -> {
if (Utils.exist(PackageTasks.getModulePath() + this.data.get(position).getAPKPath()) || Utils.exist(PackageTasks.getModulePath() + PackageTasks.getAdjAPKPath(this.data.get(position).getAPKPath()))) {
PackageTasks.revertDelete(PackageTasks.getAdjAPKPath(this.data.get(position).getAPKPath()));
} else {
if (data.get(position).isUpdatedSystemApp()) {
new MaterialAlertDialogBuilder(v.getContext())
.setIcon(data.get(position).getAppIcon())
.setTitle(data.get(position).getAppName())
.setMessage(v.getContext().getString(R.string.updated_system_app_warning, data.get(position).getAppName()))
.setNegativeButton(R.string.cancel, (dialog, id) -> {
})
.setPositiveButton(R.string.uninstall, (dialog, id) -> {
Intent remove = new Intent(Intent.ACTION_DELETE);
remove.putExtra(Intent.EXTRA_RETURN_RESULT, true);
remove.setData(Uri.parse("package:" + data.get(position).getPackageName()));
v.getContext().startActivity(remove);
}).show();
}
PackageTasks.setToDelete(PackageTasks.getAdjAPKPath(this.data.get(position).getAPKPath()), holder.mName.getText().toString());
}
notifyItemChanged(position);
});
} catch (NullPointerException ignored) {}
}
@Override
public int getItemCount() {
return this.data.size();
}
public static class ViewHolder extends RecyclerView.ViewHolder {
private final AppCompatImageButton mActionIcon, mIcon;
private final MaterialTextView mName, mPackageName, mPath, actionMessage, statusMessage;
private final FrameLayout actionLayout;
public ViewHolder(View view) {
super(view);
this.mActionIcon = view.findViewById(R.id.action_icon);
this.mIcon = view.findViewById(R.id.icon);
this.mName = view.findViewById(R.id.title);
this.mPackageName = view.findViewById(R.id.packageName);
this.mPath = view.findViewById(R.id.description);
this.actionMessage = view.findViewById(R.id.action_message);
this.statusMessage = view.findViewById(R.id.status_message);
this.actionLayout = view.findViewById(R.id.action_layout);
}
}
}

View file

@ -0,0 +1,97 @@
package com.sunilpaulmathew.debloater.adapters;
import android.annotation.SuppressLint;
import android.graphics.Color;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.FrameLayout;
import androidx.annotation.NonNull;
import androidx.appcompat.widget.AppCompatImageButton;
import androidx.recyclerview.widget.RecyclerView;
import com.google.android.material.textview.MaterialTextView;
import com.sunilpaulmathew.debloater.R;
import com.sunilpaulmathew.debloater.utils.Common;
import com.sunilpaulmathew.debloater.utils.Utils;
import java.util.List;
import in.sunilpaulmathew.sCommon.CommonUtils.sCommonUtils;
import in.sunilpaulmathew.sCommon.ThemeUtils.sThemeUtils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on February 03, 2021
*/
public class InactivePackagesAdapter extends RecyclerView.Adapter<InactivePackagesAdapter.ViewHolder> {
private final List<String> data;
public InactivePackagesAdapter(List<String> data) {
this.data = data;
}
@NonNull
@Override
public InactivePackagesAdapter.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View rowItem = LayoutInflater.from(parent.getContext()).inflate(R.layout.recycle_view_layout, parent, false);
return new InactivePackagesAdapter.ViewHolder(rowItem);
}
@SuppressLint("UseCompatLoadingForDrawables")
@Override
public void onBindViewHolder(@NonNull InactivePackagesAdapter.ViewHolder holder, int position) {
holder.appName.setText(Utils.read(this.data.get(position)));
if (sThemeUtils.isDarkTheme(holder.appName.getContext())) {
holder.appName.setTextColor(Utils.getThemeAccentColor(holder.appName.getContext()));
}
holder.appID.setText(this.data.get(position).replace(Common.getModuleParent(),""));
holder.appIcon.setImageDrawable(sCommonUtils.getDrawable(R.drawable.ic_android, holder.appIcon.getContext()));
holder.appIcon.setColorFilter(Utils.exist(this.data.get(position)) ? Color.RED : Color.GREEN);
holder.statusMessage.setTextColor(Utils.exist(this.data.get(position)) ? Color.RED : Color.GREEN);
holder.actionMessage.setTextColor(Utils.exist(this.data.get(position)) ? Color.GREEN : Color.RED);
holder.actionIcon.setColorFilter(Utils.exist(this.data.get(position)) ? Color.GREEN : Color.RED);
holder.actionMessage.setText(Utils.exist(this.data.get(position)) ? holder.actionMessage.getContext().getString(R.string.restore) : holder.actionMessage.getContext().getString(R.string.remove));
holder.actionIcon.setImageDrawable(Utils.exist(this.data.get(position)) ? sCommonUtils.getDrawable(R.drawable.ic_restore,
holder.actionMessage.getContext()) : sCommonUtils.getDrawable(R.drawable.ic_delete, holder.actionMessage.getContext()));
holder.statusMessage.setText(Utils.exist(this.data.get(position)) ? null : holder.statusMessage.getContext().getString(R.string.status_message_restore));
holder.statusMessage.setVisibility(Utils.exist(this.data.get(position)) ? View.GONE : View.VISIBLE);
holder.actionLayout.setOnClickListener(v -> {
if (Utils.exist(this.data.get(position))) {
Utils.delete(this.data.get(position));
} else {
Utils.create(holder.appName.getText().toString(), this.data.get(position));
}
notifyItemChanged(position);
});
}
@Override
public int getItemCount() {
return this.data.size();
}
public static class ViewHolder extends RecyclerView.ViewHolder {
private final AppCompatImageButton actionIcon;
private final AppCompatImageButton appIcon;
private final MaterialTextView appName;
private final MaterialTextView appID;
private final MaterialTextView actionMessage;
private final MaterialTextView statusMessage;
private final FrameLayout actionLayout;
public ViewHolder(View view) {
super(view);
this.actionIcon = view.findViewById(R.id.action_icon);
this.appIcon = view.findViewById(R.id.icon);
this.appName = view.findViewById(R.id.title);
this.appID = view.findViewById(R.id.description);
this.actionMessage = view.findViewById(R.id.action_message);
this.statusMessage = view.findViewById(R.id.status_message);
this.actionLayout = view.findViewById(R.id.action_layout);
}
}
}

View file

@ -0,0 +1,81 @@
package com.sunilpaulmathew.debloater.fragments;
import android.annotation.SuppressLint;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import androidx.activity.OnBackPressedCallback;
import androidx.annotation.Nullable;
import androidx.fragment.app.Fragment;
import androidx.recyclerview.widget.GridLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import com.sunilpaulmathew.debloater.BuildConfig;
import com.sunilpaulmathew.debloater.R;
import com.sunilpaulmathew.debloater.adapters.AboutAdapter;
import com.sunilpaulmathew.debloater.utils.Utils;
import java.util.ArrayList;
import java.util.List;
import in.sunilpaulmathew.sCommon.CommonUtils.sCommonUtils;
import in.sunilpaulmathew.sCommon.CommonUtils.sSerializableItems;
import in.sunilpaulmathew.sCommon.PackageUtils.sPackageUtils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on October 28, 2020
*/
public class AboutFragment extends Fragment {
@SuppressLint("UseCompatLoadingForDrawables")
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View mRootView = inflater.inflate(R.layout.fragment_about, container, false);
RecyclerView mRecyclerView = mRootView.findViewById(R.id.recycler_view);
mRecyclerView.setLayoutManager(new GridLayoutManager(requireActivity(), Utils.getSpanCount(requireActivity())));
AboutAdapter mRecycleViewAdapter = new AboutAdapter(getData());
mRecyclerView.setAdapter(mRecycleViewAdapter);
mRecyclerView.setVisibility(View.VISIBLE);
requireActivity().getOnBackPressedDispatcher().addCallback(new OnBackPressedCallback(true) {
@Override
public void handleOnBackPressed() {
Utils.navigateToFragment(requireActivity());
}
});
return mRootView;
}
private List<sSerializableItems> getData() {
List <sSerializableItems> mData = new ArrayList<>();
mData.add(new sSerializableItems(sCommonUtils.getDrawable(R.mipmap.ic_launcher_round, requireActivity()), getString(R.string.version).replace(": %s",""), (sPackageUtils.isPackageInstalled(
"com.android.vending", requireActivity()) ? "Pro " : "") + BuildConfig.VERSION_NAME, null));
mData.add(new sSerializableItems(sCommonUtils.getDrawable(R.drawable.ic_support, requireActivity()), getString(R.string.support), getString(R.string.support_summary),"https://t.me/smartpack_kmanager"));
mData.add(new sSerializableItems(sCommonUtils.getDrawable(R.drawable.ic_github, requireActivity()), getString(R.string.source_code), getString(R.string.source_code_summary),"https://github.com/sunilpaulmathew/De-Bloater"));
mData.add(new sSerializableItems(sCommonUtils.getDrawable(R.drawable.ic_issue, requireActivity()), getString(R.string.report_issue), getString(R.string.report_issue_summary),"https://github.com/sunilpaulmathew/De-Bloater/issues/new"));
mData.add(new sSerializableItems(sCommonUtils.getDrawable(R.drawable.ic_active, requireActivity()), getString(R.string.change_logs), getString(R.string.change_logs_summary), null));
mData.add(new sSerializableItems(sCommonUtils.getDrawable(R.drawable.ic_playstore, requireActivity()), getString(R.string.more_apps), getString(R.string.more_apps_summary), "https://play.google.com/store/apps/dev?id=5836199813143882901"));
mData.add(new sSerializableItems(sCommonUtils.getDrawable(R.drawable.ic_licence, requireActivity()), getString(R.string.licence), getString(R.string.licence_summary), "https://www.gnu.org/licenses/gpl-3.0-standalone.html"));
if (sPackageUtils.isPackageInstalled("com.android.vending", requireActivity())) {
mData.add(new sSerializableItems(sCommonUtils.getDrawable(R.drawable.ic_rate, requireActivity()), getString(R.string.rate_us), getString(R.string.rate_us_Summary), "https://play.google.com/store/apps/details?id=com.sunilpaulmathew.debloater"));
} else if (sPackageUtils.isPackageInstalled("org.fdroid.fdroid", requireActivity())) {
mData.add(new sSerializableItems(sCommonUtils.getDrawable(R.drawable.ic_fdroid, requireActivity()), getString(R.string.fdroid), getString(R.string.fdroid_summary), "https://f-droid.org/packages/com.sunilpaulmathew.debloater"));
} else {
mData.add(new sSerializableItems(sCommonUtils.getDrawable(R.drawable.ic_update, requireActivity()),getString(R.string.check_update), getString(R.string.check_update_summary), null));
}
mData.add(new sSerializableItems(sCommonUtils.getDrawable(R.drawable.ic_translate, requireActivity()), getString(R.string.translations), getString(R.string.translations_summary), null));
mData.add(new sSerializableItems(sCommonUtils.getDrawable(R.drawable.ic_credits, requireActivity()), getString(R.string.credits), getString(R.string.credits_summary), null));
mData.add(new sSerializableItems(sCommonUtils.getDrawable(R.drawable.ic_share, requireActivity()), getString(R.string.invite_friend), getString(R.string.invite_friend_summary), null));
if (!sPackageUtils.isPackageInstalled("com.android.vending", requireActivity())) {
mData.add(new sSerializableItems(sCommonUtils.getDrawable(R.drawable.ic_donate, requireActivity()), getString(R.string.donate), getString(R.string.donate_summary), "https://smartpack.github.io/donation/"));
}
return mData;
}
}

View file

@ -0,0 +1,321 @@
package com.sunilpaulmathew.debloater.fragments;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.os.Handler;
import android.text.Editable;
import android.text.TextWatcher;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.SubMenu;
import android.view.View;
import android.view.ViewGroup;
import android.widget.LinearLayout;
import androidx.activity.OnBackPressedCallback;
import androidx.annotation.Nullable;
import androidx.appcompat.widget.AppCompatEditText;
import androidx.appcompat.widget.AppCompatImageButton;
import androidx.appcompat.widget.AppCompatTextView;
import androidx.appcompat.widget.PopupMenu;
import androidx.fragment.app.Fragment;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import com.google.android.material.card.MaterialCardView;
import com.google.android.material.dialog.MaterialAlertDialogBuilder;
import com.google.android.material.tabs.TabLayout;
import com.google.android.material.textview.MaterialTextView;
import com.sunilpaulmathew.debloater.R;
import com.sunilpaulmathew.debloater.activities.TomatotActivity;
import com.sunilpaulmathew.debloater.activities.UADActivity;
import com.sunilpaulmathew.debloater.adapters.ActivePackagesAdapter;
import com.sunilpaulmathew.debloater.utils.PackageTasks;
import com.sunilpaulmathew.debloater.utils.UpdateCheck;
import com.sunilpaulmathew.debloater.utils.Utils;
import java.util.Objects;
import in.sunilpaulmathew.sCommon.CommonUtils.sCommonUtils;
import in.sunilpaulmathew.sCommon.CommonUtils.sExecutor;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on October 28, 2020
*/
public class ActivePackagesFragment extends Fragment {
private AppCompatEditText mSearchWord;
private AppCompatImageButton mMenu;
private boolean mExit = false;
private final Handler mHandler = new Handler();
private LinearLayout mProgressLayout;
private MaterialCardView mReverse;
private RecyclerView mRecyclerView;
private ActivePackagesAdapter mRecycleViewAdapter;
private String mSearchText = null;
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View mRootView = inflater.inflate(R.layout.fragment_packages, container, false);
mSearchWord = mRootView.findViewById(R.id.search_word);
AppCompatImageButton mSearchButton = mRootView.findViewById(R.id.search_button);
AppCompatTextView mSummary = mRootView.findViewById(R.id.about_summary);
MaterialTextView mPageTitle = mRootView.findViewById(R.id.page_title);
mReverse = mRootView.findViewById(R.id.reverse_button);
mMenu = mRootView.findViewById(R.id.menu_button);
mProgressLayout = mRootView.findViewById(R.id.progress_layout);
mRecyclerView = mRootView.findViewById(R.id.recycler_view);
TabLayout mTabLayout = mRootView.findViewById(R.id.tab_layout);
mRecyclerView.setLayoutManager(new LinearLayoutManager(requireActivity()));
mPageTitle.setText(getString(R.string.apps, getString(R.string.active)));
mSummary.setText(getString(R.string.active_app_summary));
mReverse.setElevation(10);
mReverse.setOnClickListener(v -> {
sCommonUtils.saveBoolean("reverse_order", !sCommonUtils.getBoolean("reverse_order", false, requireActivity()), requireActivity());
loadUI(requireActivity(), mSearchText);
});
mSearchButton.setOnClickListener(v -> {
if (mSearchWord.getVisibility() == View.VISIBLE) {
if (mSearchText != null && !mSearchText.isEmpty()) {
mSearchText = null;
mSearchWord.setText(null);
}
mSummary.setVisibility(View.VISIBLE);
mSearchWord.setVisibility(View.GONE);
PackageTasks.toggleKeyboard(mSearchWord, 0, requireActivity());
} else {
mSummary.setVisibility(View.GONE);
mSearchWord.setVisibility(View.VISIBLE);
PackageTasks.toggleKeyboard(mSearchWord, 1, requireActivity());
}
});
mTabLayout.addTab(mTabLayout.newTab().setText(getString(R.string.apps_all)));
mTabLayout.addTab(mTabLayout.newTab().setText(getString(R.string.apps_system)));
mTabLayout.addTab(mTabLayout.newTab().setText(getString(R.string.apps_product)));
mTabLayout.addTab(mTabLayout.newTab().setText(getString(R.string.apps_vendor)));
mTabLayout.setVisibility(View.VISIBLE);
Objects.requireNonNull(mTabLayout.getTabAt(getTabPosition(requireActivity()))).select();
mTabLayout.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
@Override
public void onTabSelected(TabLayout.Tab tab) {
String mStatus = sCommonUtils.getString("appTypes", "all", requireActivity());
switch (tab.getPosition()) {
case 0:
if (!mStatus.equals("all")) {
sCommonUtils.saveString("appTypes", "all", requireActivity());
loadUI(requireActivity(), mSearchText);
}
break;
case 1:
if (!mStatus.equals("system")) {
sCommonUtils.saveString("appTypes", "system", requireActivity());
loadUI(requireActivity(), mSearchText);
}
break;
case 2:
if (!mStatus.equals("product")) {
sCommonUtils.saveString("appTypes", "product", requireActivity());
loadUI(requireActivity(), mSearchText);
}
break;
case 3:
if (!mStatus.equals("vendor")) {
sCommonUtils.saveString("appTypes", "vendor", requireActivity());
loadUI(requireActivity(), mSearchText);
}
break;
}
}
@Override
public void onTabUnselected(TabLayout.Tab tab) {
}
@Override
public void onTabReselected(TabLayout.Tab tab) {
}
});
mSearchWord.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
}
@Override
public void afterTextChanged(Editable s) {
loadUI(requireActivity(), s.toString().toLowerCase());
}
});
mMenu.setOnClickListener(v -> menuOptions(requireActivity()));
loadUI(requireActivity(), mSearchText);
if (UpdateCheck.isSignatureMatched(requireActivity()) && sCommonUtils.getInt("update_enabled", 2, requireActivity()) == 2) {
new MaterialAlertDialogBuilder(requireActivity())
.setIcon(R.mipmap.ic_launcher_round)
.setTitle("Please Note")
.setMessage("""
De-Bloater includes a built-in auto-update system that is active only when the app is installed via the GitHub release page or through IzzyOnDroid. Updates are fetched directly from the latest official release on GitHub.
You can choose to enable or disable this feature. This prompt will keep appearing until you make a decision.""")
.setCancelable(false)
.setNeutralButton("No, Thanks", (dialogInterface, i) ->
sCommonUtils.saveInt("update_enabled", 1, requireActivity()))
.setPositiveButton("Yes, Enable", (dialogInterface, i) ->
sCommonUtils.saveInt("update_enabled", 0, requireActivity()))
.show();
}
requireActivity().getOnBackPressedDispatcher().addCallback(new OnBackPressedCallback(true) {
@Override
public void handleOnBackPressed() {
if (mSearchWord.getVisibility() == View.VISIBLE) {
if (mSearchText != null) {
mSearchText = null;
mSearchWord.setText(null);
}
mSearchWord.setVisibility(View.GONE);
return;
}
if (mExit) {
mExit = false;
requireActivity().finish();
} else {
sCommonUtils.toast(getString(R.string.press_back_exit), requireActivity()).show();
mExit = true;
mHandler.postDelayed(() -> mExit = false, 2000);
}
}
});
return mRootView;
}
private int getTabPosition(Activity activity) {
String mStatus = sCommonUtils.getString("appTypes", "all", activity);
return switch (mStatus) {
case "vendor" -> 3;
case "product" -> 2;
case "system" -> 1;
default -> 0;
};
}
private void menuOptions(Activity activity) {
PopupMenu popupMenu = new PopupMenu(activity, mMenu);
Menu menu = popupMenu.getMenu();
if (PackageTasks.isModuleInitialized()) {
menu.add(Menu.NONE, 1, Menu.NONE, R.string.module_status_reset);
}
SubMenu sort = menu.addSubMenu(Menu.NONE, 0, Menu.NONE, getString(R.string.sort_by));
sort.add(0, 2, Menu.NONE, getString(R.string.name)).setCheckable(true)
.setChecked(sCommonUtils.getInt("sort_apps", 1, activity) == 0);
sort.add(0, 3, Menu.NONE, getString(R.string.package_id)).setCheckable(true)
.setChecked(sCommonUtils.getInt("sort_apps", 1, activity) == 1);
sort.setGroupCheckable(0, true, true);
SubMenu customScripts = menu.addSubMenu(Menu.NONE, 0, Menu.NONE, getString(R.string.custom_scripts));
customScripts.add(Menu.NONE, 4, Menu.NONE, R.string.custom_scripts_tomatot);
customScripts.add(Menu.NONE, 5, Menu.NONE, R.string.custom_scripts_uad);
menu.add(Menu.NONE, 6, Menu.NONE, R.string.reboot);
popupMenu.setOnMenuItemClickListener(item -> {
switch (item.getItemId()) {
case 0:
break;
case 1:
PackageTasks.removeModule(activity);
break;
case 2:
if (sCommonUtils.getInt("sort_apps", 1, activity) != 0) {
sCommonUtils.saveInt("sort_apps", 0, activity);
loadUI(activity, mSearchText);
}
break;
case 3:
if (sCommonUtils.getInt("sort_apps", 1, activity) != 1) {
sCommonUtils.saveInt("sort_apps", 1, activity);
loadUI(activity, mSearchText);
}
break;
case 4:
Intent tomatotScript = new Intent(activity, TomatotActivity.class);
startActivity(tomatotScript);
break;
case 5:
Intent uadScript = new Intent(activity, UADActivity.class);
startActivity(uadScript);
break;
case 6:
Utils.runCommand("svc power reboot");
break;
}
return false;
});
popupMenu.show();
}
private void loadUI(Activity activity, String searchText) {
new sExecutor() {
@Override
public void onPreExecute() {
mProgressLayout.setVisibility(View.VISIBLE);
mReverse.setVisibility(View.GONE);
mRecyclerView.setVisibility(View.GONE);
mRecyclerView.removeAllViews();
}
@Override
public void doInBackground() {
mRecycleViewAdapter = new ActivePackagesAdapter(PackageTasks.getActivePackageData(activity, searchText), searchText);
if (searchText != null) {
mSearchText = searchText;
}
}
@Override
public void onPostExecute() {
mRecyclerView.setAdapter(mRecycleViewAdapter);
mProgressLayout.setVisibility(View.GONE);
mRecyclerView.setVisibility(View.VISIBLE);
mReverse.setVisibility(View.VISIBLE);
}
}.execute();
}
@Override
public void onStart() {
super.onStart();
if (mSearchText != null) {
mSearchText = null;
mSearchWord.setText(null);
}
}
@Override
public void onDestroy() {
super.onDestroy();
if (mSearchText != null) {
mSearchText = null;
mSearchWord.setText(null);
}
}
}

View file

@ -0,0 +1,313 @@
package com.sunilpaulmathew.debloater.fragments;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.content.Intent;
import android.net.Uri;
import android.os.Build;
import android.os.Bundle;
import android.os.Environment;
import android.text.Editable;
import android.text.TextWatcher;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.View;
import android.view.ViewGroup;
import android.widget.LinearLayout;
import androidx.activity.OnBackPressedCallback;
import androidx.activity.result.ActivityResultLauncher;
import androidx.activity.result.contract.ActivityResultContracts;
import androidx.annotation.Nullable;
import androidx.appcompat.widget.AppCompatEditText;
import androidx.appcompat.widget.AppCompatImageButton;
import androidx.appcompat.widget.AppCompatTextView;
import androidx.appcompat.widget.PopupMenu;
import androidx.core.content.FileProvider;
import androidx.fragment.app.Fragment;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import com.google.android.material.dialog.MaterialAlertDialogBuilder;
import com.google.android.material.textview.MaterialTextView;
import com.sunilpaulmathew.debloater.BuildConfig;
import com.sunilpaulmathew.debloater.R;
import com.sunilpaulmathew.debloater.adapters.InactivePackagesAdapter;
import com.sunilpaulmathew.debloater.utils.EditTextInterface;
import com.sunilpaulmathew.debloater.utils.PackageTasks;
import com.sunilpaulmathew.debloater.utils.Restore;
import com.sunilpaulmathew.debloater.utils.Utils;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.File;
import in.sunilpaulmathew.rootfilepicker.utils.FilePicker;
import in.sunilpaulmathew.sCommon.CommonUtils.sCommonUtils;
import in.sunilpaulmathew.sCommon.CommonUtils.sExecutor;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on October 28, 2020
*/
public class InactivePackagesFragment extends Fragment {
private AppCompatEditText mSearchWord;
private AppCompatImageButton mMenu;
private LinearLayout mProgressLayout;
private MaterialTextView mProgressText;
private RecyclerView mRecyclerView;
private InactivePackagesAdapter mRecycleViewAdapter;
private String mSearchText = null;
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View mRootView = inflater.inflate(R.layout.fragment_packages, container, false);
mSearchWord = mRootView.findViewById(R.id.search_word);
AppCompatTextView mSummary = mRootView.findViewById(R.id.about_summary);
mProgressLayout = mRootView.findViewById(R.id.progress_layout);
mProgressText = mRootView.findViewById(R.id.progress_text);
mRecyclerView = mRootView.findViewById(R.id.recycler_view);
mRecyclerView = mRootView.findViewById(R.id.recycler_view);
mRecyclerView.setLayoutManager(new LinearLayoutManager(requireActivity()));
MaterialTextView mTitle = mRootView.findViewById(R.id.page_title);
AppCompatImageButton mSearchButton = mRootView.findViewById(R.id.search_button);
mMenu = mRootView.findViewById(R.id.menu_button);
mTitle.setText(getString(R.string.apps, getString(R.string.inactive)));
mSummary.setText(getString(R.string.inactive_apps_summary));
mMenu.setOnClickListener(v -> menuOptions(requireActivity()));
loadUI(mSearchText);
mSearchButton.setOnClickListener(v -> {
if (mSearchWord.getVisibility() == View.VISIBLE) {
if (mSearchText != null && !mSearchText.isEmpty()) {
mSearchText = null;
mSearchWord.setText(null);
}
mSummary.setVisibility(View.VISIBLE);
mSearchWord.setVisibility(View.GONE);
PackageTasks.toggleKeyboard(mSearchWord, 0, requireActivity());
} else {
mSummary.setVisibility(View.GONE);
mSearchWord.setVisibility(View.VISIBLE);
PackageTasks.toggleKeyboard(mSearchWord, 1, requireActivity());
}
});
mSearchWord.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
}
@Override
public void afterTextChanged(Editable s) {
loadUI(s.toString().toLowerCase());
}
});
requireActivity().getOnBackPressedDispatcher().addCallback(new OnBackPressedCallback(true) {
@Override
public void handleOnBackPressed() {
if (mSearchWord.getVisibility() == View.VISIBLE) {
if (mSearchText != null) {
mSearchText = null;
mSearchWord.setText(null);
}
mSummary.setVisibility(View.VISIBLE);
mSearchWord.setVisibility(View.GONE);
return;
}
Utils.navigateToFragment(requireActivity());
}
});
return mRootView;
}
private void menuOptions(Activity activity) {
PopupMenu popupMenu = new PopupMenu(activity, mMenu);
Menu menu = popupMenu.getMenu();
if (PackageTasks.isModuleInitialized()) {
menu.add(Menu.NONE, 0, Menu.NONE, R.string.module_status_reset);
}
menu.add(Menu.NONE, 1, Menu.NONE, R.string.reboot);
menu.add(Menu.NONE, 2, Menu.NONE, R.string.backup);
menu.add(Menu.NONE, 3, Menu.NONE, R.string.restore);
popupMenu.setOnMenuItemClickListener(item -> {
switch (item.getItemId()) {
case 0:
PackageTasks.removeModule(activity);
loadUI(mSearchText);
break;
case 1:
Utils.runCommand("svc power reboot");
break;
case 2:
if (!PackageTasks.getInactivePackageData(null).isEmpty()) {
new EditTextInterface(Build.MODEL.replace(" ","_")
.replace("(","_").replace(")","_") + "_" +
Build.VERSION.SDK_INT, getString(R.string.backup_list_as), activity) {
@SuppressLint("StringFormatInvalid")
@Override
public void positiveButtonLister(Editable editable) {
String name = editable.toString().trim().replace(" ","_")
.replace("(","_").replace(")","_");
if (!name.endsWith(".json")) {
name = name + ".json";
}
File jsonFile = new File(PackageTasks.getStoragePath(), name);
try {
JSONObject obj = new JSONObject();
JSONObject device = new JSONObject();
JSONArray DeBloater = new JSONArray();
device.put("Manufacturer", Build.MANUFACTURER);
device.put("Brand", Build.BRAND);
device.put("Model", Build.MODEL);
device.put("Version", Build.VERSION.RELEASE);
device.put("SDK", Build.VERSION.SDK_INT);
obj.put("Device", device);
for (String s : PackageTasks.getInactivePackageData(null)) {
JSONObject app = new JSONObject();
app.put("name", Utils.read(s));
app.put("path", s);
DeBloater.put(app);
obj.put("DeBloater", DeBloater);
}
Utils.create(obj.toString(), jsonFile.getAbsolutePath());
new MaterialAlertDialogBuilder(requireActivity())
.setIcon(R.mipmap.ic_launcher)
.setTitle(R.string.app_name)
.setMessage(getString(R.string.backup_message, jsonFile.getAbsolutePath()) + "\n\n" + getString(R.string.backup_share_message))
.setNegativeButton(getString(R.string.cancel), (dialogInterface, i) -> {
})
.setPositiveButton(getString(R.string.share_profile), (dialogInterface, i) -> {
Uri uriFile = FileProvider.getUriForFile(activity,
BuildConfig.APPLICATION_ID + ".provider", jsonFile);
Intent share = new Intent(Intent.ACTION_SEND);
share.setType("*/*");
share.putExtra(Intent.EXTRA_SUBJECT, getString(R.string.app_name));
share.putExtra(Intent.EXTRA_TEXT, "De-Bloater profile for " + Build.MODEL + " (SDK: " + Build.VERSION.SDK_INT + ").");
share.putExtra(Intent.EXTRA_STREAM, uriFile);
share.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);
Intent shareIntent = Intent.createChooser(share, null);
startActivity(shareIntent);
}).show();
} catch (JSONException ignored) {
}
}
}.show();
} else {
sCommonUtils.snackBar(mRecyclerView, getString(R.string.backup_list_empty)).show();
}
break;
case 3:
FilePicker filePicker = new FilePicker(restoreResultLauncher, requireActivity());
filePicker.setPath(Environment.getExternalStorageDirectory().toString());
filePicker.setExtension("json");
filePicker.launch();
break;
}
return false;
});
popupMenu.show();
}
private void loadUI(String searchText) {
new sExecutor() {
@Override
public void onPreExecute() {
mProgressLayout.setVisibility(View.VISIBLE);
mRecyclerView.setVisibility(View.GONE);
mRecyclerView.removeAllViews();
}
@Override
public void doInBackground() {
mRecycleViewAdapter = new InactivePackagesAdapter(PackageTasks.getInactivePackageData(searchText));
if (searchText != null) {
mSearchText = searchText;
}
}
@Override
public void onPostExecute() {
mRecyclerView.setAdapter(mRecycleViewAdapter);
mProgressLayout.setVisibility(View.GONE);
mRecyclerView.setVisibility(View.VISIBLE);
}
}.execute();
}
@SuppressLint("StringFormatInvalid")
private final ActivityResultLauncher<Intent> restoreResultLauncher = registerForActivityResult(
new ActivityResultContracts.StartActivityForResult(),
result -> {
if (result.getResultCode() == Activity.RESULT_OK && result.getData() != null) {
File mSelectedFile = FilePicker.getSelectedFile();
if (!Restore.isValidBackup(mSelectedFile.getAbsolutePath())) {
sCommonUtils.snackBar(mRecyclerView, getString(R.string.restore_error_message)).show();
return;
}
new MaterialAlertDialogBuilder(requireActivity())
.setMessage(Restore.isJSONMatched(mSelectedFile.getAbsolutePath()) ? getString(R.string.restore_question,
mSelectedFile.getName()) : getString(R.string.restore_mismatch_message))
.setNegativeButton(getString(R.string.cancel), (dialogInterface, i) -> {
})
.setPositiveButton(getString(R.string.restore), (dialogInterface, i) ->
new sExecutor() {
@Override
public void onPreExecute() {
mProgressLayout.setVisibility(View.VISIBLE);
mProgressText.setText(getString(R.string.restoring));
}
@Override
public void doInBackground() {
Restore.restoreBackup(mSelectedFile.getAbsolutePath());
}
@Override
public void onPostExecute() {
mProgressLayout.setVisibility(View.GONE);
loadUI(mSearchText);
}
}.execute())
.show();
}
}
);
@Override
public void onStart() {
super.onStart();
if (mSearchText != null) {
mSearchText = null;
mSearchWord.setText(null);
}
}
@Override
public void onDestroy() {
super.onDestroy();
if (mSearchText != null) {
mSearchText = null;
mSearchWord.setText(null);
}
}
}

View file

@ -0,0 +1,209 @@
package com.sunilpaulmathew.debloater.fragments;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.FrameLayout;
import android.widget.LinearLayout;
import androidx.annotation.Nullable;
import androidx.appcompat.widget.AppCompatImageButton;
import androidx.fragment.app.Fragment;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import com.google.android.material.card.MaterialCardView;
import com.google.android.material.dialog.MaterialAlertDialogBuilder;
import com.google.android.material.textview.MaterialTextView;
import com.sunilpaulmathew.debloater.R;
import com.sunilpaulmathew.debloater.adapters.ActivePackagesAdapter;
import com.sunilpaulmathew.debloater.utils.Common;
import com.sunilpaulmathew.debloater.utils.Tomatot;
import com.sunilpaulmathew.debloater.utils.Utils;
import in.sunilpaulmathew.sCommon.CommonUtils.sCommonUtils;
import in.sunilpaulmathew.sCommon.CommonUtils.sExecutor;
import in.sunilpaulmathew.sCommon.ThemeUtils.sThemeUtils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on November 4, 2020
*/
public class TomatotDebloaterFragment extends Fragment {
private boolean mExtremeT = false, mInvisibleT = false, mLightT = false;
private MaterialCardView mAppListCard;
private LinearLayout mProgressLayout;
private RecyclerView mRecyclerView;
private ActivePackagesAdapter mRecycleViewAdapter;
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View mRootView = inflater.inflate(R.layout.fragment_tomatot_debloater, container, false);
AppCompatImageButton mActionIcon = mRootView.findViewById(R.id.action_icon);
mProgressLayout = mRootView.findViewById(R.id.progress_layout);
LinearLayout mTitleLayout = mRootView.findViewById(R.id.title_layout);
MaterialTextView mInvisible = mRootView.findViewById(R.id.invisible);
MaterialTextView mLight = mRootView.findViewById(R.id.light);
MaterialTextView mExtreme = mRootView.findViewById(R.id.extreme);
MaterialTextView mStatus = mRootView.findViewById(R.id.deblaoter_status);
MaterialTextView mActionMessage = mRootView.findViewById(R.id.action_message);
mRecyclerView = mRootView.findViewById(R.id.recycler_view);
mRecyclerView.setLayoutManager(new LinearLayoutManager(requireActivity()));
MaterialTextView mAppsListTitle = mRootView.findViewById(R.id.apps_list_title);
mAppListCard = mRootView.findViewById(R.id.apps_list_card);
FrameLayout mActionLayout = mRootView.findViewById(R.id.action_layout);
if (sThemeUtils.isDarkTheme(requireActivity())) {
mActionMessage.setTextColor(Utils.getThemeAccentColor(requireActivity()));
mActionIcon.setColorFilter(Utils.getThemeAccentColor(requireActivity()));
mAppsListTitle.setTextColor(Utils.getThemeAccentColor(requireActivity()));
}
if (Tomatot.isScriptEnabled("tomatot_extreme", requireActivity())) {
mInvisible.setTextColor(Utils.getPrimaryTextColor(requireActivity()));
mLight.setTextColor(Utils.getPrimaryTextColor(requireActivity()));
mExtreme.setTextColor(Utils.getThemeAccentColor(requireActivity()));
mStatus.setText(R.string.custom_scripts_uad_enabled);
mActionMessage.setText(R.string.restore);
mExtremeT = true;
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getTExtreme(), null);
mRecyclerView.setAdapter(mRecycleViewAdapter);
mAppListCard.setVisibility(View.VISIBLE);
} else if (Tomatot.isScriptEnabled("tomatot_light", requireActivity())) {
mInvisible.setTextColor(Utils.getPrimaryTextColor(requireActivity()));
mLight.setTextColor(Utils.getThemeAccentColor(requireActivity()));
mExtreme.setTextColor(Utils.getPrimaryTextColor(requireActivity()));
mStatus.setText(R.string.custom_scripts_uad_enabled);
mActionMessage.setText(R.string.restore);
mLightT = true;
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getTLight(), null);
mRecyclerView.setAdapter(mRecycleViewAdapter);
mAppListCard.setVisibility(View.VISIBLE);
} else {
mInvisible.setTextColor(Utils.getThemeAccentColor(requireActivity()));
mLight.setTextColor(Utils.getPrimaryTextColor(requireActivity()));
mExtreme.setTextColor(Utils.getPrimaryTextColor(requireActivity()));
mStatus.setText(sCommonUtils.getBoolean("tomatot_invisible", false, requireActivity()) ?
R.string.custom_scripts_uad_enabled : R.string.custom_scripts_tomatot_invisible);
mActionMessage.setText(sCommonUtils.getBoolean("tomatot_invisible", false, requireActivity()) ?
R.string.restore : R.string.apply);
mInvisibleT = true;
mRecycleViewAdapter = new ActivePackagesAdapter(Common.geTInvisible(), null);
mRecyclerView.setAdapter(mRecycleViewAdapter);
mAppListCard.setVisibility(View.VISIBLE);
}
mTitleLayout.setOnClickListener(v -> sCommonUtils.launchUrl("https://forum.xda-developers.com" +
"/oneplus-6/oneplus-6--6t-cross-device-development/tool-tomatot-debloater-basic-script-to-t3869427",
requireActivity()));
mInvisible.setOnClickListener(v -> {
mExtremeT = false;
mInvisibleT = true;
mLightT = false;
mInvisible.setTextColor(Utils.getThemeAccentColor(requireActivity()));
mLight.setTextColor(Utils.getPrimaryTextColor(requireActivity()));
mExtreme.setTextColor(Utils.getPrimaryTextColor(requireActivity()));
mStatus.setText(sCommonUtils.getBoolean("tomatot_invisible", false, requireActivity()) ?
R.string.custom_scripts_uad_enabled : R.string.custom_scripts_tomatot_invisible);
mActionMessage.setText(sCommonUtils.getBoolean("tomatot_invisible", false, requireActivity()) ?
R.string.restore : R.string.apply);
mRecycleViewAdapter = new ActivePackagesAdapter(Common.geTInvisible(), null);
mRecyclerView.setAdapter(mRecycleViewAdapter);
});
mLight.setOnClickListener(v -> {
mExtremeT = false;
mInvisibleT = false;
mLightT = true;
mInvisible.setTextColor(Utils.getPrimaryTextColor(requireActivity()));
mLight.setTextColor(Utils.getThemeAccentColor(requireActivity()));
mExtreme.setTextColor(Utils.getPrimaryTextColor(requireActivity()));
mStatus.setText(sCommonUtils.getBoolean("tomatot_light", false, requireActivity()) ?
R.string.custom_scripts_uad_enabled : R.string.custom_scripts_tomatot_light);
mActionMessage.setText(sCommonUtils.getBoolean("tomatot_light", false, requireActivity()) ?
R.string.restore : R.string.apply);
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getTLight(), null);
mRecyclerView.setAdapter(mRecycleViewAdapter);
});
mExtreme.setOnClickListener(v -> {
mExtremeT = true;
mInvisibleT = false;
mLightT = false;
mInvisible.setTextColor(Utils.getPrimaryTextColor(requireActivity()));
mLight.setTextColor(Utils.getPrimaryTextColor(requireActivity()));
mExtreme.setTextColor(Utils.getThemeAccentColor(requireActivity()));
mStatus.setText(sCommonUtils.getBoolean("tomatot_extreme", false, requireActivity()) ?
R.string.custom_scripts_uad_enabled : R.string.custom_scripts_tomatot_extreme);
mActionMessage.setText(sCommonUtils.getBoolean("tomatot_extreme", false, requireActivity()) ?
R.string.restore : R.string.apply);
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getTExtreme(), null);
mRecyclerView.setAdapter(mRecycleViewAdapter);
});
mActionLayout.setOnClickListener(v ->
new sExecutor() {
@Override
public void onPreExecute() {
mProgressLayout.setVisibility(View.VISIBLE);
mAppListCard.setVisibility(View.GONE);
}
@Override
public void doInBackground() {
if (mExtremeT) {
if (sCommonUtils.getBoolean("tomatot_extreme", false, requireActivity())) {
Tomatot.disable("tomatot_extreme", Common.getTExtreme(), requireActivity());
} else {
if (Tomatot.isScriptEnabled("tomatot_invisible", requireActivity())) {
Tomatot.disable("tomatot_invisible", Common.geTInvisible(), requireActivity());
}
if (Tomatot.isScriptEnabled("tomatot_light", requireActivity())) {
Tomatot.disable("tomatot_light", Common.getTLight(), requireActivity());
}
Tomatot.enable("tomatot_extreme", Common.getTExtreme(), requireActivity());
}
} else if (mInvisibleT) {
if (sCommonUtils.getBoolean("tomatot_invisible", false, requireActivity())) {
Tomatot.disable("tomatot_invisible", Common.geTInvisible(), requireActivity());
} else {
if (Tomatot.isScriptEnabled("tomatot_light", requireActivity())) {
Tomatot.disable("tomatot_light", Common.getTLight(), requireActivity());
}
if (Tomatot.isScriptEnabled("tomatot_extreme", requireActivity())) {
Tomatot.disable("tomatot_extreme", Common.getTExtreme(), requireActivity());
}
Tomatot.enable("tomatot_invisible", Common.geTInvisible(), requireActivity());
}
} else if (mLightT) {
if (sCommonUtils.getBoolean("tomatot_light", false, requireActivity())) {
Tomatot.disable("tomatot_light", Common.getTLight(), requireActivity());
} else {
if (Tomatot.isScriptEnabled("tomatot_invisible", requireActivity())) {
Tomatot.disable("tomatot_invisible", Common.geTInvisible(), requireActivity());
}
if (Tomatot.isScriptEnabled("tomatot_extreme", requireActivity())) {
Tomatot.disable("tomatot_extreme", Common.getTExtreme(), requireActivity());
}
Tomatot.enable("tomatot_light", Common.getTLight(), requireActivity());
}
}
}
@Override
public void onPostExecute() {
mProgressLayout.setVisibility(View.GONE);
new MaterialAlertDialogBuilder(requireActivity())
.setMessage(R.string.custom_scripts_applied_message)
.setCancelable(false)
.setPositiveButton(getString(R.string.cancel), (dialog, id) -> requireActivity().finish()).show();
}
}.execute()
);
return mRootView;
}
}

View file

@ -0,0 +1,331 @@
package com.sunilpaulmathew.debloater.fragments;
import android.app.Activity;
import android.os.Build;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.View;
import android.view.ViewGroup;
import android.widget.FrameLayout;
import android.widget.LinearLayout;
import androidx.annotation.Nullable;
import androidx.appcompat.widget.AppCompatImageButton;
import androidx.appcompat.widget.PopupMenu;
import androidx.fragment.app.Fragment;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import com.google.android.material.card.MaterialCardView;
import com.google.android.material.dialog.MaterialAlertDialogBuilder;
import com.google.android.material.textview.MaterialTextView;
import com.sunilpaulmathew.debloater.R;
import com.sunilpaulmathew.debloater.adapters.ActivePackagesAdapter;
import com.sunilpaulmathew.debloater.utils.Common;
import com.sunilpaulmathew.debloater.utils.PackageTasks;
import com.sunilpaulmathew.debloater.utils.UAD;
import com.sunilpaulmathew.debloater.utils.Utils;
import in.sunilpaulmathew.sCommon.CommonUtils.sCommonUtils;
import in.sunilpaulmathew.sCommon.CommonUtils.sExecutor;
import in.sunilpaulmathew.sCommon.ThemeUtils.sThemeUtils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on January 26, 2021
*/
public class UADFragment extends Fragment {
private AppCompatImageButton mSelectIcon;
private MaterialCardView mAppListCard;
private MaterialTextView mActionMessage, mScriptTitle, mScriptStatus;
private LinearLayout mProgressLayout;
private RecyclerView mRecyclerView;
private ActivePackagesAdapter mRecycleViewAdapter;
private String mScriptPath;
private String mTitle;
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View mRootView = inflater.inflate(R.layout.fragment_uad, container, false);
AppCompatImageButton mActionIcon = mRootView.findViewById(R.id.action_icon);
mSelectIcon = mRootView.findViewById(R.id.select_icon);
FrameLayout mActionLayout = mRootView.findViewById(R.id.action_layout);
mProgressLayout = mRootView.findViewById(R.id.progress_layout);
LinearLayout mTitleLayout = mRootView.findViewById(R.id.title_layout);
mAppListCard = mRootView.findViewById(R.id.apps_list_card);
mActionMessage = mRootView.findViewById(R.id.action_message);
MaterialTextView mAppsListTitle = mRootView.findViewById(R.id.apps_list_title);
mScriptTitle = mRootView.findViewById(R.id.script_title);
mScriptStatus = mRootView.findViewById(R.id.deblaoter_status);
mRecyclerView = mRootView.findViewById(R.id.recycler_view);
mRecyclerView.setLayoutManager(new LinearLayoutManager(requireActivity()));
if (sThemeUtils.isDarkTheme(requireActivity())) {
mActionMessage.setTextColor(Utils.getThemeAccentColor(requireActivity()));
mActionIcon.setColorFilter(Utils.getThemeAccentColor(requireActivity()));
mAppsListTitle.setTextColor(Utils.getThemeAccentColor(requireActivity()));
mScriptTitle.setTextColor(Utils.getThemeAccentColor(requireActivity()));
}
if (Build.BRAND.equalsIgnoreCase("oneplus")) {
mScriptPath = PackageTasks.getModulePath() + "/uad_oneplus";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getOnePlus(), null);
mTitle = getString(R.string.oneplus);
} else if (Build.BRAND.equalsIgnoreCase("asus")) {
mScriptPath = PackageTasks.getModulePath() + "/uad_asus";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getAsus(), null);
mTitle = getString(R.string.asus);
} else if (Build.BRAND.equalsIgnoreCase("motorola")) {
mScriptPath = PackageTasks.getModulePath() + "/uad_motorola";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getMoto(), null);
mTitle = getString(R.string.motorola);
} else if (Build.BRAND.equalsIgnoreCase("huawei")) {
mScriptPath = PackageTasks.getModulePath() + "/uad_huawei";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getHuawei(), null);
mTitle = getString(R.string.huawei);
} else if (Build.BRAND.equalsIgnoreCase("lg")) {
mScriptPath = PackageTasks.getModulePath() + "/uad_lg";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getLG(), null);
mTitle = getString(R.string.lg);
} else if (Build.BRAND.equalsIgnoreCase("samsung")) {
mScriptPath = PackageTasks.getModulePath() + "/uad_samsung";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getSamsung(), null);
mTitle = getString(R.string.samsung);
} else if (Build.BRAND.equalsIgnoreCase("nokia")) {
mScriptPath = PackageTasks.getModulePath() + "/uad_nokia";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getNokia(), null);
mTitle = getString(R.string.nokia);
} else if (Build.BRAND.equalsIgnoreCase("oppo")) {
mScriptPath = PackageTasks.getModulePath() + "/uad_oppo";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getOppo(), null);
mTitle = getString(R.string.oppo);
} else if (Build.BRAND.equalsIgnoreCase("sony")) {
mScriptPath = PackageTasks.getModulePath() + "/uad_sony";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getSony(), null);
mTitle = getString(R.string.sony);
} else if (Build.BRAND.equalsIgnoreCase("xiaomi")) {
mScriptPath = PackageTasks.getModulePath() + "/uad_xiaomi";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getXiaomi(), null);
mTitle = getString(R.string.xiaomi);
} else if (Build.BRAND.equalsIgnoreCase("zte")) {
mScriptPath = PackageTasks.getModulePath() + "/uad_zte";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getZTE(), null);
mTitle = getString(R.string.zte);
} else {
mScriptPath = PackageTasks.getModulePath() + "/uad_google";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getGoogle(), null);
mTitle = getString(R.string.google);
}
setStatus();
mTitleLayout.setOnClickListener(v -> sCommonUtils.launchUrl( "https://gitlab.com/W1nst0n/universal-android-debloater",
requireActivity()));
mActionLayout.setOnClickListener(v ->
new sExecutor() {
@Override
public void onPreExecute() {
mProgressLayout.setVisibility(View.VISIBLE);
mAppListCard.setVisibility(View.GONE);
}
@Override
public void doInBackground() {
UAD.applyScript(mScriptPath, requireActivity());
}
@Override
public void onPostExecute() {
mProgressLayout.setVisibility(View.GONE);
new MaterialAlertDialogBuilder(requireActivity())
.setMessage(R.string.custom_scripts_applied_message)
.setCancelable(false)
.setPositiveButton(getString(R.string.cancel), (dialog, id) -> requireActivity().finish()).show();
}
}.execute()
);
mSelectIcon.setOnClickListener(v -> selectionMenu(requireActivity()));
return mRootView;
}
private void selectionMenu(Activity activity) {
PopupMenu popupMenu = new PopupMenu(requireActivity(), mSelectIcon);
Menu menu = popupMenu.getMenu();
if (!Common.getAOSP().isEmpty() || Utils.exist("uad_aosp")) {
menu.add(Menu.NONE, 0, Menu.NONE, R.string.aosp);
}
if (!Common.getGoogle().isEmpty() || Utils.exist("uad_google")) {
menu.add(Menu.NONE, 1, Menu.NONE, R.string.google);
}
if (!Common.getOnePlus().isEmpty() || Utils.exist("uad_oneplus")) {
menu.add(Menu.NONE, 2, Menu.NONE, R.string.oneplus);
}
if (!Common.getAsus().isEmpty() || Utils.exist("uad_asus")) {
menu.add(Menu.NONE, 3, Menu.NONE, R.string.asus);
}
if (!Common.getHuawei().isEmpty() || Utils.exist("uad_huawei")) {
menu.add(Menu.NONE, 4, Menu.NONE, R.string.huawei);
}
if (!Common.getLG().isEmpty() || Utils.exist("uad_lg")) {
menu.add(Menu.NONE, 5, Menu.NONE, R.string.lg);
}
if (!Common.getSamsung().isEmpty() || Utils.exist("uad_samsung")) {
menu.add(Menu.NONE, 6, Menu.NONE, R.string.samsung);
}
if (!Common.getMoto().isEmpty() || Utils.exist("uad_motorola")) {
menu.add(Menu.NONE, 7, Menu.NONE, R.string.motorola);
}
if (!Common.getNokia().isEmpty() || Utils.exist("uad_nokia")) {
menu.add(Menu.NONE, 8, Menu.NONE, R.string.nokia);
}
if (!Common.getOppo().isEmpty() || Utils.exist("uad_oppo")) {
menu.add(Menu.NONE, 9, Menu.NONE, R.string.oppo);
}
if (!Common.getSony().isEmpty() || Utils.exist("uad_sony")) {
menu.add(Menu.NONE, 10, Menu.NONE, R.string.sony);
}
if (!Common.getXiaomi().isEmpty() || Utils.exist("uad_xiaomi")) {
menu.add(Menu.NONE, 11, Menu.NONE, R.string.xiaomi);
}
if (!Common.getZTE().isEmpty() || Utils.exist("uad_zte")) {
menu.add(Menu.NONE, 12, Menu.NONE, R.string.zte);
}
if (!Common.getCarrier().isEmpty() || Utils.exist("uad_carrier")) {
menu.add(Menu.NONE, 13, Menu.NONE, R.string.carrier);
}
if (!Common.getMisc().isEmpty() || Utils.exist("uad_misc")) {
menu.add(Menu.NONE, 14, Menu.NONE, R.string.miscellaneous);
}
popupMenu.setOnMenuItemClickListener(item -> {
switch (item.getItemId()) {
case 0:
sCommonUtils.saveString("setDefault", "aosp", activity);
mScriptPath = PackageTasks.getModulePath() + "/uad_aosp";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getAOSP(), null);
mTitle = getString(R.string.aosp);
setStatus();
break;
case 1:
sCommonUtils.saveString("setDefault", "google", activity);
mScriptPath = PackageTasks.getModulePath() + "/uad_google";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getGoogle(), null);
mTitle = getString(R.string.google);
setStatus();
break;
case 2:
sCommonUtils.saveString("setDefault", "oneplus", activity);
mScriptPath = PackageTasks.getModulePath() + "/uad_oneplus";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getOnePlus(), null);
mTitle = getString(R.string.oneplus);
setStatus();
break;
case 3:
sCommonUtils.saveString("setDefault", "asus", activity);
mScriptPath = PackageTasks.getModulePath() + "/uad_aosp";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getAsus(), null);
mTitle = getString(R.string.asus);
setStatus();
break;
case 4:
sCommonUtils.saveString("setDefault", "huawei", activity);
mScriptPath = PackageTasks.getModulePath() + "/uad_huawei";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getHuawei(), null);
mTitle = getString(R.string.huawei);
setStatus();
break;
case 5:
sCommonUtils.saveString("setDefault", "lg", activity);
mScriptPath = PackageTasks.getModulePath() + "/uad_lg";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getLG(), null);
mTitle = getString(R.string.lg);
setStatus();
break;
case 6:
sCommonUtils.saveString("setDefault", "samsung", activity);
mScriptPath = PackageTasks.getModulePath() + "/uad_samsung";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getSamsung(), null);
mTitle = getString(R.string.samsung);
setStatus();
break;
case 7:
sCommonUtils.saveString("setDefault", "motorola", activity);
mScriptPath = PackageTasks.getModulePath() + "/uad_motorola";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getMoto(), null);
mTitle = getString(R.string.motorola);
setStatus();
break;
case 8:
sCommonUtils.saveString("setDefault", "nokia", activity);
mScriptPath = PackageTasks.getModulePath() + "/uad_nokia";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getNokia(), null);
mTitle = getString(R.string.nokia);
setStatus();
break;
case 9:
sCommonUtils.saveString("setDefault", "oppo", activity);
mScriptPath = PackageTasks.getModulePath() + "/uad_oppo";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getOppo(), null);
mTitle = getString(R.string.oppo);
setStatus();
break;
case 10:
sCommonUtils.saveString("setDefault", "sony", activity);
mScriptPath = PackageTasks.getModulePath() + "/uad_sony";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getSony(), null);
mTitle = getString(R.string.sony);
setStatus();
break;
case 11:
sCommonUtils.saveString("setDefault", "xiaomi", activity);
mScriptPath = PackageTasks.getModulePath() + "/uad_xiaomi";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getXiaomi(), null);
mTitle = getString(R.string.xiaomi);
setStatus();
break;
case 12:
sCommonUtils.saveString("setDefault", "zte", activity);
mScriptPath = PackageTasks.getModulePath() + "/uad_zte";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getZTE(), null);
mTitle = getString(R.string.zte);
setStatus();
break;
case 13:
sCommonUtils.saveString("setDefault", "carrier", activity);
mScriptPath = PackageTasks.getModulePath() + "/uad_carrier";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getCarrier(), null);
mTitle = getString(R.string.carrier);
setStatus();
break;
case 14:
sCommonUtils.saveString("setDefault", "misc", activity);
mScriptPath = PackageTasks.getModulePath() + "/uad_misc";
mRecycleViewAdapter = new ActivePackagesAdapter(Common.getMisc(), null);
mTitle = getString(R.string.miscellaneous);
setStatus();
break;
}
return false;
});
popupMenu.show();
}
private void setStatus() {
if (Utils.exist(mScriptPath)) {
mScriptStatus.setText(getString(R.string.custom_scripts_uad_enabled));
} else {
mScriptStatus.setText(getString(R.string.custom_scripts_uad_disabled));
}
mActionMessage.setText(Utils.exist(mScriptPath) ? getString(R.string.restore) : getString(R.string.apply));
mScriptTitle.setText(mTitle);
mRecyclerView.setAdapter(mRecycleViewAdapter);
}
}

View file

@ -0,0 +1,157 @@
package com.sunilpaulmathew.debloater.utils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on June 10, 2021
*/
import android.content.Context;
import java.util.ArrayList;
import java.util.List;
import in.sunilpaulmathew.sCommon.CommonUtils.sSerializableItems;
public class Common {
private static List<PackageItem> mRawData;
private static final List<PackageItem> mAOSP = new ArrayList<>(), mAsus = new ArrayList<>(),
mCarrier = new ArrayList<>(), mGoogle = new ArrayList<>(), mHuawei = new ArrayList<>(),
mLG = new ArrayList<>(), mSamsung = new ArrayList<>(), mMisc = new ArrayList<>(),
mMoto = new ArrayList<>(), mNokia = new ArrayList<>(), mOnePlus = new ArrayList<>(),
mOppo = new ArrayList<>(), mSony = new ArrayList<>(), mTInvisible = new ArrayList<>(),
mTLight = new ArrayList<>(), mTExtreme = new ArrayList<>(), mXiaomi = new ArrayList<>(),
mZTE = new ArrayList<>();
public static boolean isTextMatched(String searchText, String searchWord) {
for (int a = 0; a < searchText.length() - searchWord.length() + 1; a++) {
if (searchWord.equalsIgnoreCase(searchText.substring(a, a + searchWord.length()))) {
return true;
}
}
return false;
}
public static List<PackageItem> getAOSP() {
return mAOSP;
}
public static List<PackageItem> getAsus() {
return mAsus;
}
public static List<PackageItem> getCarrier() {
return mCarrier;
}
public static List<PackageItem> getGoogle() {
return mGoogle;
}
public static List<PackageItem> getHuawei() {
return mHuawei;
}
public static List<PackageItem> getLG() {
return mLG;
}
public static List<PackageItem> getMisc() {
return mMisc;
}
public static List<PackageItem> getMoto() {
return mMoto;
}
public static List<PackageItem> getNokia() {
return mNokia;
}
public static List<PackageItem> getOppo() {
return mOppo;
}
public static List<PackageItem> getOnePlus() {
return mOnePlus;
}
public static List<PackageItem> getRawData() {
return mRawData;
}
public static List<PackageItem> getSamsung() {
return mSamsung;
}
public static List<PackageItem> getSony() {
return mSony;
}
public static List<PackageItem> geTInvisible() {
return mTInvisible;
}
public static List<PackageItem> getTLight() {
return mTLight;
}
public static List<PackageItem> getTExtreme() {
return mTExtreme;
}
public static List<PackageItem> getXiaomi() {
return mXiaomi;
}
public static List<PackageItem> getZTE() {
return mZTE;
}
public static List<sSerializableItems> getCredits() {
List<sSerializableItems> mData = new ArrayList<>();
mData.add(new sSerializableItems(null, "Willi Ye", "Kernel Adiutor", "https://github.com/Grarak/KernelAdiutor"));
mData.add(new sSerializableItems(null, "John Wu", "libsu & Magisk", "https://github.com/topjohnwu"));
mData.add(new sSerializableItems(null, "weishu", "KernelSU", "https://github.com/tiann"));
mData.add(new sSerializableItems(null, "Nikita", "Russian & Ukrainian Translations", "https://t.me/MONSTER_PC"));
mData.add(new sSerializableItems(null, "Emre", "Turkish Translations", "https://t.me/xcooLwastaken"));
mData.add(new sSerializableItems(null, "Firerust96", "Spanish Translations", "https://github.com/Firerust96"));
mData.add(new sSerializableItems(null, "lay4play", "Italian Translations", null));
mData.add(new sSerializableItems(null, "Axel Schaab", "German Translations", null));
mData.add(new sSerializableItems(null, "alex", "Polish Translations", null));
mData.add(new sSerializableItems(null, "Ktosspl", "Polish Translations", null));
mData.add(new sSerializableItems(null, "Valdnet", "Polish Translations", "https://github.com/Valdnet"));
mData.add(new sSerializableItems(null, "Reno", "French Translations", null));
mData.add(new sSerializableItems(null, "Ebolateam", "French Translations", null));
mData.add(new sSerializableItems(null, "Hoa Gia Đại Thiếu", "Vietnamese Translations", null));
mData.add(new sSerializableItems(null, "ひきたり", "Vietnamese Translations", null));
mData.add(new sSerializableItems(null, "qiaoxin", "Chinese - Hong Kong (Traditional and Simplified) Translations", null));
mData.add(new sSerializableItems(null, "MMETMA", "Arabic Translations", "https://github.com/MMETMA"));
mData.add(new sSerializableItems(null, "Guima Teixeira", "French (Belgian)", null));
mData.add(new sSerializableItems(null, "蔡承佑", "Chinese (Traditional) Translations", null));
mData.add(new sSerializableItems(null, "Geovanni", "Portuguese (Brazilian) Translations", null));
mData.add(new sSerializableItems(null, "Chong", "Chinese (Simplified) Translations", null));
mData.add(new sSerializableItems(null, "Lw201811", "Japanese & Chinese (Simplified) Translations", null));
mData.add(new sSerializableItems(null, "Hongle", "Chinese - Hong Kong (Traditional and Simplified) Translations", null));
mData.add(new sSerializableItems(null, "Ignác Czébán", "Hungarian Translations", null));
mData.add(new sSerializableItems(null, "mx. sony", "Slovakian Translations", null));
mData.add(new sSerializableItems(null, "Leudy R. Villa Calcaño", "Dominican Spanish Translations", null));
mData.add(new sSerializableItems(null, "Many other volunteers", "Contributed via. POEditor", "https://poeditor.com/join/project?hash=BZS89Ev3WG"));
return mData;
}
public static String getModuleParent() {
return "/data/adb/modules/De-bloater";
}
public static String geLatestAPK(Context context) {
return context.getExternalFilesDir("") + "/app-release.apk";
}
public static String getLatestVersionUrl() {
return "https://raw.githubusercontent.com/sunilpaulmathew/De-Bloater/master/app/src/main/assets/release.json";
}
public static void setRawData(List<PackageItem> rawData) {
mRawData = rawData;
}
}

View file

@ -0,0 +1,64 @@
package com.sunilpaulmathew.debloater.utils;
import android.content.Context;
import android.text.Editable;
import android.view.Gravity;
import android.view.ViewGroup;
import android.widget.LinearLayout;
import androidx.appcompat.widget.AppCompatEditText;
import com.google.android.material.dialog.MaterialAlertDialogBuilder;
import com.sunilpaulmathew.debloater.R;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on February 04, 2023
*/
public abstract class EditTextInterface {
private final Context mContext;
private final MaterialAlertDialogBuilder mDialogBuilder;
private final String mText, mTitle;
public EditTextInterface(String text, String title, Context context) {
this.mText = text;
this.mTitle = title;
this.mContext = context;
this.mDialogBuilder = new MaterialAlertDialogBuilder(context);
}
private void startDialog() {
LinearLayout layout = new LinearLayout(mContext);
layout.setPadding(75, 75, 75, 75);
final AppCompatEditText editText = new AppCompatEditText(mContext);
editText.setGravity(Gravity.CENTER);
editText.setLayoutParams(new LinearLayout.LayoutParams(
ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));
if (mText != null) {
editText.append(mText);
}
editText.setSingleLine(true);
editText.requestFocus();
layout.addView(editText);
if (mTitle != null) {
mDialogBuilder.setTitle(mTitle);
mDialogBuilder.setIcon(R.mipmap.ic_launcher);
}
mDialogBuilder.setView(layout);
mDialogBuilder.setIcon(R.mipmap.ic_launcher);
mDialogBuilder.setNegativeButton(R.string.cancel, (dialog, id) -> {
});
mDialogBuilder.setPositiveButton(R.string.backup, (dialog, id) ->
positiveButtonLister(editText.getText())
).show();
}
public void show() {
startDialog();
}
public abstract void positiveButtonLister(Editable s);
}

View file

@ -0,0 +1,45 @@
package com.sunilpaulmathew.debloater.utils;
import android.graphics.drawable.Drawable;
import java.io.Serializable;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on February 03, 2021
*/
public class PackageItem implements Serializable {
private final String mAppName, mAPKPath, mPackageName;
private final Drawable mAppIcon;
private final boolean mUpdatedSystemApp;
public PackageItem(String appName, String apkPath, Drawable appIcon, String packageName, boolean updatedSystemApp) {
this.mAppName = appName;
this.mAPKPath = apkPath;
this.mAppIcon = appIcon;
this.mPackageName = packageName;
this.mUpdatedSystemApp = updatedSystemApp;
}
public String getAppName() {
return mAppName;
}
public String getAPKPath() {
return mAPKPath;
}
public Drawable getAppIcon() {
return mAppIcon;
}
public String getPackageName() {
return mPackageName;
}
public boolean isUpdatedSystemApp() {
return mUpdatedSystemApp;
}
}

View file

@ -0,0 +1,193 @@
package com.sunilpaulmathew.debloater.utils;
import android.app.Activity;
import android.content.Context;
import android.content.pm.ApplicationInfo;
import android.content.pm.PackageManager;
import android.os.Environment;
import android.view.inputmethod.InputMethodManager;
import androidx.appcompat.widget.AppCompatEditText;
import java.io.File;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import in.sunilpaulmathew.sCommon.APKUtils.sAPKUtils;
import in.sunilpaulmathew.sCommon.CommonUtils.sCommonUtils;
import in.sunilpaulmathew.sCommon.PackageUtils.sPackageUtils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on October 27, 2020
*/
public class PackageTasks {
static void createModuleParent() {
Utils.runCommand(Utils.magiskBusyBox() + "mkdir " + Common.getModuleParent());
}
public static List<PackageItem> getRawData(Context context) {
List<PackageItem> mData = new ArrayList<>();
List<ApplicationInfo> packages = getPackageManager(context).getInstalledApplications(PackageManager.GET_META_DATA);
for (ApplicationInfo packageInfo: packages) {
if ((packageInfo.flags & ApplicationInfo.FLAG_SYSTEM) != 0) {
mData.add(new PackageItem(
sPackageUtils.getAppName(packageInfo.packageName, context).toString(),
sPackageUtils.isUpdatedSystemApp(packageInfo.packageName, context) ? findSystemAPKPath(packageInfo.packageName,
context) : sPackageUtils.getSourceDir(packageInfo.packageName, context),
sPackageUtils.getAppIcon(packageInfo.packageName, context),
packageInfo.packageName,
sPackageUtils.isUpdatedSystemApp(packageInfo.packageName, context)));
}
}
return mData;
}
public static List<PackageItem> getActivePackageData(Context context, String searchText) {
List<PackageItem> mData = new ArrayList<>();
for (PackageItem item : Common.getRawData()) {
if (getSupportedAppsList(item.getAPKPath(), context)) {
if (searchText == null) {
mData.add(item);
} else if (Common.isTextMatched(item.getAppName(), searchText) || Common.isTextMatched(item.getPackageName(), searchText)) {
mData.add(item);
}
}
}
if (sCommonUtils.getInt("sort_apps", 1, context) == 0) {
Collections.sort(mData, (lhs, rhs) -> String.CASE_INSENSITIVE_ORDER.compare(lhs.getAppName(), rhs.getAppName()));
} else {
Collections.sort(mData, (lhs, rhs) -> String.CASE_INSENSITIVE_ORDER.compare(lhs.getPackageName(), rhs.getPackageName()));
}
if (sCommonUtils.getBoolean("reverse_order", false, context)) {
Collections.reverse(mData);
}
return mData;
}
public static List<String> getInactivePackageData(String searchText) {
List<String> mData = new ArrayList<>();
for (String line : Utils.runAndGetOutput(Utils.magiskBusyBox() + "find " + Common.getModuleParent() + "/system -type f -name *.apk").split("\\r?\\n")) {
if (line.endsWith(".apk")) {
if (searchText == null) {
mData.add(line);
} else if (Common.isTextMatched(line, searchText)) {
mData.add(line);
}
}
}
return mData;
}
private static boolean getSupportedAppsList(String apkPath, Context context) {
String mStatus = sCommonUtils.getString("appTypes", "all", context);
boolean systemApps = apkPath.startsWith("/system/app") || apkPath.startsWith("/system/priv-app")
|| apkPath.startsWith("/system/product/app") || apkPath.startsWith("/system/product/priv-app")
|| apkPath.startsWith("/system/vendor/app") || apkPath.startsWith("/system/vendor/overlay")
|| apkPath.startsWith("/system/product/overlay") || apkPath.startsWith("/system/system_ext/app")
|| apkPath.startsWith("/system/system_ext/priv-app") || apkPath.startsWith("/system_ext/app")
|| apkPath.startsWith("/system_ext/priv-app") || apkPath.startsWith("/system/preload");
boolean vendorApps = apkPath.startsWith("/vendor/overlay") || apkPath.startsWith("/vendor/app");
boolean productApps = apkPath.startsWith("/product/app") || apkPath.startsWith("/product/priv-app")
|| apkPath.startsWith("/product/overlay");
return switch (mStatus) {
case "system" -> systemApps;
case "product" -> productApps;
case "vendor" -> vendorApps;
default -> true;
};
}
public static PackageManager getPackageManager(Context context) {
return context.getPackageManager();
}
public static String findSystemAPKPath(String packageName, Context context) {
try {
String mAPKPath = null;
for (String line : Utils.runAndGetOutput("dumpsys package " + packageName + " | grep resourcePath").replace("resourcePath=", "").split("\\r?\\n")) {
if (!line.startsWith("/data/")) {
mAPKPath = line.replaceAll("\\s+", "");
for (File mFile : Objects.requireNonNull(new File(mAPKPath).listFiles())) {
if (Objects.equals(sAPKUtils.getPackageName(mFile.getAbsolutePath(), context), packageName)) {
mAPKPath = mAPKPath + File.separator + mFile.getName();
}
}
}
}
if (Utils.exist(mAPKPath)) return mAPKPath;
} catch (NullPointerException ignored) {}
return sPackageUtils.getSourceDir(packageName, context);
}
public static String getAdjAPKPath(String apkPath) {
if (apkPath.startsWith("/product/")) {
apkPath = apkPath.replace("/product", "/system/product");
} else if (apkPath.startsWith("/vendor/")) {
apkPath = apkPath.replace("/vendor", "/system/vendor");
} else if (apkPath.startsWith("/system_ext/")) {
apkPath = apkPath.replace("/system_ext", "/system/system_ext");
}
return apkPath;
}
public static String getStoragePath() {
return Environment.getExternalStorageDirectory().getPath();
}
public static String getModulePath() {
return Common.getModuleParent();
}
public static void initializeModule() {
if (!Utils.exist(Common.getModuleParent())) {
createModuleParent();
Utils.chmod("755", Common.getModuleParent());
Utils.create("id=De-bloater\n" +
"name=De-bloater\n" +
"version=v1.0\n" +
"versionCode=1\n" +
"author=sunilpaulmathew\n" +
"description=De-bloat apps Systemless-ly",
Common.getModuleParent() + "/module.prop");
Utils.chmod("644", Common.getModuleParent() + "/module.prop");
}
}
public static void removeModule(Activity activity) {
Utils.delete(activity.getFilesDir().getPath() + "/De-bloater");
Utils.delete(Common.getModuleParent());
sCommonUtils.saveBoolean("tomatot_extreme", false, activity);
sCommonUtils.saveBoolean("tomatot_invisible", false, activity);
sCommonUtils.saveBoolean("tomatot_light", false, activity);
}
public static boolean isModuleInitialized() {
return Utils.exist(Common.getModuleParent()) && Utils.exist(Common.getModuleParent() + "/module.prop");
}
public static void setToDelete(String path, String name) {
initializeModule();
Utils.runCommand(Utils.magiskBusyBox() + " mkdir -p " + Common.getModuleParent() + new File(path).getParentFile());
Utils.create(name, Common.getModuleParent() + path);
}
public static void revertDelete(String path) {
Utils.delete(Common.getModuleParent() + path);
}
public static void toggleKeyboard(AppCompatEditText editText, int mode, Context context) {
InputMethodManager imm = (InputMethodManager) context.getSystemService(Context.INPUT_METHOD_SERVICE);
if (mode == 1) {
if (editText.requestFocus()) {
imm.showSoftInput(editText, InputMethodManager.SHOW_IMPLICIT);
}
} else {
imm.hideSoftInputFromWindow(editText.getWindowToken(), 0);
}
}
}

View file

@ -0,0 +1,71 @@
package com.sunilpaulmathew.debloater.utils;
import android.os.Build;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
import in.sunilpaulmathew.sCommon.JsonUtils.sJSONUtils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on November 17, 2020
*/
public class Restore {
private static JSONArray getAppList(String json) {
return sJSONUtils.getJSONArray(sJSONUtils.getJSONObject(json), "DeBloater");
}
private static JSONObject getDeviceInfo(String json) {
return sJSONUtils.getJSONObject(sJSONUtils.getString(sJSONUtils.getJSONObject(json), "Device"));
}
private static String getName(String string) {
return sJSONUtils.getString(sJSONUtils.getJSONObject(string), "name");
}
private static String getModel(String string) {
return sJSONUtils.getString(sJSONUtils.getJSONObject(string), "Model");
}
private static int getSDK(String string) {
return sJSONUtils.getInt(sJSONUtils.getJSONObject(string), "SDK");
}
private static String getPath(String string) {
return sJSONUtils.getString(sJSONUtils.getJSONObject(string), "path");
}
public static boolean isValidBackup(String path) {
return getAppList(Utils.read(path)) != null;
}
public static boolean isJSONMatched(String path) {
if (getDeviceInfo(Utils.read(path)) == null) return true;
return Objects.equals(getModel(Utils.read(path)), Build.MODEL) && getSDK(Utils.read(path)) == Build.VERSION.SDK_INT;
}
public static void restoreBackup(String path) {
List<String> mRestoreData = new ArrayList<>();
if (Utils.exist(path)) {
for (int i = 0; i < Objects.requireNonNull(getAppList(Utils.read(path))).length(); i++) {
try {
mRestoreData.add(Objects.requireNonNull(getAppList(Utils.read(path))).getJSONObject(i).toString());
} catch (JSONException ignored) {
}
}
}
for (String s : mRestoreData) {
if (Utils.exist(Objects.requireNonNull(getPath(s)).replace("/data/adb/modules/De-bloater",""))) {
PackageTasks.setToDelete(Objects.requireNonNull(getPath(s)).replace("/data/adb/modules/De-bloater",""), getName(s));
}
}
}
}

View file

@ -0,0 +1,243 @@
package com.sunilpaulmathew.debloater.utils;
import android.content.Context;
import java.io.File;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
import in.sunilpaulmathew.sCommon.APKUtils.sAPKUtils;
import in.sunilpaulmathew.sCommon.CommonUtils.sCommonUtils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on November 03, 2020
*/
public class Tomatot {
public static List<String> getTomatotInvisible() {
List<String> mData = new ArrayList<>();
mData.add("/system/app/AntHalService/AntHalService.apk");
mData.add("/system/app/AutoRegistration/AutoRegistration.apk");
mData.add("/system/app/BasicDreams/BasicDreams.apk");
mData.add("/system/app/BookmarkProvider/BookmarkProvider.apk");
mData.add("/system/app/BTtestmode/BTtestmode.apk");
mData.add("/system/app/BuiltInPrintService/BuiltInPrintService.apk");
mData.add("/system/app/card/card.apk");
mData.add("/system/app/CtsShimPrebuilt/CtsShimPrebuilt.apk");
mData.add("/system/app/EasterEgg_O2/EasterEgg_O2.apk");
mData.add("/system/app/EngineeringMode/EngineeringMode.apk");
mData.add("/system/app/EngSpecialTest/EngSpecialTest.apk");
mData.add("/system/app/GooglePrintRecommendationService/GooglePrintRecommendationService.apk");
mData.add("/system/app/GoogleTTS/GoogleTTS.apk");
mData.add("/system/app/LogKitSdService/LogKitSdService.apk");
mData.add("/system/app/NFCTestMode/NFCTestMode.apk");
mData.add("/system/app/OEMLogKit/OEMLogKit.apk");
mData.add("/system/app/oem_tcma/oem_tcma.apk");
mData.add("/system/app/OPBugReportLite/OPBugReportLite.apk");
mData.add("/system/app/OPCommonLogTool/OPCommonLogTool.apk");
mData.add("/system/app/OPLiveWallpaper/OPLiveWallpaper.apk");
mData.add("/system/app/OPPush/OPPush.apk");
mData.add("/system/app/PartnerBookmarksProvider/PartnerBookmarksProvider.apk");
mData.add("/system/app/PhotosOnline/PhotosOnline.apk");
mData.add("/system/app/PlayAutoInstallConfig/PlayAutoInstallConfig.apk");
mData.add("/system/app/RFTuner/RFTuner.apk");
mData.add("/system/app/SensorTestTool/SensorTestTool.apk");
mData.add("/system/app/SoterService/SoterService.apk");
mData.add("/system/app/Stk/Stk.apk");
mData.add("/system/app/SeempService/SeempService.apk");
mData.add("/system/app/talkback/talkback.apk");
mData.add("/system/app/Traceur/Traceur.apk");
mData.add("/system/app/WallpaperBackup/WallpaperBackup.apk");
mData.add("/system/app/WapiCertManage/WapiCertManage.apk");
mData.add("/system/app/WifiRfTestApk/WifiRfTestApk.apk");
mData.add("/system/priv-app/CtsShimPrivPrebuilt/CtsShimPrivPrebuilt.apk");
mData.add("/system/priv-app/OPCellBroadcastReceiver/OPCellBroadcastReceiver.apk");
mData.add("/system/priv-app/TagGoogle/TagGoogle.apk");
mData.add("/system/product/app/uimremoteclient/uimremoteclient.apk");
mData.add("/system/product/priv-app/GoogleFeedback/GoogleFeedback.apk");
mData.add("/product/app/uimremoteclient/uimremoteclient.apk");
mData.add("/product/priv-app/GoogleFeedback/GoogleFeedback.apk");
mData.add("/system/etc/usb_drivers.iso/usb_drivers.iso.apk");
return mData;
}
public static List<String> getTomatotLight() {
List<String> mData = new ArrayList<>();
mData.add("/system/app/ARCore_stub/ARCore_stub.apk");
mData.add("/system/app/BackupRestoreRemoteService/BackupRestoreRemoteService.apk");
mData.add("/system/app/DiracManager/DiracManager.apk");
mData.add("/system/app/GooglePay/GooglePay.apk");
mData.add("/system/app/HTMLViewer/HTMLViewer.apk");
mData.add("/system/app/NVBackupUI/NVBackupUI.apk");
mData.add("/system/app/OPScreenRecord/OPScreenRecord.apk");
mData.add("/system/priv-app/BackupRestoreConfirmation/BackupRestoreConfirmation.apk");
mData.add("/system/priv-app/CallLogBackup/CallLogBackup.apk");
mData.add("/system/priv-app/DiracAudioControlService/DiracAudioControlService.apk");
mData.add("/system/priv-app/ManagedProvisioning/ManagedProvisioning.apk");
mData.add("/system/priv-app/OnePlusWizard/OnePlusWizard.apk");
mData.add("/system/priv-app/OPDeviceManager/OPDeviceManager.apk");
mData.add("/system/priv-app/OPDeviceManagerProvider/OPDeviceManagerProvider.apk");
mData.add("/system/priv-app/SharedStorageBackup/SharedStorageBackup.apk");
mData.add("/system/product/app/Account/Account.apk");
mData.add("/system/product/app/atfwd/atfwd.apk");
mData.add("/system/product/app/CalendarGoogle/CalendarGoogle.apk");
mData.add("/system/product/app/Chrome/Chrome.apk");
mData.add("/system/product/app/Drive/Drive.apk");
mData.add("/system/product/app/Duo/Duo.apk");
mData.add("/system/product/app/Gmail2/Gmail2.apk");
mData.add("/system/product/app/Music2/Music2.apk");
mData.add("/system/product/app/PhotoTable/PhotoTable.apk");
mData.add("/system/product/app/QdcmFF/QdcmFF.apk");
mData.add("/system/product/app/Videos/Videos.apk");
mData.add("/system/product/app/YouTube/YouTube.apk");
mData.add("/system/product/priv-app/AndroidAutoStub/AndroidAutoStub.apk");
mData.add("/system/product/priv-app/GoogleOneTimeInitializer/GoogleOneTimeInitializer.apk");
mData.add("/system/product/priv-app/SetupWizard/SetupWizard.apk");
mData.add("/system/product/priv-app/Turbo/Turbo.apk");
mData.add("/product/app/Account/Account.apk");
mData.add("/product/app/atfwd/atfwd.apk");
mData.add("/product/app/CalendarGoogle/CalendarGoogle.apk");
mData.add("/product/app/Chrome/Chrome.apk");
mData.add("/product/app/Drive/Drive.apk");
mData.add("/product/app/Duo/Duo.apk");
mData.add("/product/app/Gmail2/Gmail2.apk");
mData.add("/product/app/Music2/Music2.apk");
mData.add("/product/app/PhotoTable/PhotoTable.apk");
mData.add("/product/app/QdcmFF/QdcmFF.apk");
mData.add("/product/app/Videos/Videos.apk");
mData.add("/product/app/YouTube/YouTube.apk");
mData.add("/product/priv-app/AndroidAutoStub/AndroidAutoStub.apk");
mData.add("/product/priv-app/GoogleOneTimeInitializer/GoogleOneTimeInitializer.apk");
mData.add("/product/priv-app/SetupWizard/SetupWizard.apk");
mData.add("/product/priv-app/Turbo/Turbo.apk");
return mData;
}
public static List<String> getTomatotExtreme() {
List<String> mData = new ArrayList<>();
mData.add("/system/app/Backup.apk");
mData.add("/system/app/BluetoothMidiService/BluetoothMidiService.apk");
mData.add("/system/app/LiveWallpapersPicker/LiveWallpapersPicker.apk");
mData.add("/system/app/OPBackup/OPBackup.apk");
mData.add("/system/app/OPBreathMode/OPBreathMode.apk");
mData.add("/system/app/OPSafe/OPSafe.apk");
mData.add("/system/app/OPYellowpage/OPYellowpage.apk");
mData.add("/system/app/WAPPushManager/WAPPushManager.apk");
mData.add("/system/priv-app/EmergencyInfo/EmergencyInfo.apk");
mData.add("/system/priv-app/HotwordEnrollmentOKGoogleWCD9340/HotwordEnrollmentOKGoogleWCD9340.apk");
mData.add("/system/priv-app/HotwordEnrollmentXGoogleWCD9340/HotwordEnrollmentXGoogleWCD9340.apk");
mData.add("/system/priv-app/IFAAService/IFAAService.apk");
mData.add("/system/priv-app/MusicFX/MusicFX.apk");
mData.add("/system/priv-app/OnePlusGallery/OnePlusGallery.apk");
mData.add("/system/priv-app/OPAod/OPAod.apk");
mData.add("/system/priv-app/OPFaceUnlock/OPFaceUnlock.apk");
mData.add("/system/priv-app/ProxyHandler/ProxyHandler.apk");
mData.add("/system/priv-app/VpnDialogs/VpnDialogs.apk");
mData.add("/system/product/app/datastatusnotification/datastatusnotification.apk");
mData.add("/system/product/app/GoogleContactsSyncAdapter/GoogleContactsSyncAdapter.apk");
mData.add("/system/product/app/GoogleLocationHistory/GoogleLocationHistory.apk");
mData.add("/system/product/app/Maps/Maps.apk");
mData.add("/system/product/app/Photos/Photos.apk");
mData.add("/system/product/app/remoteSimLockAuthentication/remoteSimLockAuthentication.apk");
mData.add("/system/product/app/remotesimlockservice/remotesimlockservice.apk");
mData.add("/system/product/app/WebViewGoogle/WebViewGoogle.apk");
mData.add("/system/product/priv-app/OPAppLocker/OPAppLocker.apk");
mData.add("/system/product/priv-app/Velvet/Velvet/Velvet.apk");
mData.add("/system/product/priv-app/WallpaperCropper/WallpaperCropper.apk");
mData.add("/system/product/priv-app/Wellbeing/Wellbeing.apk");
mData.add("/product/app/datastatusnotification/datastatusnotification.apk");
mData.add("/product/app/GoogleContactsSyncAdapter/GoogleContactsSyncAdapter.apk");
mData.add("/product/app/GoogleLocationHistory/GoogleLocationHistory.apk");
mData.add("/product/app/Maps/Maps.apk");
mData.add("/product/app/Photos/Photos.apk");
mData.add("/product/app/remoteSimLockAuthentication/remoteSimLockAuthentication.apk");
mData.add("/product/app/remotesimlockservice/remotesimlockservice.apk");
mData.add("/product/app/WebViewGoogle/WebViewGoogle.apk");
mData.add("/product/priv-app/OPAppLocker/OPAppLocker.apk");
mData.add("/product/priv-app/Velvet/Velvet/Velvet.apk");
mData.add("/product/priv-app/WallpaperCropper/WallpaperCropper.apk");
mData.add("/product/priv-app/Wellbeing/Wellbeing.apk");
return mData;
}
public static void enable(String tag, List<PackageItem> items, Context context) {
PackageTasks.initializeModule();
for (PackageItem item : items) {
if (Utils.exist(item.getAPKPath())) {
PackageTasks.setToDelete(item.getAPKPath(), new File(item.getAPKPath()).getName());
}
}
sCommonUtils.saveBoolean(tag, true, context);
}
public static void disable(String tag, List<PackageItem> items, Context context) {
for (PackageItem item : items) {
if (Utils.exist(PackageTasks.getModulePath() + item.getAPKPath())) {
PackageTasks.revertDelete(item.getAPKPath());
}
}
sCommonUtils.saveBoolean(tag, false, context);
}
public static boolean isScriptEnabled(String tag, Context context) {
return sCommonUtils.getBoolean(tag, false, context);
}
public static void setInvisibleData(Context context) {
try {
for (String path : getTomatotInvisible()) {
if (Utils.exist(path)) {
Common.geTInvisible().add(new PackageItem(Objects.requireNonNull(sAPKUtils.getAPKName(path, context)).toString(),
path, sAPKUtils.getAPKIcon(path, context), sAPKUtils.getPackageName(path, context), false));
}
}
} catch (NullPointerException ignored) {}
}
public static void setLightData(Context context) {
try {
List<PackageItem> items = new ArrayList<>();
for (String path : getTomatotInvisible()) {
if (Utils.exist(path)) {
items.add(new PackageItem(Objects.requireNonNull(sAPKUtils.getAPKName(path, context)).toString(),
path, sAPKUtils.getAPKIcon(path, context), sAPKUtils.getPackageName(path, context), false));
}
}
for (String path : getTomatotLight()) {
if (Utils.exist(path)) {
items.add(new PackageItem(Objects.requireNonNull(sAPKUtils.getAPKName(path, context)).toString(),
path, sAPKUtils.getAPKIcon(path, context), sAPKUtils.getPackageName(path, context), false));
}
}
Common.getTLight().addAll(items);
} catch (NullPointerException ignored) {}
}
public static void setExtremeData(Context context) {
try {
List<PackageItem> items = new ArrayList<>();
for (String path : getTomatotInvisible()) {
if (Utils.exist(path)) {
items.add(new PackageItem(Objects.requireNonNull(sAPKUtils.getAPKName(path, context)).toString(),
path, sAPKUtils.getAPKIcon(path, context), sAPKUtils.getPackageName(path, context), false));
}
}
for (String path : getTomatotLight()) {
if (Utils.exist(path)) {
items.add(new PackageItem(Objects.requireNonNull(sAPKUtils.getAPKName(path, context)).toString(),
path, sAPKUtils.getAPKIcon(path, context), sAPKUtils.getPackageName(path, context), false));
}
}
for (String path : getTomatotExtreme()) {
if (Utils.exist(path)) {
items.add(new PackageItem(Objects.requireNonNull(sAPKUtils.getAPKName(path, context)).toString(),
path, sAPKUtils.getAPKIcon(path, context), sAPKUtils.getPackageName(path, context), false));
}
}
Common.getTExtreme().addAll(items);
} catch (NullPointerException ignored) {}
}
}

File diff suppressed because it is too large Load diff

View file

@ -0,0 +1,265 @@
package com.sunilpaulmathew.debloater.utils;
import android.Manifest;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.app.ProgressDialog;
import android.content.Context;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.content.pm.Signature;
import android.preference.PreferenceManager;
import com.google.android.material.dialog.MaterialAlertDialogBuilder;
import com.sunilpaulmathew.debloater.BuildConfig;
import com.sunilpaulmathew.debloater.R;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.BufferedReader;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.Reader;
import java.net.URL;
import java.nio.charset.StandardCharsets;
import java.util.Arrays;
import java.util.Objects;
import in.sunilpaulmathew.sCommon.CommonUtils.sCommonUtils;
import in.sunilpaulmathew.sCommon.CommonUtils.sExecutor;
import in.sunilpaulmathew.sCommon.JsonUtils.sJSONUtils;
import in.sunilpaulmathew.sCommon.PermissionUtils.sPermissionUtils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on October 31, 2020
*/
public class UpdateCheck {
private static boolean mManualUpdate = false;
private static int mVersionCode = 0;
private static JSONObject mJSONObject = null;
private static String mChangeLog = null, mSHA1 = null, mReleaseURL = null, mVersionName = null;
public UpdateCheck() {
}
private static boolean isManualUpdate() {
return mManualUpdate;
}
/*
* Based on the ApkSignatureVerifier.java in https://github.com/f-droid/fdroidclient
* Ref: https://raw.githubusercontent.com/f-droid/fdroidclient/master/app/src/main/java/org/fdroid/fdroid/installer/ApkSignatureVerifier.java
*/
public static boolean isSignatureMatched(Context context) {
String mSmartPackKey = "[48, -126, 3, -69, 48, -126, 2, -93, -96, 3, 2, 1, 2, 2, 4, 83, 28, 18, 69, 48, 13, 6, 9, 42, -122, 72, -122, -9, 13, 1, 1, 11, 5, 0, 48, -127, -115, 49, 14, 48, 12, 6, 3, 85, 4, 6, 19, 5, 73, 110, 100, 105, 97, 49, 15, 48, 13, 6, 3, 85, 4, 8, 19, 6, 75, 101, 114, 97, 108, 97, 49, 14, 48, 12, 6, 3, 85, 4, 7, 19, 5, 75, 111, 99, 104, 105, 49, 18, 48, 16, 6, 3, 85, 4, 10, 19, 9, 83, 109, 97, 114, 116, 80, 97, 99, 107, 49, 33, 48, 31, 6, 3, 85, 4, 11, 19, 24, 83, 109, 97, 114, 116, 80, 97, 99, 107, 45, 75, 101, 114, 110, 101, 108, 32, 109, 97, 110, 97, 103, 101, 114, 49, 35, 48, 33, 6, 3, 85, 4, 3, 19, 26, 83, 117, 110, 105, 32, 80, 97, 117, 108, 32, 77, 97, 116, 104, 101, 119, 32, 77, 101, 110, 97, 99, 104, 101, 114, 121, 48, 30, 23, 13, 49, 55, 49, 48, 50, 54, 49, 49, 49, 57, 50, 48, 90, 23, 13, 52, 50, 49, 48, 50, 48, 49, 49, 49, 57, 50, 48, 90, 48, -127, -115, 49, 14, 48, 12, 6, 3, 85, 4, 6, 19, 5, 73, 110, 100, 105, 97, 49, 15, 48, 13, 6, 3, 85, 4, 8, 19, 6, 75, 101, 114, 97, 108, 97, 49, 14, 48, 12, 6, 3, 85, 4, 7, 19, 5, 75, 111, 99, 104, 105, 49, 18, 48, 16, 6, 3, 85, 4, 10, 19, 9, 83, 109, 97, 114, 116, 80, 97, 99, 107, 49, 33, 48, 31, 6, 3, 85, 4, 11, 19, 24, 83, 109, 97, 114, 116, 80, 97, 99, 107, 45, 75, 101, 114, 110, 101, 108, 32, 109, 97, 110, 97, 103, 101, 114, 49, 35, 48, 33, 6, 3, 85, 4, 3, 19, 26, 83, 117, 110, 105, 32, 80, 97, 117, 108, 32, 77, 97, 116, 104, 101, 119, 32, 77, 101, 110, 97, 99, 104, 101, 114, 121, 48, -126, 1, 34, 48, 13, 6, 9, 42, -122, 72, -122, -9, 13, 1, 1, 1, 5, 0, 3, -126, 1, 15, 0, 48, -126, 1, 10, 2, -126, 1, 1, 0, -93, -67, -12, 34, 23, -76, 100, -49, 117, 10, 42, 53, -19, 54, 110, -24, -109, 107, -128, -75, 80, 58, 56, 97, -65, 3, -98, -69, 111, 104, 23, 13, -40, 1, -42, 54, -1, 77, 125, 93, 85, 14, -118, -35, -71, 5, 123, -69, 23, -102, 9, -40, 52, -38, -24, -5, 85, 101, -112, -98, -71, 97, -84, -66, 76, 52, 86, 78, -55, -113, -40, 108, 110, 32, 106, -69, -107, 91, -18, -7, 59, -94, -37, -68, 97, 70, -5, 48, -22, -8, 113, 107, 96, -124, 127, 13, -61, -122, -45, -89, 3, -55, 41, -7, -89, -61, 11, -36, 9, -11, -111, -105, -5, -7, -115, 41, -67, 68, 55, 107, -19, 115, -92, -74, -116, -64, 11, -112, -75, -104, 95, 79, -106, -105, 16, 2, -79, 87, 70, 115, 73, -126, -15, 127, -92, 123, -83, -23, -107, -24, -36, -68, 6, 99, 107, -105, -1, 16, 99, 113, -82, 95, -47, 6, -95, -8, -18, -40, -104, 22, 21, 104, -26, -103, 97, 97, -19, -93, -103, -63, 61, 71, -103, -92, 95, -42, -118, 2, -99, 37, -15, -120, -84, 1, 69, -65, 6, -82, 70, -62, 86, 34, 19, -127, -109, -49, 89, 7, 46, 3, 123, -116, 127, -73, -77, 89, -22, -76, -63, 40, 123, -48, -124, -87, -93, -127, -68, 16, 43, 2, 59, 52, -63, 36, 111, 68, 119, 96, -10, 86, 7, 80, 35, 29, 28, -125, 95, 112, -101, 82, -117, 56, -45, -75, -97, 95, 2, 3, 1, 0, 1, -93, 33, 48, 31, 48, 29, 6, 3, 85, 29, 14, 4, 22, 4, 20, 57, 125, -58, -16, 30, 48, -4, -79, -11, 127, -18, -102, 77, 126, 122, 56, 118, 83, -57, 70, 48, 13, 6, 9, 42, -122, 72, -122, -9, 13, 1, 1, 11, 5, 0, 3, -126, 1, 1, 0, -123, 24, -8, -90, 49, 117, 25, 86, -40, 42, 93, 126, -104, 89, -117, -76, -118, 92, -56, 111, 105, 65, -106, 102, -9, 110, -46, -67, 15, 0, 99, -10, 127, -113, 82, -65, 21, -71, -89, 104, 126, -113, 95, 25, -97, -12, -9, -64, -2, 83, -84, 100, -21, -84, -92, -97, 61, -17, 67, -98, -66, 79, -91, 12, -15, 106, 9, 11, -22, -112, -28, -60, -75, -73, -72, 69, -118, -5, -45, 10, -25, 86, -65, 113, 76, 112, 59, 39, -87, 5, 57, 117, 102, 82, -43, 72, 83, 50, 52, -26, 49, -120, 15, -58, 13, -91, 76, 114, 93, -36, -46, -64, 23, 85, -70, -97, 124, -75, 12, 71, -5, 44, -81, 80, 40, 50, 126, -21, -127, 127, 116, -120, 97, -55, -121, 37, -111, 102, 83, -17, 9, -108, -37, -99, 20, -3, -39, -74, -15, -91, 25, 98, 36, -116, 118, 22, 116, -114, 60, 15, 49, 105, 123, 94, 29, 114, 12, -20, -61, -62, -71, 104, 48, 91, 63, -110, -54, -18, 94, -45, -11, -51, -111, -123, -75, -8, 36, -58, 88, -15, -116, 12, 4, 95, 16, 92, 61, -22, 12, 56, 5, 37, 44, -47, 123, 104, -98, -111, 21, -114, -121, 127, -64, -58, -9, -93, 63, -116, 83, -31, 61, -99, 34, 6, 19, -94, 69, 47, -106, -61, -115, -47, -50, -97, -28, -39, -54, 41, -48, -125, 120, 93, 84, 109, -84, 9, -83, 110, 119, 68, 72, -76, -53, 63, -52, 75]";
String mAppKey = Arrays.toString(Objects.requireNonNull(getSignature(context.getPackageName(), context)));
return mSmartPackKey.equals(mAppKey);
}
private static boolean isUpdateAvailable() {
return BuildConfig.VERSION_CODE < getVersionCode();
}
@SuppressLint("PackageManagerGetSignatures")
private static byte[] getSignature(String packageid, Context context) {
try {
PackageInfo pkgInfo = context.getPackageManager().getPackageInfo(packageid, PackageManager.GET_SIGNATURES);
return signatureToBytes(pkgInfo.signatures);
} catch (PackageManager.NameNotFoundException ignored) {}
return null;
}
private static byte[] signatureToBytes(Signature[] signatures) {
ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
for (Signature sig : signatures) {
try {
outputStream.write(sig.toByteArray());
} catch (IOException ignored) {}
}
return outputStream.toByteArray();
}
private static int getVersionCode() {
if (mJSONObject == null) return 0;
return mVersionCode;
}
private static MaterialAlertDialogBuilder updateAvailableDialog(Activity activity) {
return new MaterialAlertDialogBuilder(activity)
.setIcon(R.mipmap.ic_launcher)
.setTitle(activity.getString(R.string.update_available, getVersionName()))
.setMessage(activity.getString(R.string.change_logs) + "\n" + getChangeLogs())
.setCancelable(false)
.setNegativeButton(activity.getString(R.string.cancel), (dialog, id) -> {
})
.setPositiveButton(activity.getString(R.string.get_it), (dialog, id) -> {
if (sPermissionUtils.isPermissionDenied(Manifest.permission.WRITE_EXTERNAL_STORAGE, activity)) {
sPermissionUtils.requestPermission(new String[] {
Manifest.permission.WRITE_EXTERNAL_STORAGE
}, activity);
sCommonUtils.snackBar(activity.findViewById(android.R.id.content), activity.getString(R.string.storage_access_denied)).show();
return;
}
updaterTask(activity);
});
}
private static String getChangeLogs() {
if (mJSONObject == null) return "";
return mChangeLog;
}
private static String getChecksum() {
if (mJSONObject == null) return "";
return mSHA1;
}
private static String readAll(Reader rd) throws IOException {
StringBuilder sb = new StringBuilder();
int cp;
while ((cp = rd.read()) != -1) {
sb.append((char) cp);
}
return sb.toString();
}
private static String getVersionName() {
if (mJSONObject == null) return "";
return mVersionName;
}
private static String getUrl() {
if (mJSONObject == null) return "";
return mReleaseURL;
}
private static void getLatestApp(Context context) {
if (sPermissionUtils.isPermissionDenied(Manifest.permission.WRITE_EXTERNAL_STORAGE, context)) {
sPermissionUtils.requestPermission(new String[] {
Manifest.permission.WRITE_EXTERNAL_STORAGE
}, (Activity) context);
return;
}
Utils.download(Common.geLatestAPK(context), getUrl());
}
public static void isManualUpdate(boolean b) {
mManualUpdate = b;
}
private static void parseJSON(int updateCheckInterval, Activity activity) {
new sExecutor() {
private long ucTimeStamp;
private int interval;
@Override
public void onPreExecute() {
ucTimeStamp = PreferenceManager.getDefaultSharedPreferences(activity).getLong("ucTimeStamp", 0);
interval = updateCheckInterval * 60 * 60 * 1000;
}
@Override
public void doInBackground() {
if (System.currentTimeMillis() > ucTimeStamp + interval) {
try (InputStream is = new URL(Common.getLatestVersionUrl()).openStream()) {
BufferedReader rd = new BufferedReader(new InputStreamReader(is, StandardCharsets.UTF_8));
String jsonText = readAll(rd);
mJSONObject = new JSONObject(jsonText);
mChangeLog = sJSONUtils.getString(mJSONObject,"releaseNotes");
mReleaseURL = sJSONUtils.getString(mJSONObject,"releaseUrl");
mSHA1 = sJSONUtils.getString(mJSONObject,"sha1");
mVersionCode = sJSONUtils.getInt(mJSONObject,"latestVersionCode");
mVersionName = sJSONUtils.getString(mJSONObject,"latestVersion");
} catch (JSONException | IOException ignored) {
}
}
}
@Override
public void onPostExecute() {
if (isManualUpdate()) {
if (mJSONObject == null) {
sCommonUtils.snackBar(activity.findViewById(android.R.id.content), activity.getString(R.string.no_internet)).show();
return;
}
if (isUpdateAvailable()) {
updateAvailableDialog(activity).show();
} else {
new MaterialAlertDialogBuilder(activity)
.setIcon(R.mipmap.ic_launcher)
.setTitle(R.string.app_name)
.setMessage(R.string.updated_dialog)
.setPositiveButton(activity.getString(R.string.cancel), (dialog, id) -> {
}).show();
}
} else {
if (mJSONObject == null) {
return;
}
if (isUpdateAvailable()) {
updateAvailableDialog(activity).show();
}
}
PreferenceManager.getDefaultSharedPreferences(activity).edit().putLong("ucTimeStamp", System
.currentTimeMillis()).apply();
}
}.execute();
}
private static void updaterTask(Context context) {
new sExecutor() {
private String mSid = null;
private ProgressDialog mProgressDialog;
@Override
public void onPreExecute() {
mProgressDialog = new ProgressDialog(context);
mProgressDialog.setMessage(context.getString(R.string.downloading, getVersionName() + "..."));
mProgressDialog.setCancelable(false);
mProgressDialog.show();
}
@Override
public void doInBackground() {
getLatestApp(context);
mProgressDialog.setMessage("Installing De-Bloater " + getVersionName() + "...");
Utils.runCommand("sleep 5");
if (Utils.exist(Common.geLatestAPK(context)) && Utils.getChecksum(Common.geLatestAPK(context))
.contains(Objects.requireNonNull(getChecksum()))) {
mSid = Utils.runAndGetOutput("pm install-create").replace(
"Success: created install session [","").replace("]", "");
File mAPK = new File(Common.geLatestAPK(context));
Utils.runCommand("pm install-write -S " + mAPK.length() + " " + mSid + " " + mAPK.getName() + " " + mAPK);
}
}
@Override
public void onPostExecute() {
try {
mProgressDialog.dismiss();
} catch (IllegalArgumentException ignored) {}
if (Utils.exist(Common.geLatestAPK(context)) && Utils.getChecksum(Common.geLatestAPK(context))
.contains(Objects.requireNonNull(getChecksum()))) {
Utils.runCommand("pm install-commit " + mSid);
} else {
new MaterialAlertDialogBuilder(context)
.setMessage(context.getString(R.string.download_failed))
.setNegativeButton(context.getString(R.string.cancel), (dialog, id) -> {
}).show();
}
}
}.execute();
}
public void initialize(int updateCheckInterval, Activity activity) {
parseJSON(updateCheckInterval, activity);
}
}

View file

@ -0,0 +1,169 @@
package com.sunilpaulmathew.debloater.utils;
import android.app.Activity;
import android.content.Context;
import android.content.res.Configuration;
import android.os.Build;
import android.text.Html;
import android.util.TypedValue;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import com.google.android.material.bottomnavigation.BottomNavigationView;
import com.sunilpaulmathew.debloater.BuildConfig;
import com.sunilpaulmathew.debloater.R;
import com.topjohnwu.superuser.Shell;
import com.topjohnwu.superuser.ShellUtils;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.net.URL;
import java.util.List;
import in.sunilpaulmathew.sCommon.CommonUtils.sCommonUtils;
import in.sunilpaulmathew.sCommon.PackageUtils.sPackageUtils;
/*
* Created by sunilpaulmathew <sunil.kde@gmail.com> on October 27, 2020
*/
public class Utils {
static {
Shell.enableVerboseLogging = BuildConfig.DEBUG;
}
public static String getAppStoreURL(Context context) {
if (sPackageUtils.isPackageInstalled("com.android.vending", context)) {
return " Google Play: https://play.google.com/store/apps/details?id=com.sunilpaulmathew.debloater";
} else if (sPackageUtils.isPackageInstalled("org.fdroid.fdroid", context)) {
return " F-Droid: https://f-droid.org/packages/com.sunilpaulmathew.debloater/";
} else {
return " GitHub: https://github.com/sunilpaulmathew/De-Bloater/releases/latest";
}
}
public static int getSpanCount(Activity activity) {
return sCommonUtils.isTablet(activity) ? sCommonUtils.getOrientation(activity) == Configuration.ORIENTATION_LANDSCAPE ?
4 : 3 : sCommonUtils.getOrientation(activity) == Configuration.ORIENTATION_LANDSCAPE ? 3 : 2;
}
public static boolean rootAccess() {
return Shell.getShell().isRoot();
}
public static void runCommand(String command) {
Shell.cmd(command).exec();
}
@NonNull
static String runAndGetOutput(String command) {
StringBuilder sb = new StringBuilder();
try {
List<String> outputs = Shell.cmd(command).exec().getOut();
if (ShellUtils.isValidOutput(outputs)) {
for (String output : outputs) {
sb.append(output).append("\n");
}
}
return removeSuffix(sb.toString()).trim();
} catch (Exception e) {
return "";
}
}
public static boolean magiskSupported() {
return Utils.exist("/sbin/.magisk") || Utils.exist("/data/adb/magisk") || isAPatchSupported() || isKSUSupported();
}
public static int getThemeAccentColor(Context context) {
TypedValue value = new TypedValue();
context.getTheme().resolveAttribute(R.attr.colorAccent, value, true);
return value.data;
}
public static int getPrimaryTextColor(Context context) {
TypedValue value = new TypedValue();
context.getTheme().resolveAttribute(R.attr.colorPrimary, value, true);
return value.data;
}
private static String removeSuffix(@Nullable String s) {
if (s != null && s.endsWith("\n")) {
return s.substring(0, s.length() - "\n".length());
}
return s;
}
public static boolean exist(String file) {
String output = runAndGetOutput("[ -e " + file + " ] && echo true");
return output.equals("true");
}
public static boolean isAPatchSupported() {
return Utils.exist("/data/adb/ap/bin/busybox");
}
public static boolean isKSUSupported() {
return Utils.exist("/data/adb/ksu/bin/busybox");
}
public static void delete(String path) {
runCommand(magiskBusyBox() + "rm -r " + path);
}
public static void create(String text, String path) {
Utils.runCommand(magiskBusyBox() + "echo '" + text + "' > " + path);
}
public static String read(String path) {
return Utils.runAndGetOutput("cat " + path);
}
public static void navigateToFragment(Activity activity) {
BottomNavigationView bottomNavigationView = activity.findViewById(R.id.bottom_navigation);
bottomNavigationView.setSelectedItemId(R.id.nav_active);
}
static void download(String path, String url) {
try (InputStream input = new URL(url).openStream();
FileOutputStream output = new FileOutputStream(path)) {
byte[] data = new byte[4096];
int count;
while ((count = input.read(data)) != -1) {
output.write(data, 0, count);
}
} catch (Exception ignored) {
}
}
static void chmod(String permission, String path) {
runCommand(magiskBusyBox() + "chmod " + permission + " " + path);
}
public static String getChecksum(String path) {
return runAndGetOutput("sha1sum " + path);
}
public static String magiskBusyBox() {
if (Utils.exist("/data/adb/magisk/busybox")) {
return "/data/adb/magisk/busybox ";
} else if (isAPatchSupported()) {
return "/data/adb/ap/bin/busybox ";
} else if (isKSUSupported()) {
return "/data/adb/ksu/bin/busybox ";
} else {
return "";
}
}
public static CharSequence fromHtml(String text) {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
return Html.fromHtml(text, Html.FROM_HTML_MODE_LEGACY);
} else {
return Html.fromHtml(text);
}
}
}

View file

@ -0,0 +1,5 @@
<vector android:height="48dp" android:tint="?attr/colorControlNormal"
android:viewportHeight="24" android:viewportWidth="24"
android:width="48dp" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="@android:color/white" android:pathData="M12,2C6.48,2 2,6.48 2,12s4.48,10 10,10 10,-4.48 10,-10S17.52,2 12,2zM13,17h-2v-6h2v6zM13,9h-2L11,7h2v2z"/>
</vector>

View file

@ -0,0 +1,5 @@
<vector android:height="48dp" android:tint="?attr/colorControlNormal"
android:viewportHeight="24" android:viewportWidth="24"
android:width="48dp" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="@android:color/white" android:pathData="M12,4.5C7,4.5 2.73,7.61 1,12c1.73,4.39 6,7.5 11,7.5s9.27,-3.11 11,-7.5c-1.73,-4.39 -6,-7.5 -11,-7.5zM12,17c-2.76,0 -5,-2.24 -5,-5s2.24,-5 5,-5 5,2.24 5,5 -2.24,5 -5,5zM12,9c-1.66,0 -3,1.34 -3,3s1.34,3 3,3 3,-1.34 3,-3 -1.34,-3 -3,-3z"/>
</vector>

View file

@ -0,0 +1,4 @@
<vector android:height="36dp" android:viewportHeight="1024"
android:viewportWidth="1024" android:width="36dp" android:tint="?attr/colorControlNormal" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="#FF000000" android:pathData="M256.01,768.01c0,23.47 19.2,42.66 42.66,42.66h42.66v149.33c0,35.41 28.59,64 64,64s64,-28.59 64,-64v-149.33h85.33v149.33c0,35.41 28.59,64 64,64s64,-28.59 64,-64v-149.33h42.66c23.47,0 42.66,-19.2 42.66,-42.66L767.99,341.36L256.01,341.36v426.65zM149.35,341.36c-35.41,0 -64,28.59 -64,64v298.65c0,35.41 28.59,64 64,64s64,-28.59 64,-64L213.35,405.36c0,-35.41 -28.59,-64 -64,-64zM874.65,341.36c-35.41,0 -64,28.59 -64,64v298.65c0,35.41 28.59,64 64,64s64,-28.59 64,-64L938.65,405.36c0,-35.41 -28.59,-64 -64,-64zM662.61,92.2l55.68,-55.68A21.25,21.25 0,1 0,688.21 6.44L625.06,69.37A254.28,254.28 0,0 0,512 42.71c-40.96,0 -79.36,9.81 -113.7,26.88L334.94,6.23a21.25,21.25 0,1 0,-30.08 30.08l55.89,55.89C297.4,138.92 256.01,214.01 256.01,298.7h511.98c0,-84.9 -41.6,-159.99 -105.38,-206.5zM426.67,213.37h-42.66L384.01,170.7h42.66v42.66zM639.99,213.37h-42.66L597.33,170.7h42.66v42.66z"/>
</vector>

View file

@ -0,0 +1,10 @@
<vector xmlns:android="http://schemas.android.com/apk/res/android"
android:width="24dp"
android:height="24dp"
android:viewportWidth="24"
android:viewportHeight="24"
android:tint="?attr/colorControlNormal">
<path
android:fillColor="@android:color/white"
android:pathData="M6,19c0,1.1 0.9,2 2,2h8c1.1,0 2,-0.9 2,-2V7H6v12zM19,4h-3.5l-1,-1h-5l-1,1H5v2h14V4z"/>
</vector>

View file

@ -0,0 +1,5 @@
<vector android:height="30dp" android:tint="?attr/colorControlNormal"
android:viewportHeight="24" android:viewportWidth="24"
android:width="30dp" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="@android:color/white" android:pathData="M12,2C6.48,2 2,6.48 2,12s4.48,10 10,10 10,-4.48 10,-10S17.52,2 12,2zM13.41,18.09L13.41,20h-2.67v-1.93c-1.71,-0.36 -3.16,-1.46 -3.27,-3.4h1.96c0.1,1.05 0.82,1.87 2.65,1.87 1.96,0 2.4,-0.98 2.4,-1.59 0,-0.83 -0.44,-1.61 -2.67,-2.14 -2.48,-0.6 -4.18,-1.62 -4.18,-3.67 0,-1.72 1.39,-2.84 3.11,-3.21L10.74,4h2.67v1.95c1.86,0.45 2.79,1.86 2.85,3.39L14.3,9.34c-0.05,-1.11 -0.64,-1.87 -2.22,-1.87 -1.5,0 -2.4,0.68 -2.4,1.64 0,0.84 0.65,1.39 2.67,1.91s4.18,1.39 4.18,3.91c-0.01,1.83 -1.38,2.83 -3.12,3.16z"/>
</vector>

View file

@ -0,0 +1,105 @@
<vector android:height="35dp" android:viewportHeight="48"
android:viewportWidth="48" android:width="35dp"
xmlns:aapt="http://schemas.android.com/aapt" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillAlpha="0.4" android:fillColor="#263238"
android:fillType="evenOdd"
android:pathData="m2.6135,1.9866a1.2501,1.2501 0,0 0,-1.0117 2.0293l3.6035,4.6641c-0.127,0.3331 -0.2031,0.6915 -0.2031,1.0703l0,4 0,2.8652 0,0.1348c0,1.662 1.338,3 3,3l32,0c1.662,0 3,-1.338 3,-3l0,-4 0,-2.8652 0,-0.1348c0,-0.3803 -0.0771,-0.74 -0.2051,-1.0742l3.6016,-4.6602a1.2501,1.2501 0,0 0,-1.0488 -2.0273,1.2501 1.2501,0 0,0 -0.9297,0.498l-3.4316,4.4414c-0.3102,-0.1079 -0.6384,-0.1777 -0.9863,-0.1777l-32,0c-0.3486,0 -0.6776,0.069 -0.9883,0.1777l-3.4336,-4.4414a1.2501,1.2501 0,0 0,-0.9668 -0.5zM8.0021,20.7504c-0.2077,0 -0.4098,0.021 -0.6055,0.061 -1.3695,0.2761 -2.3945,1.4698 -2.3945,2.9101l0,0.029 0,19.7793 0,0.029 0,0.1914c0,1.662 1.338,3 3,3l32,0c1.662,0 3,-1.338 3,-3l0,-20 0,-0.029c0,-1.4403 -1.025,-2.634 -2.3945,-2.9101 -0.1956,-0.039 -0.3977,-0.061 -0.6055,-0.061l-32,0z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="2.5"/>
<path android:fillColor="#8ab000" android:fillType="evenOdd"
android:pathData="m45.4108,2.5 l-4.25,5.5"
android:strokeColor="#769616" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="2.5"/>
<path android:fillAlpha="0.29803923" android:fillColor="#ffffff"
android:fillType="evenOdd"
android:pathData="m45.3885,1.2472c0.4535,0.012 0.7617,0.189 0.9807,0.4486 -2.0269,2.4089 -2.3684,2.7916 -5.1355,6.2214 -1.0195,1.319 -2.0816,0.6373 -1.0621,-0.6817l4.25,-5.5c0.229,-0.3056 0.5851,-0.478 0.9668,-0.4883z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="2.5"/>
<path android:fillAlpha="0.2" android:fillColor="#263238"
android:fillType="evenOdd"
android:pathData="m46.3777,1.7083c0.1239,0.1479 0.5612,0.8046 0.0225,1.5562l-4.25,5.5c-1.0195,1.319 -1.1499,-0.6123 -1.1499,-0.6123 -0,0 3.7345,-4.51 5.3774,-6.4439z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="2.5"/>
<path android:fillColor="#8ab000" android:fillType="evenOdd"
android:pathData="m45.6619,1.4821c0.4382,0 0.9599,0.1416 0.8242,0.7986 -0.1036,0.5016 -4.6608,6.0744 -4.6608,6.0744 -1.0195,1.319 -2.4935,0.6763 -1.4739,-0.6425l4.2344,-5.4727c0.2602,-0.29 0.6085,-0.7436 1.0762,-0.7578z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="2.5"/>
<path android:fillColor="#8ab000" android:fillType="evenOdd"
android:pathData="m2.5889,2.5 l4.25,5.5"
android:strokeColor="#769616" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="2.5"/>
<path android:fillAlpha="0.29803923" android:fillColor="#ffffff"
android:fillType="evenOdd"
android:pathData="m2.6113,1.2472c-0.4535,0.012 -0.7617,0.189 -0.9807,0.4486 2.0269,2.4089 2.3684,2.7916 5.1355,6.2214 1.0195,1.319 2.0816,0.6373 1.0621,-0.6817l-4.25,-5.5c-0.229,-0.3056 -0.5851,-0.478 -0.9668,-0.4883z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="2.5"/>
<path android:fillAlpha="0.2" android:fillColor="#263238"
android:fillType="evenOdd"
android:pathData="m1.6221,1.7083c-0.1239,0.1479 -0.5612,0.8046 -0.0225,1.5562l4.25,5.5c1.0195,1.319 1.1499,-0.6123 1.1499,-0.6123 0,0 -3.7345,-4.51 -5.3774,-6.4439z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="2.5"/>
<path android:fillColor="#8ab000" android:fillType="evenOdd"
android:pathData="m2.3379,1.4821c-0.4382,0 -0.9599,0.1416 -0.8242,0.7986 0.1036,0.5016 4.6608,6.0744 4.6608,6.0744 1.0195,1.319 2.4935,0.6763 1.4739,-0.6425l-4.2344,-5.4727c-0.2602,-0.29 -0.6085,-0.7436 -1.0762,-0.7578z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="2.5"/>
<path android:fillColor="#aeea00"
android:pathData="M8,6L40,6A3,3 0,0 1,43 9L43,16A3,3 0,0 1,40 19L8,19A3,3 0,0 1,5 16L5,9A3,3 0,0 1,8 6z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="3"/>
<path android:fillAlpha="0.2" android:fillColor="#263238"
android:pathData="M8,9L40,9A3,3 0,0 1,43 12L43,16A3,3 0,0 1,40 19L8,19A3,3 0,0 1,5 16L5,12A3,3 0,0 1,8 9z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="3"/>
<path android:fillAlpha="0.29803923" android:fillColor="#ffffff"
android:pathData="M8,6L40,6A3,3 0,0 1,43 9L43,13A3,3 0,0 1,40 16L8,16A3,3 0,0 1,5 13L5,9A3,3 0,0 1,8 6z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="3"/>
<path android:fillColor="#aeea00"
android:pathData="M8,7L40,7A3,2.5385 0,0 1,43 9.5385L43,15.4615A3,2.5385 0,0 1,40 18L8,18A3,2.5385 0,0 1,5 15.4615L5,9.5385A3,2.5385 0,0 1,8 7z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="3"/>
<path android:fillColor="#1976d2"
android:pathData="M8,20L40,20A3,3 0,0 1,43 23L43,43A3,3 0,0 1,40 46L8,46A3,3 0,0 1,5 43L5,23A3,3 0,0 1,8 20z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="3"/>
<path android:fillAlpha="0.2" android:fillColor="#263238"
android:pathData="M8,33L40,33A3,3 0,0 1,43 36L43,43A3,3 0,0 1,40 46L8,46A3,3 0,0 1,5 43L5,36A3,3 0,0 1,8 33z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="3"/>
<path android:fillAlpha="0.2" android:fillColor="#ffffff"
android:pathData="M8,20L40,20A3,3 0,0 1,43 23L43,30A3,3 0,0 1,40 33L8,33A3,3 0,0 1,5 30L5,23A3,3 0,0 1,8 20z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="3"/>
<path android:fillColor="#1976d2"
android:pathData="M8,21L40,21A3,2.7692 0,0 1,43 23.7693L43,42.2307A3,2.7692 0,0 1,40 45L8,45A3,2.7692 0,0 1,5 42.2307L5,23.7693A3,2.7692 0,0 1,8 21z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="3"/>
<path android:fillColor="#0d47a1" android:fillType="nonZero"
android:pathData="m24,26.75c-2.8807,0 -5.3198,1.9847 -6.0332,4.6504l3.2129,0C21.734,30.415 22.7748,29.75 24,29.75c1.8127,0 3.25,1.4373 3.25,3.25 0,1.8127 -1.4373,3.25 -3.25,3.25 -1.3074,0 -2.4113,-0.7527 -2.9297,-1.8496l-3.1543,0C18.5583,37.1661 21.0479,39.25 24,39.25c3.434,0 6.25,-2.816 6.25,-6.25 0,-3.434 -2.816,-6.25 -6.25,-6.25z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="3"/>
<path android:fillAlpha="0.40392157" android:fillColor="#00000000"
android:pathData="M24,33m-9.55,0a9.55,9.55 0,1 1,19.1 0a9.55,9.55 0,1 1,-19.1 0"
android:strokeColor="#0d47a1" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="1.89999998"/>
<path android:fillAlpha="0.2" android:fillColor="#263238"
android:pathData="M11,12.625a3.375,3.875 0,1 0,6.75 0a3.375,3.875 0,1 0,-6.75 0z"
android:strokeAlpha="0.69721115" android:strokeColor="#00000000"
android:strokeLineCap="round" android:strokeLineJoin="miter" android:strokeWidth="1.89999998"/>
<path android:fillColor="#ffffff"
android:pathData="M14.375,13.125m-3.375,0a3.375,3.375 0,1 1,6.75 0a3.375,3.375 0,1 1,-6.75 0"
android:strokeAlpha="0.69721115" android:strokeColor="#00000000"
android:strokeLineCap="round" android:strokeLineJoin="miter" android:strokeWidth="1.89999998"/>
<path android:fillAlpha="0.2" android:fillColor="#263238"
android:pathData="M30.5,12.625a3.375,3.875 0,1 0,6.75 0a3.375,3.875 0,1 0,-6.75 0z"
android:strokeAlpha="0.69721115" android:strokeColor="#00000000"
android:strokeLineCap="round" android:strokeLineJoin="miter" android:strokeWidth="1.89999998"/>
<path android:fillColor="#ffffff"
android:pathData="M33.875,13.125m-3.375,0a3.375,3.375 0,1 1,6.75 0a3.375,3.375 0,1 1,-6.75 0"
android:strokeAlpha="0.69721115" android:strokeColor="#00000000"
android:strokeLineCap="round" android:strokeLineJoin="miter" android:strokeWidth="1.89999998"/>
<path android:fillType="evenOdd"
android:pathData="m2.6135,1.2365a1.2501,1.2501 0,0 0,-1.0117 2.0293l3.6035,4.6641c-0.127,0.3331 -0.2031,0.6915 -0.2031,1.0703l0,4 0,2.8652 0,0.1348c0,1.662 1.338,3 3,3l32,0c1.662,0 3,-1.338 3,-3l0,-4 0,-2.8652 0,-0.1348c0,-0.3803 -0.0771,-0.74 -0.2051,-1.0742l3.6016,-4.6602a1.2501,1.2501 0,0 0,-1.0488 -2.0273,1.2501 1.2501,0 0,0 -0.9297,0.498l-3.4316,4.4414c-0.3102,-0.1079 -0.6384,-0.1777 -0.9863,-0.1777l-32,0c-0.3486,0 -0.6776,0.069 -0.9883,0.1777l-3.4336,-4.4414a1.2501,1.2501 0,0 0,-0.9668 -0.5zM8.0021,20.0002c-0.2077,0 -0.4098,0.021 -0.6055,0.061 -1.3695,0.2761 -2.3945,1.4698 -2.3945,2.9101l0,0.029 0,19.7793 0,0.029 0,0.1914c0,1.662 1.338,3 3,3l32,0c1.662,0 3,-1.338 3,-3l0,-20 0,-0.029c0,-1.4403 -1.025,-2.634 -2.3945,-2.9101 -0.1956,-0.039 -0.3977,-0.061 -0.6055,-0.061l-32,0z"
android:strokeColor="#00000000" android:strokeLineCap="round"
android:strokeLineJoin="miter" android:strokeWidth="2.5"/>
</vector>

View file

@ -0,0 +1,6 @@
<vector xmlns:tools="http://schemas.android.com/tools"
android:height="35dp" android:viewportHeight="438.549" android:tint="?attr/colorControlNormal"
android:viewportWidth="438.549" android:width="35dp" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="@android:color/white" android:pathData="M409.132,114.573c-19.608,-33.596 -46.205,-60.194 -79.798,-79.8C295.736,15.166 259.057,5.365 219.271,5.365c-39.781,0 -76.472,9.804 -110.063,29.408c-33.596,19.605 -60.192,46.204 -79.8,79.8C9.803,148.168 0,184.854 0,224.63c0,47.78 13.94,90.745 41.827,128.906c27.884,38.164 63.906,64.572 108.063,79.227c5.14,0.954 8.945,0.283 11.419,-1.996c2.475,-2.282 3.711,-5.14 3.711,-8.562c0,-0.571 -0.049,-5.708 -0.144,-15.417c-0.098,-9.709 -0.144,-18.179 -0.144,-25.406l-6.567,1.136c-4.187,0.767 -9.469,1.092 -15.846,1c-6.374,-0.089 -12.991,-0.757 -19.842,-1.999c-6.854,-1.231 -13.229,-4.086 -19.13,-8.559c-5.898,-4.473 -10.085,-10.328 -12.56,-17.556l-2.855,-6.57c-1.903,-4.374 -4.899,-9.233 -8.992,-14.559c-4.093,-5.331 -8.232,-8.945 -12.419,-10.848l-1.999,-1.431c-1.332,-0.951 -2.568,-2.098 -3.711,-3.429c-1.142,-1.331 -1.997,-2.663 -2.568,-3.997c-0.572,-1.335 -0.098,-2.43 1.427,-3.289c1.525,-0.859 4.281,-1.276 8.28,-1.276l5.708,0.853c3.807,0.763 8.516,3.042 14.133,6.851c5.614,3.806 10.229,8.754 13.846,14.842c4.38,7.806 9.657,13.754 15.846,17.847c6.184,4.093 12.419,6.136 18.699,6.136c6.28,0 11.704,-0.476 16.274,-1.423c4.565,-0.952 8.848,-2.383 12.847,-4.285c1.713,-12.758 6.377,-22.559 13.988,-29.41c-10.848,-1.14 -20.601,-2.857 -29.264,-5.14c-8.658,-2.286 -17.605,-5.996 -26.835,-11.14c-9.235,-5.137 -16.896,-11.516 -22.985,-19.126c-6.09,-7.614 -11.088,-17.61 -14.987,-29.979c-3.901,-12.374 -5.852,-26.648 -5.852,-42.826c0,-23.035 7.52,-42.637 22.557,-58.817c-7.044,-17.318 -6.379,-36.732 1.997,-58.24c5.52,-1.715 13.706,-0.428 24.554,3.853c10.85,4.283 18.794,7.952 23.84,10.994c5.046,3.041 9.089,5.618 12.135,7.708c17.705,-4.947 35.976,-7.421 54.818,-7.421s37.117,2.474 54.823,7.421l10.849,-6.849c7.419,-4.57 16.18,-8.758 26.262,-12.565c10.088,-3.805 17.802,-4.853 23.134,-3.138c8.562,21.509 9.325,40.922 2.279,58.24c15.036,16.18 22.559,35.787 22.559,58.817c0,16.178 -1.958,30.497 -5.853,42.966c-3.9,12.471 -8.941,22.457 -15.125,29.979c-6.191,7.521 -13.901,13.85 -23.131,18.986c-9.232,5.14 -18.182,8.85 -26.84,11.136c-8.662,2.286 -18.415,4.004 -29.263,5.146c9.894,8.562 14.842,22.077 14.842,40.539v60.237c0,3.422 1.19,6.279 3.572,8.562c2.379,2.279 6.136,2.95 11.276,1.995c44.163,-14.653 80.185,-41.062 108.068,-79.226c27.88,-38.161 41.825,-81.126 41.825,-128.906C438.536,184.851 428.728,148.168 409.132,114.573z"
tools:ignore="VectorPath" />
</vector>

View file

@ -0,0 +1,5 @@
<vector android:height="48dp" android:tint="?attr/colorControlNormal"
android:viewportHeight="24" android:viewportWidth="24"
android:width="48dp" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="@android:color/white" android:pathData="M12,7c2.76,0 5,2.24 5,5 0,0.65 -0.13,1.26 -0.36,1.83l2.92,2.92c1.51,-1.26 2.7,-2.89 3.43,-4.75 -1.73,-4.39 -6,-7.5 -11,-7.5 -1.4,0 -2.74,0.25 -3.98,0.7l2.16,2.16C10.74,7.13 11.35,7 12,7zM2,4.27l2.28,2.28 0.46,0.46C3.08,8.3 1.78,10.02 1,12c1.73,4.39 6,7.5 11,7.5 1.55,0 3.03,-0.3 4.38,-0.84l0.42,0.42L19.73,22 21,20.73 3.27,3 2,4.27zM7.53,9.8l1.55,1.55c-0.05,0.21 -0.08,0.43 -0.08,0.65 0,1.66 1.34,3 3,3 0.22,0 0.44,-0.03 0.65,-0.08l1.55,1.55c-0.67,0.33 -1.41,0.53 -2.2,0.53 -2.76,0 -5,-2.24 -5,-5 0,-0.79 0.2,-1.53 0.53,-2.2zM11.84,9.02l3.15,3.15 0.02,-0.16c0,-1.66 -1.34,-3 -3,-3l-0.17,0.01z"/>
</vector>

View file

@ -0,0 +1,10 @@
<vector xmlns:android="http://schemas.android.com/apk/res/android"
android:width="24dp"
android:height="24dp"
android:viewportWidth="24"
android:viewportHeight="24"
android:tint="?attr/colorControlNormal">
<path
android:fillColor="@android:color/white"
android:pathData="M20,8h-2.81c-0.45,-0.78 -1.07,-1.45 -1.82,-1.96L17,4.41 15.59,3l-2.17,2.17C12.96,5.06 12.49,5 12,5c-0.49,0 -0.96,0.06 -1.41,0.17L8.41,3 7,4.41l1.62,1.63C7.88,6.55 7.26,7.22 6.81,8L4,8v2h2.09c-0.05,0.33 -0.09,0.66 -0.09,1v1L4,12v2h2v1c0,0.34 0.04,0.67 0.09,1L4,16v2h2.81c1.04,1.79 2.97,3 5.19,3s4.15,-1.21 5.19,-3L20,18v-2h-2.09c0.05,-0.33 0.09,-0.66 0.09,-1v-1h2v-2h-2v-1c0,-0.34 -0.04,-0.67 -0.09,-1L20,10L20,8zM14,16h-4v-2h4v2zM14,12h-4v-2h4v2z"/>
</vector>

View file

@ -0,0 +1,10 @@
<vector xmlns:android="http://schemas.android.com/apk/res/android"
android:width="24dp"
android:height="24dp"
android:viewportWidth="24"
android:viewportHeight="24"
android:tint="?attr/colorControlNormal">
<path
android:fillColor="@android:color/white"
android:pathData="M12,2C6.48,2 2,6.48 2,12s4.48,10 10,10 10,-4.48 10,-10S17.52,2 12,2zM11,19.93c-3.95,-0.49 -7,-3.85 -7,-7.93 0,-0.62 0.08,-1.21 0.21,-1.79L9,15v1c0,1.1 0.9,2 2,2v1.93zM17.9,17.39c-0.26,-0.81 -1,-1.39 -1.9,-1.39h-1v-3c0,-0.55 -0.45,-1 -1,-1L8,12v-2h2c0.55,0 1,-0.45 1,-1L11,7h2c1.1,0 2,-0.9 2,-2v-0.41c2.93,1.19 5,4.06 5,7.41 0,2.08 -0.8,3.97 -2.1,5.39z"/>
</vector>

View file

@ -0,0 +1,4 @@
<vector android:height="35dp" android:viewportHeight="24"
android:viewportWidth="24" android:width="35dp" android:tint="?attr/colorControlNormal" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="@android:color/white" android:pathData="M1.22,0c-0.03,0.093 -0.06,0.185 -0.06,0.308v23.229c0,0.217 0.061,0.34 0.184,0.463l11.415,-12.093L1.22,0zM13.529,12.708l2.951,3.045 -4.213,2.4s-5.355,3.044 -8.308,4.739l9.57,-10.184zM14.33,11.877l3.166,3.292c0.496,-0.276 4.371,-2.492 4.924,-2.8 0.584,-0.338 0.525,-0.8 0.029,-1.046 -0.459,-0.255 -4.334,-2.475 -4.92,-2.835l-3.203,3.392 0.004,-0.003zM13.527,11.077l2.984,-3.169 -4.259,-2.431S5.309,1.505 2.999,0.179l10.53,10.898h-0.002z"/>
</vector>

View file

@ -0,0 +1,5 @@
<vector android:height="32dp" android:tint="?attr/colorControlNormal"
android:viewportHeight="24" android:viewportWidth="24"
android:width="32dp" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="@android:color/white" android:pathData="M20,2L4,2c-1.1,0 -1.99,0.9 -1.99,2L2,22l4,-4h14c1.1,0 2,-0.9 2,-2L22,4c0,-1.1 -0.9,-2 -2,-2zM6,14v-2.47l6.88,-6.88c0.2,-0.2 0.51,-0.2 0.71,0l1.77,1.77c0.2,0.2 0.2,0.51 0,0.71L8.47,14L6,14zM18,14h-7.5l2,-2L18,12v2z"/>
</vector>

View file

@ -0,0 +1,10 @@
<vector xmlns:android="http://schemas.android.com/apk/res/android"
android:width="24dp"
android:height="24dp"
android:viewportWidth="24"
android:viewportHeight="24"
android:tint="?attr/colorControlNormal">
<path
android:fillColor="@android:color/white"
android:pathData="M14,12c0,-1.1 -0.9,-2 -2,-2s-2,0.9 -2,2 0.9,2 2,2 2,-0.9 2,-2zM12,3c-4.97,0 -9,4.03 -9,9L0,12l4,4 4,-4L5,12c0,-3.87 3.13,-7 7,-7s7,3.13 7,7 -3.13,7 -7,7c-1.51,0 -2.91,-0.49 -4.06,-1.3l-1.42,1.44C8.04,20.3 9.94,21 12,21c4.97,0 9,-4.03 9,-9s-4.03,-9 -9,-9z"/>
</vector>

View file

@ -0,0 +1,5 @@
<vector android:height="36dp" android:tint="?attr/colorControlNormal"
android:viewportHeight="24" android:viewportWidth="24"
android:width="36dp" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="@android:color/white" android:pathData="M9,3L5,6.99h3L8,14h2L10,6.99h3L9,3zM16,17.01L16,10h-2v7.01h-3L15,21l4,-3.99h-3z"/>
</vector>

View file

@ -0,0 +1,5 @@
<vector android:height="36dp" android:tint="?attr/colorControlNormal"
android:viewportHeight="24" android:viewportWidth="24"
android:width="36dp" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="@android:color/white" android:pathData="M15.5,14h-0.79l-0.28,-0.27C15.41,12.59 16,11.11 16,9.5 16,5.91 13.09,3 9.5,3S3,5.91 3,9.5 5.91,16 9.5,16c1.61,0 3.09,-0.59 4.23,-1.57l0.27,0.28v0.79l5,4.99L20.49,19l-4.99,-5zM9.5,14C7.01,14 5,11.99 5,9.5S7.01,5 9.5,5 14,7.01 14,9.5 11.99,14 9.5,14z"/>
</vector>

View file

@ -0,0 +1,10 @@
<vector xmlns:android="http://schemas.android.com/apk/res/android"
android:width="24dp"
android:height="24dp"
android:viewportWidth="24"
android:viewportHeight="24"
android:tint="?attr/colorControlNormal">
<path
android:fillColor="@android:color/white"
android:pathData="M10,18h4v-2h-4v2zM3,6v2h18L21,6L3,6zM6,13h12v-2L6,11v2z"/>
</vector>

View file

@ -0,0 +1,5 @@
<!-- drawable/menu_open.xml -->
<vector xmlns:android="http://schemas.android.com/apk/res/android"
android:height="36dp" android:width="36dp" android:viewportWidth="24" android:viewportHeight="24">
<path android:fillColor="?attr/colorControlNormal" android:pathData="M21,15.61L19.59,17L14.58,12L19.59,7L21,8.39L17.44,12L21,15.61M3,6H16V8H3V6M3,13V11H13V13H3M3,18V16H16V18H3Z" />
</vector>

View file

@ -0,0 +1,5 @@
<vector android:height="30dp" android:tint="?attr/colorControlNormal"
android:viewportHeight="24" android:viewportWidth="24"
android:width="30dp" xmlns:android="http://schemas.android.com/apk/res/android">
<path android:fillColor="@android:color/white" android:pathData="M18,16.08c-0.76,0 -1.44,0.3 -1.96,0.77L8.91,12.7c0.05,-0.23 0.09,-0.46 0.09,-0.7s-0.04,-0.47 -0.09,-0.7l7.05,-4.11c0.54,0.5 1.25,0.81 2.04,0.81 1.66,0 3,-1.34 3,-3s-1.34,-3 -3,-3 -3,1.34 -3,3c0,0.24 0.04,0.47 0.09,0.7L8.04,9.81C7.5,9.31 6.79,9 6,9c-1.66,0 -3,1.34 -3,3s1.34,3 3,3c0.79,0 1.5,-0.31 2.04,-0.81l7.12,4.16c-0.05,0.21 -0.08,0.43 -0.08,0.65 0,1.61 1.31,2.92 2.92,2.92 1.61,0 2.92,-1.31 2.92,-2.92s-1.31,-2.92 -2.92,-2.92z"/>
</vector>

View file

@ -0,0 +1,10 @@
<vector xmlns:android="http://schemas.android.com/apk/res/android"
android:width="24dp"
android:height="24dp"
android:viewportWidth="24"
android:viewportHeight="24"
android:tint="?attr/colorControlNormal">
<path
android:fillColor="@android:color/white"
android:pathData="M11.5,2C6.81,2 3,5.81 3,10.5S6.81,19 11.5,19h0.5v3c4.86,-2.34 8,-7 8,-11.5C20,5.81 16.19,2 11.5,2zM12.5,16.5h-2v-2h2v2zM12.5,13h-2c0,-3.25 3,-3 3,-5 0,-1.1 -0.9,-2 -2,-2s-2,0.9 -2,2h-2c0,-2.21 1.79,-4 4,-4s4,1.79 4,4c0,2.5 -3,2.75 -3,5z"/>
</vector>

View file

@ -0,0 +1,10 @@
<vector xmlns:android="http://schemas.android.com/apk/res/android"
android:width="24dp"
android:height="24dp"
android:viewportWidth="24"
android:viewportHeight="24"
android:tint="?attr/colorControlNormal">
<path
android:fillColor="@android:color/white"
android:pathData="M21,10.12h-6.78l2.74,-2.82c-2.73,-2.7 -7.15,-2.8 -9.88,-0.1c-2.73,2.71 -2.73,7.08 0,9.79s7.15,2.71 9.88,0C18.32,15.65 19,14.08 19,12.1h2c0,1.98 -0.88,4.55 -2.64,6.29c-3.51,3.48 -9.21,3.48 -12.72,0c-3.5,-3.47 -3.53,-9.11 -0.02,-12.58s9.14,-3.47 12.65,0L21,3V10.12zM12.5,8v4.25l3.5,2.08l-0.72,1.21L11,13V8H12.5z"/>
</vector>

View file

@ -0,0 +1,95 @@
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_gravity="center" >
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginBottom="50sp"
android:layout_gravity="start"
android:orientation="vertical"
android:padding="16dp" >
<androidx.appcompat.widget.AppCompatImageView
android:layout_width="100dp"
android:layout_height="100dp"
android:layout_marginTop="15dp"
android:src="@mipmap/ic_launcher_foreground"
android:layout_gravity="center" />
<com.google.android.material.textview.MaterialTextView
android:id="@+id/app_title"
android:layout_width="match_parent"
android:layout_height="50dp"
android:padding="5dp"
android:gravity="center"
android:textSize="23sp"
android:textStyle="bold" />
<com.google.android.material.textview.MaterialTextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="10dp"
android:layout_marginBottom="15dp"
android:layout_marginEnd="10dp"
android:text="@string/app_summary"
android:gravity="center_horizontal"
android:textStyle="bold|italic"
android:textSize="15sp" />
<androidx.core.widget.NestedScrollView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingLeft="16dp"
android:paddingRight="16dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:gravity="center_vertical" >
<com.google.android.material.card.MaterialCardView
android:layout_width="match_parent"
android:layout_height="match_parent"
app:cardCornerRadius="15dp">
<com.google.android.material.textview.MaterialTextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="10dp"
android:text="@string/change_logs"
android:textStyle="bold"
android:gravity="center_horizontal"
android:textIsSelectable="true"
android:textSize="18sp" />
<com.google.android.material.textview.MaterialTextView
android:id="@+id/change_log"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="15dp"
android:padding="16dp"
android:gravity="start"
android:textIsSelectable="true"
android:textSize="15sp" />
</com.google.android.material.card.MaterialCardView>
</LinearLayout>
</androidx.core.widget.NestedScrollView>
</LinearLayout>
<com.google.android.material.textview.MaterialTextView
android:id="@+id/cancel_button"
android:layout_width="match_parent"
android:layout_height="50dp"
android:gravity="center_horizontal"
android:layout_alignParentBottom="true"
android:text="@string/cancel"
android:textStyle="bold"
android:textSize="18sp"
android:padding="10dp" />
</RelativeLayout>

View file

@ -0,0 +1,26 @@
<LinearLayout
android:id="@+id/layout_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_gravity="center"
android:orientation="vertical"
android:gravity="center" >
<ProgressBar
android:id="@+id/progress"
android:layout_width="175dp"
android:layout_height="20dp"
style="?android:attr/progressBarStyleHorizontal"
android:layout_gravity="center"
android:indeterminate="true"
android:paddingStart="15dp"
android:paddingEnd="15dp" />
<FrameLayout
android:id="@+id/fragment_container"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:visibility="gone" >
</FrameLayout>
</LinearLayout>

View file

@ -0,0 +1,38 @@
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<com.google.android.material.textview.MaterialTextView
android:id="@+id/unsupported"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:textSize="23sp"
android:textStyle="bold"
android:visibility="gone" />
<FrameLayout
android:id="@+id/fragment_container"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginBottom="75dp" />
</LinearLayout>
<com.google.android.material.bottomnavigation.BottomNavigationView
android:id="@+id/bottom_navigation"
android:layout_width="match_parent"
android:layout_height="75dp"
android:layout_alignParentBottom="true"
app:labelVisibilityMode="labeled"
app:menu="@menu/bottom_navigation"
android:layout_gravity="bottom"
android:visibility="gone" />
</RelativeLayout>

View file

@ -0,0 +1,84 @@
<androidx.core.widget.NestedScrollView
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto" >
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center"
android:orientation="vertical"
android:layout_margin="10dp"
android:gravity="center">
<androidx.appcompat.widget.AppCompatImageView
android:layout_width="250dp"
android:layout_height="250dp"
android:src="@mipmap/ic_launcher_foreground"
android:layout_gravity="center_horizontal"
android:gravity="center" />
<com.google.android.material.textview.MaterialTextView
android:id="@+id/warning"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="-35dp"
android:layout_gravity="center_horizontal"
android:text="@string/warning_summary"
android:textStyle="bold|italic"
android:layout_margin="10dp"
android:visibility="gone"
android:gravity="center"
android:textSize="17sp" />
<ProgressBar
android:id="@+id/progress"
android:layout_width="175dp"
android:layout_height="20dp"
style="?android:attr/progressBarStyleHorizontal"
android:progressBackgroundTint="?attr/colorAccent"
android:layout_gravity="center"
android:indeterminate="true"
android:paddingStart="15dp"
android:paddingEnd="15dp" />
<com.google.android.material.card.MaterialCardView
android:id="@+id/start_card"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:strokeColor="?attr/colorPrimary"
android:layout_margin="25dp"
app:cardCornerRadius="15dp"
android:visibility="gone" >
<androidx.appcompat.widget.LinearLayoutCompat
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:gravity="center" >
<com.google.android.material.textview.MaterialTextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="?attr/colorPrimary"
android:textStyle="bold|italic"
android:text="@string/start"
android:textAllCaps="true"
android:clickable="false"
android:textSize="16sp"
android:padding="10dp" />
<androidx.appcompat.widget.AppCompatImageButton
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:tint="?attr/colorPrimary"
android:src="@drawable/ic_back"
android:layout_marginEnd="5dp"
android:background="@null"
android:clickable="false"
android:rotation="180" />
</androidx.appcompat.widget.LinearLayoutCompat>
</com.google.android.material.card.MaterialCardView>
</LinearLayout>
</androidx.core.widget.NestedScrollView>

View file

@ -0,0 +1,45 @@
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<com.google.android.material.textview.MaterialTextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:textColor="?attr/colorPrimary"
android:text="@string/about"
android:textStyle="bold"
android:gravity="center"
android:textSize="20sp" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_vertical"
android:padding="10dp"
android:orientation="horizontal" >
<androidx.appcompat.widget.AppCompatImageView
android:layout_width="50dp"
android:layout_height="50dp"
android:src="@mipmap/ic_launcher_round"/>
<com.google.android.material.textview.MaterialTextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/about_summary"
android:textSize="15sp"
android:gravity="center"
android:textStyle="bold|italic" />
</LinearLayout>
<include layout="@layout/layout_recyclerview" />
</LinearLayout>
</androidx.constraintlayout.widget.ConstraintLayout>

View file

@ -0,0 +1,122 @@
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_vertical"
android:orientation="vertical" >
<FrameLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical" >
<com.google.android.material.textview.MaterialTextView
android:id="@+id/page_title"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginEnd="50dp"
android:layout_gravity="center_vertical"
android:textColor="?attr/colorPrimary"
android:gravity="center_horizontal"
android:textStyle="bold"
android:textSize="20sp" />
<androidx.appcompat.widget.AppCompatImageButton
android:id="@+id/search_button"
android:layout_width="40dp"
android:layout_height="40dp"
android:layout_marginEnd="50dp"
android:src="@drawable/ic_search"
android:layout_gravity="end|center_vertical"
android:tint="?attr/colorPrimary"
android:background="@null" />
<androidx.appcompat.widget.AppCompatImageButton
android:id="@+id/menu_button"
android:layout_width="40dp"
android:layout_height="40dp"
android:layout_marginEnd="10dp"
android:src="@drawable/ic_settings"
android:tint="?attr/colorPrimary"
android:layout_gravity="end"
android:background="@null" />
</FrameLayout>
<com.google.android.material.textview.MaterialTextView
android:id="@+id/about_summary"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginBottom="-15dp"
android:layout_marginTop="-15dp"
android:padding="15dp"
android:textSize="15sp"
android:gravity="center"
android:textStyle="bold|italic" />
<com.google.android.material.card.MaterialCardView
android:id="@+id/search_card"
android:layout_height="wrap_content"
android:layout_width="match_parent"
app:strokeColor="?attr/colorPrimary"
android:layout_marginStart="5dp"
android:layout_marginEnd="5dp"
app:cardCornerRadius="45dp" >
<androidx.appcompat.widget.AppCompatEditText
android:id="@+id/search_word"
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:drawableStart="@drawable/ic_search"
android:layout_gravity="center"
android:gravity="start|center"
android:layout_margin="10dp"
android:background="@null"
android:visibility="gone"
android:inputType="text" />
</com.google.android.material.card.MaterialCardView>
</LinearLayout>
<com.google.android.material.tabs.TabLayout
android:id="@+id/tab_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:visibility="gone"
app:tabGravity="fill"
app:tabMode="fixed" />
<include layout="@layout/layout_recyclerview" />
</LinearLayout>
<com.google.android.material.card.MaterialCardView
android:id="@+id/reverse_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentEnd="true"
android:layout_marginTop="150dp"
android:layout_marginEnd="10dp"
android:layout_gravity="end"
app:cardCornerRadius="10dp"
android:visibility="gone" >
<androidx.appcompat.widget.AppCompatImageButton
android:layout_width="40dp"
android:layout_height="40dp"
android:src="@drawable/ic_reverse"
android:tint="?attr/colorPrimary"
android:background="@null"
android:clickable="false" />
</com.google.android.material.card.MaterialCardView>
<include layout="@layout/progress_view_layout" />
</RelativeLayout>

View file

@ -0,0 +1,157 @@
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<LinearLayout
android:id="@+id/title_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:padding="15dp" >
<com.google.android.material.textview.MaterialTextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:text="@string/custom_scripts_tomatot"
android:textColor="?attr/colorPrimary"
android:textStyle="bold"
android:gravity="center"
android:textSize="20sp" />
<com.google.android.material.textview.MaterialTextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/custom_scripts_tomatot_Summary"
android:textSize="15sp"
android:gravity="center"
android:textStyle="bold|italic" />
</LinearLayout>
<com.google.android.material.card.MaterialCardView
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:cardUseCompatPadding="true"
app:cardCornerRadius="10dp"
android:padding="10dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:orientation="horizontal"
android:padding="10dp">
<com.google.android.material.textview.MaterialTextView
android:id="@+id/invisible"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:focusable="false"
android:textStyle="bold"
android:text="@string/invisible"
android:textSize="17sp" />
<com.google.android.material.textview.MaterialTextView
android:id="@+id/light"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:focusable="false"
android:textStyle="bold"
android:text="@string/light"
android:textSize="17sp" />
<com.google.android.material.textview.MaterialTextView
android:id="@+id/extreme"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:focusable="false"
android:textStyle="bold"
android:text="@string/extreme"
android:textSize="17sp" />
</LinearLayout>
<com.google.android.material.textview.MaterialTextView
android:id="@+id/deblaoter_status"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="10dp"
android:layout_marginEnd="10dp"
android:gravity="center"
android:textStyle="italic"
android:textSize="15sp" />
<FrameLayout
android:id="@+id/action_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:layout_margin="5dp">
<com.google.android.material.textview.MaterialTextView
android:id="@+id/action_message"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginEnd="30dp"
android:textStyle="bold"
android:textSize="15sp"
android:gravity="end" />
<androidx.appcompat.widget.AppCompatImageButton
android:id="@+id/action_icon"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_restore"
android:layout_gravity="end"
android:background="@null"
android:clickable="false" />
</FrameLayout>
</LinearLayout>
</com.google.android.material.card.MaterialCardView>
<com.google.android.material.card.MaterialCardView
android:id="@+id/apps_list_card"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:cardUseCompatPadding="true"
app:cardCornerRadius="10dp"
android:visibility="gone"
android:padding="10dp" >
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >
<com.google.android.material.textview.MaterialTextView
android:id="@+id/apps_list_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:focusable="false"
android:textStyle="bold"
android:text="@string/custom_scripts_tomatot_list"
android:textSize="17sp" />
<include layout="@layout/layout_recyclerview" />
</LinearLayout>
</com.google.android.material.card.MaterialCardView>
</LinearLayout>
<include layout="@layout/progress_view_layout" />
</androidx.constraintlayout.widget.ConstraintLayout>

View file

@ -0,0 +1,149 @@
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<LinearLayout
android:id="@+id/title_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:padding="15dp" >
<com.google.android.material.textview.MaterialTextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:text="@string/custom_scripts_uad"
android:tint="?attr/colorPrimary"
android:textStyle="bold"
android:gravity="center"
android:textSize="20sp" />
<com.google.android.material.textview.MaterialTextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/custom_scripts_uad_summary"
android:textSize="15sp"
android:gravity="center"
android:textStyle="bold|italic" />
</LinearLayout>
<com.google.android.material.card.MaterialCardView
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:cardUseCompatPadding="true"
app:cardCornerRadius="10dp"
android:padding="10dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >
<FrameLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="10dp" >
<com.google.android.material.textview.MaterialTextView
android:id="@+id/script_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:focusable="false"
android:textStyle="bold"
android:textSize="17sp" />
<androidx.appcompat.widget.AppCompatImageButton
android:id="@+id/select_icon"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_select"
android:tint="?attr/colorPrimary"
android:layout_gravity="end"
android:background="@null"
android:clickable="false" />
</FrameLayout>
<com.google.android.material.textview.MaterialTextView
android:id="@+id/deblaoter_status"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="10dp"
android:layout_marginEnd="10dp"
android:gravity="center"
android:textStyle="italic"
android:textSize="15sp" />
<FrameLayout
android:id="@+id/action_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:layout_margin="5dp">
<com.google.android.material.textview.MaterialTextView
android:id="@+id/action_message"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginEnd="30dp"
android:text="@string/apply"
android:textStyle="bold"
android:textSize="15sp"
android:gravity="end" />
<androidx.appcompat.widget.AppCompatImageButton
android:id="@+id/action_icon"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_restore"
android:layout_gravity="end"
android:background="@null"
android:clickable="false" />
</FrameLayout>
</LinearLayout>
</com.google.android.material.card.MaterialCardView>
<com.google.android.material.card.MaterialCardView
android:id="@+id/apps_list_card"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:cardUseCompatPadding="true"
app:cardCornerRadius="10dp"
android:padding="10dp" >
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >
<FrameLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:layout_margin="10dp" >
<com.google.android.material.textview.MaterialTextView
android:id="@+id/apps_list_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:focusable="false"
android:textStyle="bold"
android:text="@string/custom_scripts_tomatot_list"
android:textSize="17sp" />
</FrameLayout>
<include layout="@layout/layout_recyclerview" />
</LinearLayout>
</com.google.android.material.card.MaterialCardView>
</LinearLayout>
<include layout="@layout/progress_view_layout" />
</androidx.constraintlayout.widget.ConstraintLayout>

View file

@ -0,0 +1,25 @@
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/progress_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:visibility="gone"
android:gravity="center"
android:alpha="0.75" >
<ProgressBar
android:layout_width="100dp"
android:layout_height="100dp"
android:layout_gravity="center"/>
<com.google.android.material.textview.MaterialTextView
android:id="@+id/progress_text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_margin="20dp"
android:textStyle="bold"
android:gravity="center"
android:textSize="20sp" />
</LinearLayout>

View file

@ -0,0 +1,43 @@
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/rv_about"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_vertical"
android:layout_margin="10dp"
android:orientation="horizontal" >
<androidx.appcompat.widget.AppCompatImageButton
android:id="@+id/icon"
android:layout_width="25dp"
android:layout_height="25dp"
android:scaleType="fitCenter"
android:layout_gravity="center_vertical"
android:background="@null" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_vertical"
android:layout_gravity="center_vertical"
android:orientation="vertical"
android:layout_marginStart="10dp"
android:padding="5dp"
android:baselineAligned="false">
<com.google.android.material.textview.MaterialTextView
android:id="@+id/title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:focusable="false"
android:textStyle="bold"
android:textSize="17sp" />
<com.google.android.material.textview.MaterialTextView
android:id="@+id/description"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textStyle="bold|italic"
android:focusable="false" />
</LinearLayout>
</LinearLayout>

View file

@ -0,0 +1,101 @@
<?xml version="1.0" encoding="utf-8"?>
<com.google.android.material.card.MaterialCardView
android:layout_width="match_parent"
android:layout_height="wrap_content"
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
app:cardUseCompatPadding="true"
app:cardCornerRadius="10dp"
android:padding="10dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >
<com.google.android.material.textview.MaterialTextView
android:id="@+id/status_message"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textStyle="bold|italic"
android:visibility="gone"
android:textSize="14sp"
android:gravity="center"
android:padding="10dp" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="start|center_vertical"
android:orientation="horizontal"
android:padding="5dp">
<androidx.appcompat.widget.AppCompatImageButton
android:id="@+id/icon"
android:layout_width="35dp"
android:layout_height="35dp"
android:scaleType="fitCenter"
android:layout_gravity="center_vertical"
android:layout_marginEnd="10dp"
android:background="@null" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center_vertical"
android:layout_gravity="center_vertical"
android:orientation="vertical"
android:layout_marginEnd="35dp"
android:baselineAligned="false">
<com.google.android.material.textview.MaterialTextView
android:id="@+id/title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:focusable="true"
android:textStyle="bold"
android:textSize="17sp" />
<com.google.android.material.textview.MaterialTextView
android:id="@+id/packageName"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textStyle="bold"
android:focusable="true"
android:visibility="gone" />
<com.google.android.material.textview.MaterialTextView
android:id="@+id/description"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textStyle="bold|italic"
android:focusable="true" />
</LinearLayout>
</LinearLayout>
<FrameLayout
android:id="@+id/action_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:layout_margin="5dp">
<com.google.android.material.textview.MaterialTextView
android:id="@+id/action_message"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginEnd="30dp"
android:textStyle="bold"
android:textSize="15sp"
android:gravity="end" />
<androidx.appcompat.widget.AppCompatImageButton
android:id="@+id/action_icon"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="end"
android:background="@null"
android:clickable="false" />
</FrameLayout>
</LinearLayout>
</com.google.android.material.card.MaterialCardView>

View file

@ -0,0 +1,16 @@
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@+id/nav_active"
android:icon="@drawable/ic_active"
android:title="@string/active" />
<item
android:id="@+id/nav_inactive"
android:icon="@drawable/ic_inactive"
android:title="@string/inactive" />
<item
android:id="@+id/nav_about"
android:icon="@drawable/ic_about"
android:title="@string/about" />
</menu>

View file

@ -0,0 +1,5 @@
<?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
<background android:drawable="@color/ic_launcher_background"/>
<foreground android:drawable="@mipmap/ic_launcher_foreground"/>
</adaptive-icon>

View file

@ -0,0 +1,5 @@
<?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
<background android:drawable="@color/ic_launcher_background"/>
<foreground android:drawable="@mipmap/ic_launcher_foreground"/>
</adaptive-icon>

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.9 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 9.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 9 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 15 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 KiB

View file

@ -0,0 +1,108 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"حول"</string>
<string name="about_summary">"ـ De-Bloater هو تطبيق يستخدم الروت لإزالة التطبيقات الغير مرغوب فيها بدون تعديل النظام."</string>
<string name="active">"مفعل"</string>
<string name="active_app_summary">"كل التطبيقات موضحة بالاسفل. التطبيقات التي يتم اختيارها سيتم حذفها بعد إعادة التشغيل."</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"طبق"</string>
<string name="apps">"%s تطبيقات"</string>
<string name="apps_system">"/system"</string>
<string name="apps_vendor">"/vendor"</string>
<string name="apps_product">"/product"</string>
<string name="app_summary">"استخدم قوة Magisk لإزالة التطبيقات الغير مرغوب فيها بدون تعديل النظام"</string>
<string name="asus">"ASUS"</string>
<string name="backup">"نسخة احتياطية"</string>
<string name="backup_list_empty">"لم تقم بازالة اية تطبيقات بعد"</string>
<string name="backup_message">"تم انشاء النسخة الاحتياطية"</string>
<string name="carrier">"الناقل"</string>
<string name="change_logs">"سجل التغيرات"</string>
<string name="change_logs_summary">"لمشاهدة التغييرات الاخيره على هذا التطبيق"</string>
<string name="check_update">"بحث عن تحديث"</string>
<string name="check_update_summary">"بحث عن نسخ جديدة من De-Bloater"</string>
<string name="custom_scripts">"قوائم معدة مسبقا"</string>
<string name="custom_scripts_applied_message">"تم. التغيرات التي قمت بعملها سيتم تطبيقها بعد إعادة التشغيل."</string>
<string name="custom_scripts_tomatot">"Tomatot Debloater"</string>
<string name="custom_scripts_tomatot_list">"التطبيقات الآتية موجودة في القائمة المعدة مسبقا"</string>
<string name="custom_scripts_tomatot_extreme">"ازالة كل التطبيقات الموجودة في قائمة \"غير مرئي\" و \"خفيف\" بالإضافة إلي بعد تطبيقات جوجل التي ليست ضرورية ولكنها قد تكون مفيدة لبعض المستخدمين."</string>
<string name="custom_scripts_tomatot_invisible">"ازالة التطبيقات التي التي ليس لها أي وظيفة فقط."</string>
<string name="custom_scripts_tomatot_light">"ازالة كل التطبيقات الموجودة في القائمة الخفيفة مع ازالة بعض التطبيقات التي يندر استخدامها."</string>
<string name="custom_scripts_tomatot_Summary">"نسخة من القائمة المعدة مسبقاً بواسطة Tomatot لجهاز وان بلس 6. من فضلك قم باستخدامها علي مسؤوليتك الشخصية."</string>
<string name="custom_scripts_uad">"سكربت موحد"</string>
<string name="custom_scripts_uad_disabled">"هذه القائمة معطلة حاليا"</string>
<string name="custom_scripts_uad_enabled">"هذه القائمة مفعلة حاليا"</string>
<string name="custom_scripts_uad_summary">"نسخة من قائمة Universal Android De-Bloater المعدة مسبقا بواسطة W1nst0n بهدف تحسين البطارية والخصوصية عن طريق ازالة تطبيقات النظام الغير ضرورية والغامضة."</string>
<string name="donate">"دعم"</string>
<string name="donate_summary">"التبرع لدعم المطور"</string>
<string name="download_failed">"فشل التنزيل، أو الملف الذي تم تنزيله معطوب"</string>
<string name="downloading">"جار التحميل %s"</string>
<string name="extreme">"شديد"</string>
<string name="fdroid">"متجر F-Droid"</string>
<string name="fdroid_summary">"فتح F-Droid"</string>
<string name="google">"Google"</string>
<string name="get_it">"احصل عليها"</string>
<string name="huawei">"هواوي"</string>
<string name="inactive">"غير مفعل"</string>
<string name="inactive_apps_summary">"التطبيقات التي تم إزالتها موجودة في هذه القائمة"</string>
<string name="invisible">"غير مرئي"</string>
<string name="invite_friend">"دعوة الاصدقاء"</string>
<string name="invite_friend_summary">"دعوة صديق لتجربة De-Bloater"</string>
<string name="lg">"LG"</string>
<string name="licence">"التراخيص"</string>
<string name="licence_summary">"معاينة ترخيص GPL V3"</string>
<string name="light">"خفيف"</string>
<string name="miscellaneous">"متنوع"</string>
<string name="module_status_reset">"إعادة ضبط الاضافة"</string>
<string name="more_apps">"مزيد من التطبيقات"</string>
<string name="more_apps_summary">"تطبيقات أخري من المطور"</string>
<string name="motorola">"Motorola"</string>
<string name="name">"الاسم"</string>
<string name="nokia">"Nokia"</string>
<string name="no_internet">"من فضلك، تحقق من اتصالك بالانترنت"</string>
<string name="no_magisk">"لم يتم العثور علي Magisk"</string>
<string name="no_root">"بدون روت"</string>
<string name="oneplus">"OnePlus"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"الحزمة"</string>
<string name="press_back_exit">"اضغط زر \"رجوع\" مرة اخرى للخروج"</string>
<string name="rate_us">"تقييم التطبيق"</string>
<string name="rate_us_Summary">"تقييم التطبيق علي متجر بلاي"</string>
<string name="reboot">"إعادة تشغيل الجهاز"</string>
<string name="remove">"ازالة"</string>
<string name="report_issue">"الابلاغ عن مشكلة"</string>
<string name="report_issue_summary">"الابلاغ عن مشكلة علي GitHub"</string>
<string name="restore">"استعادة"</string>
<string name="restore_error_message">"لقد اخترت ملف نسخة احتياطية غير مدعوم. جار الإلغاء"</string>
<string name="restore_question">"استعادة من%s؟"</string>
<string name="restoring">"جار الاستعادة…"</string>
<string name="samsung">"Samsung"</string>
<string name="search_hint">"بحث…"</string>
<string name="share_app_message">"الحصول علي De-Bloater %s من"</string>
<string name="sony">"Sony"</string>
<string name="sort_by">"ترتيب التطبيقات حسب"</string>
<string name="source_code">"كود المصدر"</string>
<string name="source_code_summary">"زيارة صفحة GitHub"</string>
<string name="status_message_remove">"سيتم إزالته بعد إعادة التشغيل"</string>
<string name="status_message_restore">"سيتم استعادته بعد إعادة التشغيل"</string>
<string name="storage_access_denied">"تم رفض إذن التخزين"</string>
<string name="support">"المساعدة"</string>
<string name="support_summary">"زيارة مجموعة المساعدة"</string>
<string name="update_available">"تحديث جديد متاح
(%s)"</string>
<string name="updated_dialog">"مبروك. انت علي احدث اصدار من De-Bloater."</string>
<string name="version">"الإصدار"</string>
<string name="warning_summary">"ـ De-Bloater تطبيق قوي جدا. من فضلك استخدمه بحرص.
مطور التطبيق غير مسؤل عن أي ضرر يحدث لهاتفك بس الاستخدام الغير لائق."</string>
<string name="xiaomi">"Xiaomi"</string>
<string name="zte">"ZTE"</string>
<string name="apps_all">"الكل"</string>
<string name="start">"بدأ"</string>
<string name="backup_share_message">"من اجل إنشاء قاعدة بيانات من القوائم المعده مسبقا لكل المستخدمين، من فضلك قم بإرسال القائمة التي قمت بعملها المطور. شكرا لك.
البريد الالكتروني: smartpack.org@gmail.com
تليجرام: https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"لقد اخترت ملف نسخة احتياطية خاص بجهاز أو اصدار اندرويد اخر. هل تريد استعادته؟"</string>
<string name="share_profile">"مشاركة التفضيلات"</string>
<string name="uninstall">"الغاء التثبيت"</string>
<string name="updated_system_app_warning">"لقد قررت ازالة '%s' ، وهو تطبيق نظام تم تحديثه. لذلك إذا أردت أن تقوم بإزالة التطبيق نهائيا، قم بالغاء تثبيت التحديثات، وإلا سيكون التطبيق موجود كتطبيق مستخدم بعد إعادة التشغيل."</string>
</resources>

View file

@ -0,0 +1,108 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"Acerca de"</string>
<string name="about_summary">"De-Boater es una aplicación que usa el poder de Magisk para desinstalar aplicaciones no deseadas si la necesidad de un sistema."</string>
<string name="active">"Activo"</string>
<string name="active_app_summary">"La lista completa de aplicaciones se detalla a continuación. Las aplicaciones seleccionadas para ser removidas serán desinstaladas automáticamente después de reiniciar."</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"Aplicar"</string>
<string name="apps">"%s Aplicaciones"</string>
<string name="apps_system">"/system"</string>
<string name="apps_vendor">"/vendor"</string>
<string name="apps_product">"/product"</string>
<string name="app_summary">"Utilice el poder de Magisk para eliminar aplicaciones del sistema automáticamente "</string>
<string name="asus">"ASUS"</string>
<string name="backup">"Copia de seguridad"</string>
<string name="backup_list_empty">"No has eliminado ninguna aplicación aún"</string>
<string name="backup_message">"Los archivos de copia de seguridad se crean como %s"</string>
<string name="carrier">"Portador"</string>
<string name="change_logs">"Registros de cambios"</string>
<string name="change_logs_summary">"Ver cambios recientes en esta aplicación"</string>
<string name="check_update">"Comprobación de actualización"</string>
<string name="check_update_summary">"Busque nuevas versiones de De-Bloater"</string>
<string name="custom_scripts">"Scripts personalizados"</string>
<string name="custom_scripts_applied_message">"Todo listo. Los cambios se harán efectivos tras reiniciar."</string>
<string name="custom_scripts_tomatot">"Tomatot Debloater"</string>
<string name="custom_scripts_tomatot_list">"Las siguientes aplicaciones están incluidas en este script"</string>
<string name="custom_scripts_tomatot_extreme">"Elimina todas las aplicaciones incluidas en la lista invisible y ligera, así como algunas aplicaciones y funciones de Google que no son absolutamente necesarias pero que son útiles para algunas personas."</string>
<string name="custom_scripts_tomatot_invisible">"Eliminar únicamente las aplicaciones relacionadas con la telemetría o que no tengan ninguna función."</string>
<string name="custom_scripts_tomatot_light">"Elimina todas las aplicaciones incluidas en la lista invisible, así como algunas otras aplicaciones que rara vez utilizas."</string>
<string name="custom_scripts_tomatot_Summary">"Adaptación del script de debloater desarrollado originalmente por Tomatot para OnePlus 6. Úselo en otros dispositivos bajo su propia responsabilidad."</string>
<string name="custom_scripts_uad">"Universal Android Debloater"</string>
<string name="custom_scripts_uad_disabled">"Este script está actualmente deshabilitado"</string>
<string name="custom_scripts_uad_enabled">"Este script está habilitado actualmente"</string>
<string name="custom_scripts_uad_summary">"Adaptación del Universal Android Debloater desarrollado originalmente por W1nst0n con el objetivo de mejorar el rendimiento de la batería y la privacidad al eliminar aplicaciones del sistema innecesarias y oscuras."</string>
<string name="donate">"Donar"</string>
<string name="donate_summary">"Dona para apoyar el desarrollo"</string>
<string name="download_failed">"Parece que la descarga falló o se descargó un archivo dañado"</string>
<string name="downloading">"Descargando %s"</string>
<string name="extreme">"Extremo"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"Visita la página de F-Droid"</string>
<string name="google">"Google"</string>
<string name="get_it">"Consíguelo"</string>
<string name="huawei">"Huawei"</string>
<string name="inactive">"Inactivo"</string>
<string name="inactive_apps_summary">"En esta página se enumeran las aplicaciones que se desinflan sin sistema o que se asignan para eliminar."</string>
<string name="invisible">"Invisible"</string>
<string name="invite_friend">"Invitar amigos"</string>
<string name="invite_friend_summary">"Invita a un amigo a probar De-Bloater"</string>
<string name="lg">"LG"</string>
<string name="licence">"Licencia"</string>
<string name="licence_summary">"Ver GPL V3"</string>
<string name="light">"Luz"</string>
<string name="miscellaneous">"Misceláneas"</string>
<string name="module_status_reset">"Módulo de reinicio"</string>
<string name="more_apps">"Más aplicaciones"</string>
<string name="more_apps_summary">"Más aplicaciones del desarrollador"</string>
<string name="motorola">"Motorola"</string>
<string name="name">"Nombre"</string>
<string name="nokia">"Nokia"</string>
<string name="no_internet">"Por favor, compruebe su conexión a Internet."</string>
<string name="no_magisk">"Magisk no detectado"</string>
<string name="no_root">"Sin raíz"</string>
<string name="oneplus">"OnePlus"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"ID del paquete"</string>
<string name="press_back_exit">"Presione el botón \"Atrás\" nuevamente para salir"</string>
<string name="rate_us">"Calificanos"</string>
<string name="rate_us_Summary">"Califica y reseña De-Bloater en PlayStore"</string>
<string name="reboot">"Reiniciar el dispositivo"</string>
<string name="remove">"Eliminar"</string>
<string name="report_issue">"Informar de un problema"</string>
<string name="report_issue_summary">"Plantear un problema en GitHub"</string>
<string name="restore">"Restaurar"</string>
<string name="restore_error_message">"Has seleccionado un archivo de copia de seguridad no válido. Cancelando."</string>
<string name="restore_question">"¿Restaurar desde %s?"</string>
<string name="restoring">"Restaurando…"</string>
<string name="samsung">"Samsung"</string>
<string name="search_hint">"Buscar…"</string>
<string name="share_app_message">"Obtenga De-Bloater %s de"</string>
<string name="sony">"Sony"</string>
<string name="sort_by">"Ordenar aplicaciones por"</string>
<string name="source_code">"Código fuente"</string>
<string name="source_code_summary">"Visita la página de GitHub"</string>
<string name="status_message_remove">"Se eliminará después de reiniciar."</string>
<string name="status_message_restore">"Se restaurará después de reiniciar."</string>
<string name="storage_access_denied">"Permiso denegado para escribir en el almacenamiento"</string>
<string name="support">"Apoyo"</string>
<string name="support_summary">"Visita un grupo de apoyo"</string>
<string name="update_available">"Nueva actualización disponible
(%s)"</string>
<string name="updated_dialog">"¡Felicidades! Ya tienes una versión actualizada de De-Bloater."</string>
<string name="version">"Versión"</string>
<string name="warning_summary">"De-Bloater es demasiado potente. Úselo con cuidado. El desarrollador de esta aplicación no se responsabiliza si ocurre algún problema debido a un uso indebido."</string>
<string name="xiaomi">"Xiaomi"</string>
<string name="zte">"ZTE"</string>
<string name="apps_all">"Todo"</string>
<string name="start">"Comenzar"</string>
<string name="backup_share_message">"Para crear una base de datos de perfiles predefinidos para uso público, le rogamos que comparta los mejores perfiles de desbloater que haya creado con el desarrollador. Gracias.
Correo electrónico: smartpack.org@gmail.com
Telegram: https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"Has seleccionado una copia de seguridad creada para otro dispositivo o versión de Android. ¿Aún quieres restaurarla?"</string>
<string name="share_profile">"Compartir perfil"</string>
<string name="uninstall">"Desinstalar"</string>
<string name="updated_system_app_warning">"Has decidido desinstalar \"%s\", una aplicación del sistema que ya está actualizada. Por lo tanto, si realmente quieres eliminarla por completo, considera desinstalar también las actualizaciones locales. De lo contrario, la aplicación funcionará como una aplicación de usuario normal tras reiniciar."</string>
<string name="backup_list_as">"¿Cómo hacer una copia de seguridad del perfil del desblocador?"</string>
</resources>

View file

@ -0,0 +1,108 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<!-- zh-Hans (Simplified, generic) -->
<string name="about">"关于"</string>
<string name="about_summary">"De-Bloater是一个使用Magisk无系统地清除不需要的应用程序的app。"</string>
<string name="active">"使用中"</string>
<string name="active_app_summary">"整个应用程序列表详见下文。 被指定为删除的应用程序将在重启后无系统地被删除。"</string>
<string name="aosp">"Android开放源代码项目AOSP"</string>
<string name="apply">"应用"</string>
<string name="apps">"%s 个应用"</string>
<string name="apps_system">"/system"</string>
<string name="apps_vendor">"/vendor"</string>
<string name="apps_product">"/product"</string>
<string name="app_summary">"使用Magisk无系统地精简系统应用"</string>
<string name="asus">"华硕"</string>
<string name="backup">"备份"</string>
<string name="backup_list_empty">"你还未移除任何应用"</string>
<string name="backup_message">"备份文件将生成为 %s"</string>
<string name="carrier">"运营商"</string>
<string name="change_logs">"更新日志"</string>
<string name="change_logs_summary">"查看此应用的最近更新"</string>
<string name="check_update">"检查更新"</string>
<string name="check_update_summary">"检查De-Bloater新版本"</string>
<string name="custom_scripts">"自定义脚本"</string>
<string name="custom_scripts_applied_message">"已完成设置,重启后将生效。"</string>
<string name="custom_scripts_tomatot">"Tomatot Debloater"</string>
<string name="custom_scripts_tomatot_list">"此脚本包含以下应用"</string>
<string name="custom_scripts_tomatot_extreme">"删除不可见和轻列表中包含的所有应用程序以及一些并非绝对必要但对某些人有用的 Google Apps 和功能。"</string>
<string name="custom_scripts_tomatot_invisible">"仅删除与遥测有关或没有任何功能的应用程序。"</string>
<string name="custom_scripts_tomatot_light">"删除隐藏列表中包含的所有应用程序以及一些很少使用的其他应用程序。"</string>
<string name="custom_scripts_tomatot_Summary">"改编自最初由Tomatot为OnePlus 6开发的debloater脚本。 在其他设备上使用这个脚本时风险自负。"</string>
<string name="custom_scripts_uad">"通用 Android Debloater"</string>
<string name="custom_scripts_uad_disabled">"此脚本现在已禁用"</string>
<string name="custom_scripts_uad_enabled">"此脚本现在已启用"</string>
<string name="custom_scripts_uad_summary">"改编自由W1nst0n开发的通用Android Debloater目的是通过删除不必要的和不明显的系统应用程序来提高电池性能和隐私。"</string>
<string name="donate">"捐赠"</string>
<string name="donate_summary">"捐赠给此项目"</string>
<string name="download_failed">"下载似乎失败了,或者下载了一个损坏的文件。"</string>
<string name="downloading">"下载中 %s"</string>
<string name="extreme">"极端"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"访问F-Droid页面"</string>
<string name="google">"Google"</string>
<string name="get_it">"获取"</string>
<string name="huawei">"华为"</string>
<string name="inactive">"已禁用"</string>
<string name="inactive_apps_summary">"在这个页面中列出了被 systemless-ly 删除或被指定为删除的应用程序"</string>
<string name="invisible">"隐藏的"</string>
<string name="invite_friend">"分享"</string>
<string name="invite_friend_summary">"邀请朋友使用De-Bloater"</string>
<string name="lg">"LG"</string>
<string name="licence">"许可"</string>
<string name="licence_summary">"查看GPL V3"</string>
<string name="light">"明亮"</string>
<string name="miscellaneous">"其它"</string>
<string name="module_status_reset">"重置模块"</string>
<string name="more_apps">"更多应用"</string>
<string name="more_apps_summary">"来自开发者的更多应用"</string>
<string name="motorola">"摩托罗拉"</string>
<string name="name">"应用名"</string>
<string name="nokia">"诺基亚"</string>
<string name="no_internet">"请检查你的网络连接"</string>
<string name="no_magisk">"未检测到Magisk"</string>
<string name="no_root">"未Root"</string>
<string name="oneplus">"一加"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"包名"</string>
<string name="press_back_exit">"再次按返回键退出"</string>
<string name="rate_us">"评分"</string>
<string name="rate_us_Summary">"对PlayStore中的De Bloater进行评分或审核"</string>
<string name="reboot">"重启手机"</string>
<string name="remove">"移除"</string>
<string name="report_issue">"报告问题"</string>
<string name="report_issue_summary">"在GitHub上提交新问题"</string>
<string name="restore">"恢复"</string>
<string name="restore_error_message">"您选择的备份文件无效,已停止。"</string>
<string name="restore_question">"从 %s 恢复?"</string>
<string name="restoring">"恢复中"</string>
<string name="samsung">"三星"</string>
<string name="search_hint">"搜索…"</string>
<string name="share_app_message">"从 %s 获取 De-Bloater"</string>
<string name="sony">"索尼"</string>
<string name="sort_by">"排序"</string>
<string name="source_code">"源代码"</string>
<string name="source_code_summary">"访问GitHub页面"</string>
<string name="status_message_remove">"重启后将被移除"</string>
<string name="status_message_restore">"重启后将被恢复"</string>
<string name="storage_access_denied">"无法获取存储权限"</string>
<string name="support">"支持"</string>
<string name="support_summary">"访问支持群组"</string>
<string name="update_available">"有新版本可更新
(%s)"</string>
<string name="updated_dialog">"恭喜你的De-Bloater是最新版本"</string>
<string name="version">"版本"</string>
<string name="warning_summary">"De-Bloater太强大了。请谨慎使用。如果由于使用不当而发生错误此应用程序的开发人员不承担任何责任。"</string>
<string name="xiaomi">"小米"</string>
<string name="zte">"中兴"</string>
<string name="apps_all">"所以"</string>
<string name="start">"开始"</string>
<string name="backup_share_message">"为了创建供公众使用的预定义配置文件数据库,请考虑与 De-Bloater 的开发人员共享您制作的最佳 de-bloater 配置文件。谢谢。
Email: smartpack.org@gmail.com
Telegram: https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"你选择的备份文件是为其它不同的设备或安卓版本生成的,确定恢复?"</string>
<string name="share_profile">"分享配置"</string>
<string name="uninstall">"卸载"</string>
<string name="updated_system_app_warning">"您决定对已更新的系统应用程序“%s”进行去膨胀。因此如果您真的想完全删除此应用程序请考虑同时卸载本地更新。否则应用程序将在重新启动后像普通用户应用程序一样运行。"</string>
</resources>

View file

@ -0,0 +1,108 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"Über"</string>
<string name="about_summary">"De-Bloater ist eine Anwendung, die ohne Veränderung des Systems mit Hilfe der Magie von Magisk unerwünschte Apps entfernt."</string>
<string name="active">"Aktiv"</string>
<string name="active_app_summary">"Unten sind alle Apps aufgeführt. Alle zur Entfernung ausgewählten Apps werden nach Neustart ohne Veränderung des Systems entfernt!"</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"Anwenden"</string>
<string name="apps">"%s Anwendungen"</string>
<string name="apps_system">"/system"</string>
<string name="apps_vendor">"/vendor"</string>
<string name="apps_product">"/product"</string>
<string name="app_summary">"Nutze die Magie von Magisk um Systemanwendungen ohne Veränderung des Systems zu debloaten."</string>
<string name="asus">"ASUS"</string>
<string name="backup">"Sicherung"</string>
<string name="backup_list_empty">"Du hast noch keine Apps entfernt!"</string>
<string name="backup_message">"Sicherung unter %s gespeichert!"</string>
<string name="carrier">"Mobilanbieter"</string>
<string name="change_logs">"Change Log"</string>
<string name="change_logs_summary">"Aktuelle Änderungen dieser App"</string>
<string name="check_update">"Prüfung auf Updates"</string>
<string name="check_update_summary">"Schaue nach neuen Versionen von De-Bloater"</string>
<string name="custom_scripts">"Benutzerdefinierte Skripte"</string>
<string name="custom_scripts_applied_message">"Alles erledigt ! Die Änderungen greifen nach dem Neustart."</string>
<string name="custom_scripts_tomatot">"Tomat Debloater"</string>
<string name="custom_scripts_tomatot_list">"Folgende Apps sind in diesem Skript enthalten!"</string>
<string name="custom_scripts_tomatot_extreme">"Entferne alle Apps der \"Unsichtbar\" und \"Leicht\" Liste sowie einige Google Apps und Funktionen die nicht lebensnotwendig sind aber für einige Nutzer hilfreich sein könnten."</string>
<string name="custom_scripts_tomatot_invisible">"Entferne nur Apps die Messdaten übertragen oder keine weitere Funktion haben."</string>
<string name="custom_scripts_tomatot_light">"Entferne alle Apps in der \"Unsichtbar\" Liste sowie einige andere, wenig genutzte Apps."</string>
<string name="custom_scripts_tomatot_Summary">"Anpassung des Debloat-Skripts das ursprünglich von Tomatot für das OnePlus 6 entwickelt wurde. Verwendung auf anderen Geräten auf eigene Gefahr!"</string>
<string name="custom_scripts_uad">"Universal Android Debloater"</string>
<string name="custom_scripts_uad_disabled">"Dieses Skript ist im Moment deaktiviert!"</string>
<string name="custom_scripts_uad_enabled">"Dieses Skript ist im Moment aktiviert!"</string>
<string name="custom_scripts_uad_summary">"Anpassung des Universal Android Debloaters von W1nst0n mit dem Ziel die Akkulaufzeit und den Schutz der Nutzerdaten durch Entfernung von unnötigen oder unklaren Systemapps zu verbessern."</string>
<string name="donate">"Spende"</string>
<string name="donate_summary">"Spende um die Entwicklung zu unterstützen!"</string>
<string name="download_failed">"Es scheint der Download hat nicht funktioniert oder es wurde eine beschädigte Datei heruntergeladen!"</string>
<string name="downloading">"Lade %s herunter"</string>
<string name="extreme">"Extrem"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"Besuche die F-Droid Seite"</string>
<string name="google">"Google"</string>
<string name="get_it">"Hols dir"</string>
<string name="huawei">"Huawei"</string>
<string name="inactive">"Inaktiv"</string>
<string name="inactive_apps_summary">"Hier sind alle Apps aufgelistet, die debloated sind oder werden."</string>
<string name="invisible">"Unsichtbar"</string>
<string name="invite_friend">"Freunde einladen"</string>
<string name="invite_friend_summary">"Lade einen Freund ein um De-Bloater auszuprobieren"</string>
<string name="lg">"LG"</string>
<string name="licence">"Lizenz"</string>
<string name="licence_summary">"Siehe GPL V3"</string>
<string name="light">"Hell"</string>
<string name="miscellaneous">"Verschiedenes"</string>
<string name="module_status_reset">"Modul zurücksetzen"</string>
<string name="more_apps">"Mehr Apps"</string>
<string name="more_apps_summary">"Mehr Apps von diesem Entwickler"</string>
<string name="motorola">"Motorola"</string>
<string name="name">"Name"</string>
<string name="nokia">"Nokia"</string>
<string name="no_internet">"Bitte die Internetverbindung prüfen !"</string>
<string name="no_magisk">"Magisk nicht erkannt"</string>
<string name="no_root">"kein Root"</string>
<string name="oneplus">"Oneplus"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"Paket ID"</string>
<string name="press_back_exit">"Drücke \"Zurück\" nochmal zum Beenden!"</string>
<string name="rate_us">"Bewerte uns"</string>
<string name="rate_us_Summary">"Bewerte und/oder reviewe De-Bloater im PlayStore"</string>
<string name="reboot">"Gerät neu starten"</string>
<string name="remove">"Entfernen"</string>
<string name="report_issue">"Fehler melden"</string>
<string name="report_issue_summary">"Melde einen Fehler bei GitHub"</string>
<string name="restore">"Wiederherstellen"</string>
<string name="restore_error_message">"Abbruch wegen ungültiger Sicherungsdatei !"</string>
<string name="restore_question">"Wiederherstellen aus %s?"</string>
<string name="restoring">"Wiederherstellen…"</string>
<string name="samsung">"Samsung"</string>
<string name="search_hint">"Suche…"</string>
<string name="share_app_message">"Hole De-Bloater %s von"</string>
<string name="sony">"Sony"</string>
<string name="sort_by">"Sortieren nach"</string>
<string name="source_code">"Quellcode"</string>
<string name="source_code_summary">"Besuche die GitHub Seite"</string>
<string name="status_message_remove">"Wird nach Neustart entfernt"</string>
<string name="status_message_restore">"Wird nach Neustart wiederhergestellt"</string>
<string name="storage_access_denied">"Kein Schreibzugriff auf den Speicher!"</string>
<string name="support">"Support"</string>
<string name="support_summary">"Besuche die Supportgruppe"</string>
<string name="update_available">"Neues Update verfügbar!
(%s)"</string>
<string name="updated_dialog">"Glückwunsch, du hast die neuste Version von De-Bloater installiert!"</string>
<string name="version">"Version"</string>
<string name="warning_summary">"De-Bloater ist sehr mächtig ! Bitte nutze es vorsichtig und in eigener Verantwortung! Der Entwickler übernimmt keine Verantwortung für Folgen aus der Nutzung der App."</string>
<string name="xiaomi">"Xiaomi"</string>
<string name="zte">"ZTE"</string>
<string name="apps_all">"Alle"</string>
<string name="start">"Start"</string>
<string name="backup_share_message">"Um eine Datenbank mit vordefinierten Profilen für die öffentliche Nutzung zu erstellen, erwäge bitte, die besten von dir erstellten De-Bloater-Profile mit dem Entwickler von De-Bloater zu teilen. Danke!
E-Mail: smartpack.org@gmail.com
Telegram: https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"Du hast ein Backup ausgewählt welches für ein anderes Gerät oder eine andere Android Version gemacht wurde ausgewählt. Möchtest du es trotzdem wiederherstellen?"</string>
<string name="share_profile">"Profil Teilen"</string>
<string name="uninstall">"Deinstallieren"</string>
<string name="updated_system_app_warning">"Du hast sich entschieden, „%s“, eine bereits aktualisierte System-App, zu de-bloaten. Wenn du diese App wirklich vollständig entfernen möchtest, solltest du auch die lokalen Updates deinstallieren. Andernfalls verhält sich die App nach einem Neustart wie eine normale Benutzer-App."</string>
<string name="backup_list_as">"Sicherung des de-bloater Profil als?"</string>
</resources>

View file

@ -0,0 +1,108 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"Acerca de"</string>
<string name="about_summary">"De-Bloater es una aplicación que utiliza el poder de Magisk para eliminar las aplicaciones no deseadas ¡sin necesidad de recurrir al sistema!"</string>
<string name="active">"Activo"</string>
<string name="active_app_summary">"La lista completa de aplicaciones se detalla a continuación. Las aplicaciones que se asignan a eliminar serán desinstaladas sin problemas después de un reinicio."</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"Aplicar"</string>
<string name="apps">"%s Aplicaciones"</string>
<string name="apps_system">"/system"</string>
<string name="apps_vendor">"/vendor"</string>
<string name="apps_product">"/product"</string>
<string name="app_summary">"Usa el poder de Magisk para desinstalar aplicaciones de sistema."</string>
<string name="asus">"ASUS"</string>
<string name="backup">"Copia de seguridad"</string>
<string name="backup_list_empty">"Todavía no has removido ninguna app"</string>
<string name="backup_message">"Archivo de respaldo ha sido creado como %s"</string>
<string name="carrier">"Operador"</string>
<string name="change_logs">"Registro de cambios"</string>
<string name="change_logs_summary">"Ver cambios recientes en esta app."</string>
<string name="check_update">"Buscar actualizaciones."</string>
<string name="check_update_summary">"Buscar nuevas versiones de De-Bloater."</string>
<string name="custom_scripts">"Scripts personalizados."</string>
<string name="custom_scripts_applied_message">"Todo listo! Los cambios se harán después de un reinicio."</string>
<string name="custom_scripts_tomatot">"Tomatot Debloater"</string>
<string name="custom_scripts_tomatot_list">"Las siguientes apps están incluidas en este script!"</string>
<string name="custom_scripts_tomatot_extreme">"Remover todas las aplicaciones en la lista invisible y clara así como unas cuantas aplicaciones de Google y características no son necesarias pero son útiles para algunas personas."</string>
<string name="custom_scripts_tomatot_invisible">"Remover solo las aplicaciones que están relacionadas con la telemetría o que son inútiles."</string>
<string name="custom_scripts_tomatot_light">"Remover todas las aplicaciones incluidas en la lista invisible así como otras aplicaciones que rara vez se usan."</string>
<string name="custom_scripts_tomatot_Summary">"Adaptación del script de debloater fue originalmente desarrollado por Tomatot para el OnePlus 6! Por favor utiliza este script en otros dispositivos bajo tu propio riesgo."</string>
<string name="custom_scripts_uad">"Universal Android Debloater"</string>
<string name="custom_scripts_uad_disabled">"Este script está desactivado!"</string>
<string name="custom_scripts_uad_enabled">"Este script esta activado!"</string>
<string name="custom_scripts_uad_summary">"Adaptación de Universal Android Debloater desarrollado originalmente por W1nst0n con el objetivo de mejorar el rendimiento de la batería y la privacidad removiendo aplicaciones de sistema oscuras e inútiles."</string>
<string name="donate">"Donar"</string>
<string name="donate_summary">"Dona para apoyar el desarrollo!"</string>
<string name="download_failed">"Parece que la descarga ha fallado, o un archivo corrupto ha sido descargado!"</string>
<string name="downloading">"Descargando %s"</string>
<string name="extreme">"Extremo"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"Visita la página de F-Droid"</string>
<string name="google">"Google"</string>
<string name="get_it">"Conseguir"</string>
<string name="huawei">"Huawei"</string>
<string name="inactive">"Inactivo"</string>
<string name="inactive_apps_summary">"Las aplicaciones que han sido removidas o asignadas para removerse están listadas en esta página!"</string>
<string name="invisible">"Invisible"</string>
<string name="invite_friend">"Invitar a amigos"</string>
<string name="invite_friend_summary">"Invita a un amigo a usar De-Bloater"</string>
<string name="lg">"LG"</string>
<string name="licence">"Licencia"</string>
<string name="licence_summary">"Mirar GPL V3"</string>
<string name="light">"Claro"</string>
<string name="miscellaneous">"Misceláneo"</string>
<string name="module_status_reset">"Reiniciar módulo"</string>
<string name="more_apps">"Más apps"</string>
<string name="more_apps_summary">"Más apps del desarrollador"</string>
<string name="motorola">"Motorola"</string>
<string name="name">"Nombre"</string>
<string name="nokia">"Nokia"</string>
<string name="no_internet">"Por favor revisa tu conexión a internet!"</string>
<string name="no_magisk">"Magisk no encontrado"</string>
<string name="no_root">"Sin Root"</string>
<string name="oneplus">"OnePlus"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"ID del paquete"</string>
<string name="press_back_exit">"Presiona de nuevo el botón \"Atrás\" para salir!"</string>
<string name="rate_us">"Califícanos"</string>
<string name="rate_us_Summary">"Califica y/o reseña De-Bloater en la PlayStore"</string>
<string name="reboot">"Reiniciar dispositivo"</string>
<string name="remove">"Remover"</string>
<string name="report_issue">"Reportar un problema"</string>
<string name="report_issue_summary">"Reportar un problema en Github"</string>
<string name="restore">"Restaurar"</string>
<string name="restore_error_message">"Seleccionaste un archivo de respaldo inválido. Cancelando"</string>
<string name="restore_question">"Restaurar desde %s"</string>
<string name="restoring">"Restaurando…"</string>
<string name="samsung">"Samsung"</string>
<string name="search_hint">"Buscando…"</string>
<string name="share_app_message">"Obtener De-Bloater %s desde"</string>
<string name="sony">"Sony"</string>
<string name="sort_by">"Ordenar apps por"</string>
<string name="source_code">"Código fuente"</string>
<string name="source_code_summary">"Visitar página en GitHub"</string>
<string name="status_message_remove">"Será removida después de un reinicio"</string>
<string name="status_message_restore">"Será restaurada después de un reinicio"</string>
<string name="storage_access_denied">"Permiso de escribir en el almacenamiento denegado!"</string>
<string name="support">"Soporte"</string>
<string name="support_summary">"Visita el grupo de soporte"</string>
<string name="update_available">"Nueva actualización disponible!
(%s)"</string>
<string name="updated_dialog">"Felicidades! Estás usando la versión mas reciente de De-Bloater!"</string>
<string name="version">"Versión"</string>
<string name="warning_summary">"De-Bloater es muy poderoso! Por favor úsalo con cuidado. El desarrollador de esta aplicación no se hace responsable si algo sale mal debido a su uso incorrecto."</string>
<string name="xiaomi">"Xiaomi"</string>
<string name="zte">"ZTE"</string>
<string name="apps_all">"Todo"</string>
<string name="start">"Empezar"</string>
<string name="backup_share_message">"Para crear una base de datos de perfiles predefinidos para uso público, por favor considere compartir los mejores perfiles de de-bloater hechos por usted con el desarrollador de De-Bloater. Gracias.
Correo electrónico: smartpack.org@gmail.com
Telegram: https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"Ha seleccionado un archivo de copia de seguridad creado para un dispositivo o versión de Android diferente. ¿Aún desea restaurar?"</string>
<string name="share_profile">"Compartir perfil"</string>
<string name="uninstall">"Desinstalar"</string>
<string name="updated_system_app_warning">"Estás decidido a de-bloat '%s', una aplicación del sistema que ya está actualizada. Por lo tanto, si realmente desea eliminar esta aplicación por completo, considere desinstalar las actualizaciones locales también. De lo contrario, la aplicación se comportará como una aplicación de usuario normal después de un reinicio."</string>
<string name="backup_list_as">"¿Copia de seguridad del perfil de-bloater como?"</string>
</resources>

View file

@ -0,0 +1,103 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"Teave"</string>
<string name="about_summary">"De-Bloater on rakendus, mis kasutab turdvara eemaldamiseks Magiski systemless meetodi võimekust."</string>
<string name="active">"Aktiivsed"</string>
<string name="active_app_summary">"Täielik rakenduste nimekiri on allpool. Rakendused, mis on märgitud, eemaldatakse peale taaskäivitust systemless meetodit kasutades."</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"Rakenda"</string>
<string name="apps">"%s rakendust"</string>
<string name="app_summary">"Kasuta süsteemi turdvara eemaldamiseks Magiski systemless võimekust"</string>
<string name="asus">"ASUS"</string>
<string name="backup">"Varunda"</string>
<string name="backup_list_empty">"Te ei ole ühtegi rakendust eemaldanud"</string>
<string name="backup_message">"Taastefail on %s"</string>
<string name="carrier">"Teenusepakkuja"</string>
<string name="change_logs">"Logifailid"</string>
<string name="change_logs_summary">"Kuva rakenduse viimased muudatused"</string>
<string name="check_update">"Kontrolli värskendusi"</string>
<string name="check_update_summary">"Kontrolli uusi versioone De-Bloaterist"</string>
<string name="custom_scripts">"Kohandatud skriptid"</string>
<string name="custom_scripts_applied_message">"Valmis. Muudatused jõustuvad peale taaskäivitust."</string>
<string name="custom_scripts_tomatot">"Tomatoti Debloater"</string>
<string name="custom_scripts_tomatot_list">"Selles skriptis on alljärgnevad rakendused"</string>
<string name="custom_scripts_tomatot_extreme">"Eemalda kõik rakendused nähtamatust ja lahjast nimekirjast ning mõned Google'i rakendused ja lisad, mis pole vajalikud, kuid on kellelegi kasulikud."</string>
<string name="custom_scripts_tomatot_invisible">"Eemalda rakendused, mis on seotud andmete kogumisega või millel puuduvad ülesanded."</string>
<string name="custom_scripts_tomatot_light">"Eemalda kõik rakendused nähtamatust nimekirjast ja mõned rakendused mida kasutatakse harva. "</string>
<string name="custom_scripts_tomatot_Summary">"Kohandatud versioon debloateri skriptist, mille algselt Tomatot tegi selle OnePlus 6 jaoks. Skripti kasutamine teistes seadmetes on omal riisikol."</string>
<string name="custom_scripts_uad">"Universal Android Debloater"</string>
<string name="custom_scripts_uad_disabled">"See skript on keelatud"</string>
<string name="custom_scripts_uad_enabled">"See skript on lubatud"</string>
<string name="custom_scripts_uad_summary">"W1nst0ni loodud Universal Android Debloateri kohandatud variant, eesmärgiga parandada akukasutust ja turvalisust eemaldades mitte vajalikud ja segased süsteemirakendused."</string>
<string name="donate">"Anneta"</string>
<string name="donate_summary">"Anneta rakenduse loojatele"</string>
<string name="download_failed">"Kas allalaadimine ebaõnnestus või laeti alla vigane fail"</string>
<string name="downloading">"%s allalaadimine"</string>
<string name="extreme">"Äärmuslik"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"Külasta F-Droidi lehte"</string>
<string name="google">"Google"</string>
<string name="get_it">"Hangi"</string>
<string name="huawei">"Huawei"</string>
<string name="inactive">"Mitte aktiivsed"</string>
<string name="inactive_apps_summary">"Sellel lehel on rakendused, mis eemaldatakse systemless meetodil"</string>
<string name="invisible">"Nähtamatu"</string>
<string name="invite_friend">"Kutsu sõpru"</string>
<string name="invite_friend_summary">"Kutsu sõber De-Bloaterit proovima"</string>
<string name="lg">"LG"</string>
<string name="licence">"Litsents"</string>
<string name="licence_summary">"Kuva GPL V3"</string>
<string name="light">"Lahja"</string>
<string name="miscellaneous">"Mitmesugust"</string>
<string name="module_status_reset">"Lähtesta moodul"</string>
<string name="more_apps">"Rohkem rakendusi"</string>
<string name="more_apps_summary">"Rohkem rakendusi loojalt"</string>
<string name="motorola">"Motorola"</string>
<string name="name">"Nimi"</string>
<string name="nokia">"Nokia"</string>
<string name="no_internet">"Kontrolli interneti ühendust"</string>
<string name="no_magisk">"Magiski ei leitud"</string>
<string name="no_root">"Juurligipääs puudub"</string>
<string name="oneplus">"OnePlus"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"Paki ID"</string>
<string name="press_back_exit">"Väljumiseks vajuta veelkord \"Tagasi\" nuppu"</string>
<string name="rate_us">"Hinda"</string>
<string name="rate_us_Summary">"Hinda ja/või arvusta De-Bloaterit PlayStore'is"</string>
<string name="reboot">"Taaskäivita seade"</string>
<string name="remove">"Eemalda"</string>
<string name="report_issue">"Teata veast"</string>
<string name="report_issue_summary">"Teata veast Githubi vahendusel"</string>
<string name="restore">"Taasta"</string>
<string name="restore_error_message">"Valisite vale taastefaili. Katkestamine"</string>
<string name="restore_question">"Kas taastame failist %s?"</string>
<string name="restoring">"Taastamine…"</string>
<string name="samsung">"Samsung"</string>
<string name="search_hint">"Otsing…"</string>
<string name="share_app_message">"Hangi De-Bloater %s'ist"</string>
<string name="sony">"Sony"</string>
<string name="sort_by">"Sorteeri rakendused"</string>
<string name="source_code">"Lähtekood"</string>
<string name="source_code_summary">"Külasta Githubi lehte"</string>
<string name="status_message_remove">"Eemaldatakse peale taaskäivitust"</string>
<string name="status_message_restore">"Taastatakse peale taaskäivitust"</string>
<string name="storage_access_denied">"Andmekandjale kirjutamine on keelatud"</string>
<string name="support">"Tugi"</string>
<string name="support_summary">"Külasta tugirühma"</string>
<string name="update_available">"Värskendus on saadaval
(%s)"</string>
<string name="updated_dialog">"Õnnitleme. Teil on juba kõige uuem De-Bloateri versioon."</string>
<string name="version">"Versioon"</string>
<string name="warning_summary">"De-Bloater on väge täis. Palun kasutage teda ettevaatlikult. Selle rakenduse looja ei vastuta, kui valesti kasutades midagi läheb vussi."</string>
<string name="xiaomi">"Xiaomi"</string>
<string name="zte">"ZTE"</string>
<string name="apps_all">"Kõik"</string>
<string name="backup_share_message">"Et luua avalikuks kasutamiseks eelseadistatud profiilidega andmebaas, palun jagage, oma parimaid, de-bloateri profiile De-Bloateri loojaga. Aitäh.
E-post: smartpack.org@gmail.com
Telegram: https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"Valisite taastefaili, mis on loodud teise seadme või Androidi versiooni jaoks. Kas soovite ikkagi taastada?"</string>
<string name="share_profile">"Jaga profiili"</string>
<string name="uninstall">"Desinstalli"</string>
<string name="updated_system_app_warning">"Olete otsustanud eemaldada süsteemi rakenduse '%s'-i, mida on juba värskendatud. Kui te tõesti soovite selle rakenduse täielikult eemaldada, kaaluge ka värskenduste desinstalli. Vastasel korral käitub rakendus peale taaskäivitust, kui tavaline rakendus."</string>
</resources>

View file

@ -0,0 +1,107 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"À Propos"</string>
<string name="about_summary">"De-Bloater utilise la puissance de Magisk pour retirer les applications gênantes inutiles au système."</string>
<string name="active">"Actif"</string>
<string name="active_app_summary">"La liste complète des applications est détaillée ci-dessous. Les applications à supprimer seront retirées du système après redémarrage."</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"Ok"</string>
<string name="apps">"%s Applications"</string>
<string name="apps_system">"/Système"</string>
<string name="apps_vendor">"/Fabricant"</string>
<string name="apps_product">"/Produit"</string>
<string name="app_summary">"Utilise Magisk pour retirer les appli inutiles attachées au système"</string>
<string name="asus">"ASUS"</string>
<string name="backup">"Backup"</string>
<string name="backup_list_empty">"Aucune app n'a encore été supprimer"</string>
<string name="backup_message">"Fichiers Backup créé %s"</string>
<string name="carrier">"Fabricant"</string>
<string name="change_logs">"Modifs-list"</string>
<string name="change_logs_summary">"Voir les modifications récentes"</string>
<string name="check_update">"Vérifier MàJ"</string>
<string name="check_update_summary">"Recherche d'une nouvelle version"</string>
<string name="custom_scripts">"Scripts Perso"</string>
<string name="custom_scripts_applied_message">"Tout est fait. Refonte pris en compte après redémarrage."</string>
<string name="custom_scripts_tomatot">"Tomatot Debloater"</string>
<string name="custom_scripts_tomatot_list">"Apps incluses dans ce script"</string>
<string name="custom_scripts_tomatot_extreme">"Supprimez toutes les apps de la liste invisible et légère ainsi que quelques apps et fonctionnalités Google qui ne sont pas nécessaires mais utiles pour certains."</string>
<string name="custom_scripts_tomatot_invisible">"Supprimez uniquement les apps de télémétrie ou qui n'ont pas de fonction."</string>
<string name="custom_scripts_tomatot_light">"Supprimez toutes les apps de la liste invisible et certaines autres apps rarement utilisées."</string>
<string name="custom_scripts_tomatot_Summary">"Adaptation du script debloater développé par Tomatot pour OnePlus 6. Utiliser ce script sur d'autres appareils à vos risques et périls."</string>
<string name="custom_scripts_uad">"Debloater Android Universel"</string>
<string name="custom_scripts_uad_disabled">"Ce script est désactivé"</string>
<string name="custom_scripts_uad_enabled">"Ce script est activé"</string>
<string name="custom_scripts_uad_summary">"Adaptation de l'Universal Android Debloater développé par W1nst0n afin d'améliorer les perfs de la batterie et la confidentialité en supprimant les apps système inutiles et obscures."</string>
<string name="donate">"Donnation"</string>
<string name="donate_summary">"Faire un don pour soutenir le développement"</string>
<string name="download_failed">"Le téléchargement à échoué ou un fichier corrompu à été téléchargé"</string>
<string name="downloading">"Transfert %s"</string>
<string name="extreme">"Extrême"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"Visitez F-Droid"</string>
<string name="google">"Google"</string>
<string name="get_it">"Avoir"</string>
<string name="huawei">"Huawei"</string>
<string name="inactive">"Inactif"</string>
<string name="inactive_apps_summary">"Les applications débloquées ou affectées à la suppression sont répertoriées sur cette page"</string>
<string name="invisible">"Invisible"</string>
<string name="invite_friend">"Partager"</string>
<string name="invite_friend_summary">"Invite un ami à tester De-Bloater"</string>
<string name="lg">"LG"</string>
<string name="licence">"Licence"</string>
<string name="licence_summary">"Voir GPL V3"</string>
<string name="light">"Leger"</string>
<string name="miscellaneous">"Autres"</string>
<string name="module_status_reset">"Réinitialiser le Module"</string>
<string name="more_apps">"Plus"</string>
<string name="more_apps_summary">"Plus d'apps du développeur"</string>
<string name="motorola">"Motorola"</string>
<string name="name">"Nom"</string>
<string name="nokia">"Nokia"</string>
<string name="no_internet">"Vérifiez votre connexion internet"</string>
<string name="no_magisk">"Magisk non détecté"</string>
<string name="no_root">"Root absent"</string>
<string name="oneplus">"OnePlus"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"ID Paquet"</string>
<string name="press_back_exit">"Appuyez à nouveau sur \"Retour\" pour quitter"</string>
<string name="rate_us">"Évaluer"</string>
<string name="rate_us_Summary">"Évaluez/commentez De-Bloater sur PlayStore"</string>
<string name="reboot">"Redémarrage"</string>
<string name="remove">"Retirer"</string>
<string name="report_issue">"Signaler"</string>
<string name="report_issue_summary">"Relevé un souci sur GitHub"</string>
<string name="restore">"Restaurer"</string>
<string name="restore_error_message">"Sélection d'une sauvegarde non valide. Abandon"</string>
<string name="restore_question">"Restaurer de %s?"</string>
<string name="restoring">"Restauration"</string>
<string name="samsung">"Samsung"</string>
<string name="search_hint">"Recherche"</string>
<string name="share_app_message">"Obtenez De-Bloater %s"</string>
<string name="sony">"Sony"</string>
<string name="sort_by">"Trier par"</string>
<string name="source_code">"Code Source"</string>
<string name="source_code_summary">"Visitez GitHub"</string>
<string name="status_message_remove">"Sera effacé après redémarrage"</string>
<string name="status_message_restore">"Sera restauré après redémarrage"</string>
<string name="storage_access_denied">"Permission d'écrire le stockage refusée"</string>
<string name="support">"Support"</string>
<string name="support_summary">"groupe d'assistance"</string>
<string name="update_available">"Mise à jour disponible
(%s)"</string>
<string name="updated_dialog">"Félicitations. De-Bloater est déjà à jour."</string>
<string name="version">"Version"</string>
<string name="warning_summary">"Veuillez utiliser De-Bloater avec précaution. Le développeur de l'application n'assume aucune responsabilité si quelque chose de mal découle d'une utilisation inappropriée."</string>
<string name="xiaomi">"Xiaomi"</string>
<string name="zte">"ZTE"</string>
<string name="apps_all">"Tout"</string>
<string name="start">"Lancer"</string>
<string name="backup_share_message">"Afin de créer une base de données de profils prédéfinis pour un usage public, veuillez partager avec nous les meilleurs profils de de-bloater que vous avez créés. Merci.
Email: smartpack.org@gmail.com
Télégram : https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"Le fichier backup sélectionné a été créé pour un autre appareil ou une autre version d'Android. Continuer quand-même?"</string>
<string name="share_profile">"Partager le Profil"</string>
<string name="uninstall">"Désinstaller"</string>
<string name="updated_system_app_warning">"Vous avez décidé de supprimer '%s', une application système qui est déjà mise à jour. Pour supprimer complètement cette appli, veuillez désinstaller les mises à jour locales. Sinon, l'appli se comportera comme une appli utilisateur normale après le redémarrage."</string>
</resources>

View file

@ -0,0 +1,107 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"A propos"</string>
<string name="about_summary">"De-Bloater est une application utilisant la puissance de Magisk pour désactiver les applications indésirables du système !"</string>
<string name="active">"Active(s)"</string>
<string name="active_app_summary">"La liste complète des applications est détaillée ci-dessous. Les applications sélectionnées seront désactivées du système après un redémarrage!"</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"Appliquez"</string>
<string name="apps">"%s Applications"</string>
<string name="apps_system">"/system"</string>
<string name="apps_vendor">"/Fabriquant"</string>
<string name="apps_product">"/produit"</string>
<string name="app_summary">"Utilisez la puissance de Magisk pour désactiver les applications système"</string>
<string name="asus">"ASUS"</string>
<string name="backup">"sauvegarde"</string>
<string name="backup_list_empty">"Vous n'avez supprimé aucune application!"</string>
<string name="backup_message">"Les fichiers de sauvegarde seront créés en tant que %s!"</string>
<string name="carrier">"Opérateur"</string>
<string name="change_logs">"Changements"</string>
<string name="change_logs_summary">"Voir les changements récents"</string>
<string name="check_update">"Vérifier mise a jour"</string>
<string name="check_update_summary">"Vérification de nouvelles versions de De-Bloater"</string>
<string name="custom_scripts">"Scripts personnalisés"</string>
<string name="custom_scripts_applied_message">"Tout est fait! Les modifications seront effectuées après un redémarrage."</string>
<string name="custom_scripts_tomatot">"Tomatot Debloater"</string>
<string name="custom_scripts_tomatot_list">"Les applications suivantes sont incluses dans ce script!"</string>
<string name="custom_scripts_tomatot_extreme">"Supprimez toutes les applications incluses dans la liste invisible et légère ainsi que quelques applications et fonctionnalités de Google qui ne sont absolument pas nécessaires mais utiles pour certaines personnes."</string>
<string name="custom_scripts_tomatot_invisible">"Supprimez uniquement les applications liées à la télémétrie ou qui n'ont aucune fonction."</string>
<string name="custom_scripts_tomatot_light">"Supprimer toutes les applications incluses dans la liste invisible ainsi que certaines autres applications rarement utilisées."</string>
<string name="custom_scripts_tomatot_Summary">"Adaptation du script \"debloater\" développé à l'origine par Tomatot pour l'OnePlus 6. Utiliser ce script sur d'autres appareils à vos risques et périls."</string>
<string name="custom_scripts_uad">"Universal Android Debloater"</string>
<string name="custom_scripts_uad_disabled">"Ce script est actuellement désactivé !"</string>
<string name="custom_scripts_uad_enabled">"Ce script est actuellement activé !"</string>
<string name="custom_scripts_uad_summary">"Adaptation de \"Universal Android Debloater\" développé à l'origine par W1nst0n dans le but d'améliorer les performances de la batterie et la confidentialité des données en supprimant les applications système inutiles et/ou obscures."</string>
<string name="donate">"Donner"</string>
<string name="donate_summary">"Donner pour aider le développement !"</string>
<string name="download_failed">"Il semble que le téléchargement ait échoué ou qu'un fichier corrompu ait été téléchargé !"</string>
<string name="downloading">"Téléchargement de %s"</string>
<string name="extreme">"Extreme"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"Visiter la page de F-Droid"</string>
<string name="google">"Google"</string>
<string name="get_it">"L'obtenir"</string>
<string name="huawei">"Huawei"</string>
<string name="inactive">"Inactive(s) "</string>
<string name="inactive_apps_summary">"Les applications système qui sont désactivées ou les applications affectées pour désactivation sont répertoriées dans cette page !"</string>
<string name="invisible">"Invisible"</string>
<string name="invite_friend">"Inviter un ami"</string>
<string name="invite_friend_summary">"Inviter un ami pour essayer De-Bloater"</string>
<string name="lg">"LG"</string>
<string name="licence">"Licence"</string>
<string name="licence_summary">"Voir la GPL V3"</string>
<string name="light">"Clair"</string>
<string name="miscellaneous">"Divers"</string>
<string name="module_status_reset">"Réinitialiser le module"</string>
<string name="more_apps">"Plus d'applications"</string>
<string name="more_apps_summary">"Plus d'application du développeur"</string>
<string name="motorola">"Motorola"</string>
<string name="name">"Nom"</string>
<string name="nokia">"Nokia"</string>
<string name="no_internet">"Merci de vérifier votre connexion internet"</string>
<string name="no_magisk">"Magisk non détecté"</string>
<string name="no_root">"Pas de root"</string>
<string name="oneplus">"OnePlus"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"Identifiant du package"</string>
<string name="press_back_exit">"Appuyez de nouveau sur le bouton \"retour\" pour quitter"</string>
<string name="rate_us">"Notez nous"</string>
<string name="rate_us_Summary">"Noter ou/et évaluer De-Bloater dans le PlayStore"</string>
<string name="reboot">"Redémarrer l'appareil"</string>
<string name="remove">"Retirer"</string>
<string name="report_issue">"Signaler un problème"</string>
<string name="report_issue_summary">"Reporter un problème sur GitHub"</string>
<string name="restore">"Restaurer"</string>
<string name="restore_error_message">"Vous avez sélectionné un fichier de sauvegarde non valide. Abandon"</string>
<string name="restore_question">"Restaurer à partir de %s ?"</string>
<string name="restoring">"Restauration…"</string>
<string name="samsung">"Samsung"</string>
<string name="search_hint">"Recherche…"</string>
<string name="share_app_message">"Obtenir De-Bloater %s de"</string>
<string name="sony">"Sony"</string>
<string name="sort_by">"Trier les applications par"</string>
<string name="source_code">"Code source"</string>
<string name="source_code_summary">"Visiter la page GitHub"</string>
<string name="status_message_remove">"Sera retiré après un redémarrage"</string>
<string name="status_message_restore">"Sera restauré après un redémarrage"</string>
<string name="storage_access_denied">"Autorisation refusée pour l'écriture dans le stockage"</string>
<string name="support">"Soutien"</string>
<string name="support_summary">"Visiter le groupe de soutien"</string>
<string name="update_available">"Nouvelle mise à jour disponible
(%s)"</string>
<string name="updated_dialog">"Félicitations. Vous avez déjà une version à jour de De-Bloater."</string>
<string name="version">"Version"</string>
<string name="warning_summary">"De-Bloater est trop puissant. Veuillez l'utiliser avec précaution. Le développeur de cette application n'assume aucune responsabilité si quelque chose ne fonctionne plus en raison d'une utilisation inappropriée."</string>
<string name="xiaomi">"Xiaomi"</string>
<string name="zte">"ZTE"</string>
<string name="apps_all">"Tous"</string>
<string name="start">"Démarrer"</string>
<string name="backup_share_message">"Afin de créer une base de données de profils prédéfinis pour un usage public, veuillez envisager de partager vos meilleurs profils de de-bloater avec le développeur de De-Bloater. Merci.
Email: smartpack.org@gmail.com
Telegram: https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"Vous avez sélectionné un fichier de sauvegarde créé pour un autre appareil ou une autre version d'Android. Voulez-vous toujours restaurer cette sauvegarde ?"</string>
<string name="share_profile">"Partager le profil"</string>
<string name="uninstall">"Désinstaller"</string>
<string name="updated_system_app_warning">"Vous avez décidé de \"débloater\" '%s', une application système déjà mise à jour. Par conséquent, si vous voulez vraiment supprimer complètement cette application, veuillez également envisager de désinstaller les mises à jour locales. Sinon, l'application se comportera comme une application utilisateur normale après un redémarrage."</string>
</resources>

View file

@ -0,0 +1,108 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"Az alkalmazásról"</string>
<string name="about_summary">"A De-Bloater egy olyan applikáció, amely a Magisk erejével lehetővé teszi, hogy eltávolíts kéretlen applikációkat rendszertelenül."</string>
<string name="active">"Aktív"</string>
<string name="active_app_summary">"A teljes alkalmazáslista lejebb található. Az eltávolításra jelölt alkalmazások rendszertelenül törölve lesznek egy újraindítás után."</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"Alkalmaz"</string>
<string name="apps">"%s Applikációk"</string>
<string name="apps_system">"/system"</string>
<string name="apps_vendor">"/vendor"</string>
<string name="apps_product">"/product"</string>
<string name="app_summary">"Használd a Magisk erejét, hogy törölj rendszeralkalmazásokat rendszertelenül"</string>
<string name="asus">"ASUS"</string>
<string name="backup">"Biztonsági mentés"</string>
<string name="backup_list_empty">"Még nem távolítottál el egyetlen appot sem"</string>
<string name="backup_message">"Biztonsági mentés fájlok készítve mint %s"</string>
<string name="carrier">"Hordozó"</string>
<string name="change_logs">"Változási napló"</string>
<string name="change_logs_summary">"Legutóbbi változások mutatása"</string>
<string name="check_update">"Frissítés Keresése"</string>
<string name="check_update_summary">"Új De-Bloater verziók keresése"</string>
<string name="custom_scripts">"Egyéni Szkriptek"</string>
<string name="custom_scripts_applied_message">"Minden készen áll. A módosítások újraindítás után végbemennek."</string>
<string name="custom_scripts_tomatot">"Tomatot Debloater"</string>
<string name="custom_scripts_tomatot_list">"A szkript a következő appokat tartalmazza"</string>
<string name="custom_scripts_tomatot_extreme">"Minden a láthatatlan és lágy listában szereplő app eltávolítása, csakúgy mint pár Gooogle App és jellemző, amelyek nem abszolút létfontosságúak, de hasznosak lehetnek egyes embereknek."</string>
<string name="custom_scripts_tomatot_invisible">"Csak a telemetriával kapcsolatos vagy funkció nélküli appok eltávolítása."</string>
<string name="custom_scripts_tomatot_light">"Minden alkalmazás eltávolítása, amely szerepel a láthatatlan listában, csakúgy, mint néhány egyéb, ritkán használt app."</string>
<string name="custom_scripts_tomatot_Summary">"A Debloater szkript adaptációja, amit Tomatot készített OnePlus 6-ra. Kérlek, csak saját felelősségre használd ezt a szkriptet más eszközökön."</string>
<string name="custom_scripts_uad">"Universal Android Debloater"</string>
<string name="custom_scripts_uad_disabled">"Ez a szkript jelenleg ki van kapcsolva"</string>
<string name="custom_scripts_uad_enabled">"Ez a szkript jelenleg be van kapcsolva"</string>
<string name="custom_scripts_uad_summary">"Az Universal Android Debloater adaptációja, amit W1nst0n készített, az akkumlátor teljesítményének és az adatvédelem javításának céljából eltávolít felesleges és ismeretlen rendszeralkalmazásokat."</string>
<string name="donate">"Adományozás"</string>
<string name="donate_summary">"Adományozz, hogy támogasd a fejlesztést"</string>
<string name="download_failed">"Úgy néz ki, hogy a letöltés sikertelen volt, vagy egy korrupt fájl lett letöltve."</string>
<string name="downloading">"Letöltés %s"</string>
<string name="extreme">"Extrém"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"F-Droid oldal meglátogatása"</string>
<string name="google">"Google"</string>
<string name="get_it">"Megszerzés"</string>
<string name="huawei">"Huawei"</string>
<string name="inactive">"Inaktív"</string>
<string name="inactive_apps_summary">"A rendszertelenül eltávolított vagy eltávolításra jelölt alkalmazások ezen az oldalon vannak listázva."</string>
<string name="invisible">"Láthatatlan"</string>
<string name="invite_friend">"Barátok meghívása"</string>
<string name="invite_friend_summary">"Barát meghívása, hogy próbálja ki a De-Bloater-t"</string>
<string name="lg">"LG"</string>
<string name="licence">"Licensz"</string>
<string name="licence_summary">"GPL V3 megnézése"</string>
<string name="light">"Világos"</string>
<string name="miscellaneous">"Egyéb"</string>
<string name="module_status_reset">"Modul visszaállítása"</string>
<string name="more_apps">"További appok"</string>
<string name="more_apps_summary">"Több alkalmazás a fejlesztőtől"</string>
<string name="motorola">"Motorola"</string>
<string name="name">"Név"</string>
<string name="nokia">"Nokia"</string>
<string name="no_internet">"Kérlek ellenőrizd az internet-hozzáférésedet"</string>
<string name="no_magisk">"Magisk nem található"</string>
<string name="no_root">"Nincs root"</string>
<string name="oneplus">"OnePlus"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"Csomagazonosító"</string>
<string name="press_back_exit">"Nyomd meg újra a \"Vissza\" gombot a kilépéshez"</string>
<string name="rate_us">"Értékelj minket"</string>
<string name="rate_us_Summary">"Értékelés vagy hozzászólás írása a De-Bloater -hez a Play Áruházban"</string>
<string name="reboot">"Eszköz újraindítása"</string>
<string name="remove">"Eltávolítás"</string>
<string name="report_issue">"Probléma jelentése"</string>
<string name="report_issue_summary">"Problémára való felhívás GitHub-on"</string>
<string name="restore">"Visszaállítás"</string>
<string name="restore_error_message">"Rossz biztonsági mentés fájlt választottál. Megszakítás"</string>
<string name="restore_question">"Visszaállítás %s -ből?"</string>
<string name="restoring">"Visszaállítás…"</string>
<string name="samsung">"Samsung"</string>
<string name="search_hint">"Keresés…"</string>
<string name="share_app_message">"Debloater beszerzése innen: %s"</string>
<string name="sony">"Sony"</string>
<string name="sort_by">"Appok rendezése"</string>
<string name="source_code">"Forráskód"</string>
<string name="source_code_summary">"Github oldal meglátogatása"</string>
<string name="status_message_remove">"Újraindítás után eltávolításra kerül"</string>
<string name="status_message_restore">"Újraindítás után visszaállításra kerül"</string>
<string name="storage_access_denied">"A tárhely írásának engedélye meg lett tagadva"</string>
<string name="support">"Támogatás"</string>
<string name="support_summary">"Támogatói csoport meglátogatása"</string>
<string name="update_available">"Új frissítés elérhető
(%s)"</string>
<string name="updated_dialog">"Gratulálunk. Már így is a De-Bloater legújabb verziójának birtokában vagy."</string>
<string name="version">"Verzió"</string>
<string name="warning_summary">"A De-Bloater túl erős. Használd körültekintően. Ezen applikáció fejlesztője semmilyen felelősséget nem vállal a nem rendeltetésszerű használatból származó károkért."</string>
<string name="xiaomi">"Xiaomi"</string>
<string name="zte">"ZTE"</string>
<string name="apps_all">"Mind"</string>
<string name="start">"Start"</string>
<string name="backup_share_message">"Annak érdekében, hogy adatbázist készítsünk az előre meghatározott profilokról, közfelhasználásra, kérünk, gondold meg a legjobb De-Bloater profilok megosztását a De-Bloater fejlesztőjével. Köszönjük.
Email: smartpack.org@gmail.com
Telegram: https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"Egy másik eszköz vagy android verzió számára készített biztonsági mentés fájlt választottál ki. Még mindig vissza akarod azt állítani?"</string>
<string name="share_profile">"Profil Megosztása"</string>
<string name="uninstall">"Eltávolítás"</string>
<string name="updated_system_app_warning">"Elhatároztad, hogy törlöd '%s' -t, ami már frissített rendszeralkalmazás. Emiatt, ha tényleg azt akarod, hogy teljesen törlődjön ez az app, kérlek gondold meg a helyi frissítések eltávolítását is. Egyéb esetben ez az app normál felhasználói appként fog viselkedni újraindítás után. "</string>
<string name="backup_list_as">"De-Bloater profil biztonsági mentése másként?"</string>
</resources>

View file

@ -0,0 +1,107 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"Informazioni"</string>
<string name="about_summary">"De-Bloater è un'applicazione che sfrutta le capacità di Magisk per rimuovere le applicazioni indesiderate senza alterare il sistema."</string>
<string name="active">"Attive"</string>
<string name="active_app_summary">"L'intero elenco delle applicazioni è dettagliato di seguito. Le applicazioni marchiate per la rimozione verranno disinstallate senza alterare il sistema dopo un riavvio."</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"Applica"</string>
<string name="apps">"Applicazioni %s"</string>
<string name="apps_system">"/system"</string>
<string name="apps_vendor">"/vendor"</string>
<string name="apps_product">"/product"</string>
<string name="app_summary">"Sfrutta le capacità di Magisk per disinstallare le applicazioni di sistema senza alterare quest'ultimo"</string>
<string name="asus">"ASUS"</string>
<string name="backup">"Backup"</string>
<string name="backup_list_empty">"Non hai ancora rimosso alcuna app!"</string>
<string name="backup_message">"I file di backup vengono creati come %s!"</string>
<string name="carrier">"Produttore"</string>
<string name="change_logs">"Novità"</string>
<string name="change_logs_summary">"Visualizza le modifiche recenti su questa app"</string>
<string name="check_update">"Verifica aggiornamenti"</string>
<string name="check_update_summary">"Verifica la presenza di nuove versioni di De-Bloater"</string>
<string name="custom_scripts">"Script personalizzati"</string>
<string name="custom_scripts_applied_message">"Tutto fatto! Le modifiche verranno apportate dopo un riavvio."</string>
<string name="custom_scripts_tomatot">"Tomatot Debloater"</string>
<string name="custom_scripts_tomatot_list">"Le seguenti app sono incluse in questo script"</string>
<string name="custom_scripts_tomatot_extreme">"Rimuovi tutte le app incluse negli elenchi \"Invisibili\" e \"Leggero\", le app di Google e le funzionalità che non sono strettamente necessarie ma che potrebbero essere utili per alcune persone."</string>
<string name="custom_scripts_tomatot_invisible">"Rimuovi solo le app relative alla telemetria o che non hanno alcuna funzionalità."</string>
<string name="custom_scripts_tomatot_light">"Rimuovi tutte le app incluse nell'elenco \"Invisibili\" e altre app che vengono utilizzate raramente."</string>
<string name="custom_scripts_tomatot_Summary">"Adattamento dello script di rimozione originariamente sviluppato da Tomatot per OnePlus 6. Utilizza questo script su altri dispositivi a tuo rischio."</string>
<string name="custom_scripts_uad">"Universal Android Debloater"</string>
<string name="custom_scripts_uad_disabled">"Questo script è attualmente disabilitato"</string>
<string name="custom_scripts_uad_enabled">"Questo script è attualmente abilitato"</string>
<string name="custom_scripts_uad_summary">"Adattamento di Universal Android Debloater originariamente sviluppato da W1nst0n con l'obiettivo di migliorare le prestazioni della batteria e la privacy rimuovendo app di sistema non necessarie e oscure."</string>
<string name="donate">"Dona"</string>
<string name="donate_summary">"Dona per sostenere lo sviluppo"</string>
<string name="download_failed">"Sembra che il download non sia riuscito, o che sia stato scaricato un file danneggiato"</string>
<string name="downloading">"Scaricamento di %s"</string>
<string name="extreme">"Estremo"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"Visita la pagina di F-Droid"</string>
<string name="google">"Google"</string>
<string name="get_it">"Ottieni"</string>
<string name="huawei">"Huawei"</string>
<string name="inactive">"Non attive"</string>
<string name="inactive_apps_summary">"Le applicazioni rimosse senza alterare il sistema o che sono marchiate per la rimozione sono elencate in questa pagina"</string>
<string name="invisible">"Invisibili"</string>
<string name="invite_friend">"Invita gli amici"</string>
<string name="invite_friend_summary">"Invita un amico a provare De-Bloater"</string>
<string name="lg">"LG"</string>
<string name="licence">"Licenza"</string>
<string name="licence_summary">"Visualizza la licenza GPL V3"</string>
<string name="light">"Leggero"</string>
<string name="miscellaneous">"Varie"</string>
<string name="module_status_reset">"Ripristina modulo"</string>
<string name="more_apps">"Altre applicazioni"</string>
<string name="more_apps_summary">"Altre app dello sviluppatore"</string>
<string name="motorola">"Motorola"</string>
<string name="name">"Nome"</string>
<string name="nokia">"Nokia"</string>
<string name="no_internet">"Controlla la tua connessione a Internet"</string>
<string name="no_magisk">"Magisk non rilevato"</string>
<string name="no_root">"Permessi di root mancanti"</string>
<string name="oneplus">"OnePlus"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"ID pacchetto"</string>
<string name="press_back_exit">"Premi di nuovo il pulsante \"Indietro\" per uscire"</string>
<string name="rate_us">"Valutaci"</string>
<string name="rate_us_Summary">"Valuta o recensisci De-Bloater sul Play Store"</string>
<string name="reboot">"Riavvia il dispositivo"</string>
<string name="remove">"Rimuovi"</string>
<string name="report_issue">"Segnala problema"</string>
<string name="report_issue_summary">"Segnala un problema su GitHub"</string>
<string name="restore">"Ripristina"</string>
<string name="restore_error_message">"Hai selezionato un file di backup non valido. Operazione annullata"</string>
<string name="restore_question">"Ripristinare da %s?"</string>
<string name="restoring">"Ripristino in corso…"</string>
<string name="samsung">"Samsung"</string>
<string name="search_hint">"Ricerca…"</string>
<string name="share_app_message">"Ottieni De-Bloater %s da"</string>
<string name="sony">"Sony"</string>
<string name="sort_by">"Ordina app per"</string>
<string name="source_code">"Codice sorgente"</string>
<string name="source_code_summary">"Visita la pagina GitHub"</string>
<string name="status_message_remove">"Verrà rimossa dopo un riavvio"</string>
<string name="status_message_restore">"Verrà ripristinata dopo un riavvio"</string>
<string name="storage_access_denied">"Autorizzazione negata per la scrittura nell'archivio!"</string>
<string name="support">"Supporto"</string>
<string name="support_summary">"Visita il gruppo di supporto"</string>
<string name="update_available">"Nuovo aggiornamento disponibile
(%s)"</string>
<string name="updated_dialog">"Congratulazioni. Stai già usando una versione aggiornata di De-Bloater."</string>
<string name="version">"Versione"</string>
<string name="warning_summary">"De-Bloater è davvero potente. Usalo con attenzione. Lo sviluppatore di questa applicazione non si assume alcuna responsabilità se qualcosa va storto a causa di un uso non appropriato."</string>
<string name="xiaomi">"Xiaomi"</string>
<string name="zte">"ZTE"</string>
<string name="apps_all">"Tutte"</string>
<string name="start">"Avvia"</string>
<string name="backup_share_message">"Al fine di creare un database di profili predefiniti ad uso pubblico, ti suggeriamo di condividere i tuoi profili migliori con lo sviluppatore di De-Bloater. Grazie.
Email: smartpack.org@gmail.com
Telegram: https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"Hai selezionato un file di backup creato per un dispositivo o una versione di Android differente. Vuoi comunque procedere con il ripristino?"</string>
<string name="share_profile">"Condividi profilo"</string>
<string name="uninstall">"Disinstalla"</string>
<string name="updated_system_app_warning">"Hai deciso di rimuovere \"%s\", un'app di sistema che è già stata aggiornata. Se vuoi davvero rimuovere completamente questa app, dovresti disinstallare anche gli aggiornamenti locali. Altrimenti, dopo un riavvio l'app si comporterà come una normale app utente."</string>
</resources>

View file

@ -0,0 +1,108 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">アプリについて</string>
<string name="about_summary">De-Bloater は Magisk を利用してシステムレスにアプリを削除するツールです。</string>
<string name="active">有効</string>
<string name="active_app_summary">インストール済みのアプリ一覧\n選んだアプリは、再起動後システムレスに削除されます。</string>
<string name="aosp">AOSP</string>
<string name="apply">適用</string>
<string name="apps">%sなアプリ</string>
<string name="apps_all">すべて</string>
<string name="apps_system">/system</string>
<string name="apps_vendor">/vendor</string>
<string name="apps_product">/product</string>
<string name="app_summary">Magisk を利用してシステムレスにアプリを削除</string>
<string name="asus">ASUS</string>
<string name="backup">バックアップ</string>
<string name="backup_list_as">バックアップ名</string>
<string name="backup_list_empty">削除対象のアプリが選択されていません</string>
<string name="backup_message">バックアップを %s に作成しました</string>
<string name="backup_share_message">プロファイルの公開データベースの作成に協力してください。作成したプロファイルを De-Bloater の開発者と共有しませんか?ありがとうございます。
Email smartpack.org@gmail.com
Telegram https://t.me/smartpack_kmanager</string>
<string name="carrier">キャリア</string>
<string name="change_logs">更新履歴</string>
<string name="change_logs_summary">更新履歴を表示</string>
<string name="check_update">アップデートを確認</string>
<string name="check_update_summary">新しいバージョンを確認</string>
<string name="custom_scripts">カスタムスクリプト</string>
<string name="custom_scripts_applied_message">適用しました。変更は再起動後に反映されます</string>
<string name="custom_scripts_tomatot">Tomatot Debloater</string>
<string name="custom_scripts_tomatot_list">このスクリプトに含まれているアプリ一覧</string>
<string name="custom_scripts_tomatot_extreme">「Invisible」と「Light」に含まれる全アプリに加えて、必須ではないが人によっては使うかもしれない Google アプリや機能も削除</string>
<string name="custom_scripts_tomatot_invisible">テレメトリ関連や、機能を持たないアプリを削除</string>
<string name="custom_scripts_tomatot_light">「Invisible」に含まれる全アプリに加えて、ほとんど使われないアプリも削除</string>
<string name="custom_scripts_tomatot_Summary">Tomatot 氏が OnePlus 6 向けに作成したデブロートスクリプトの改変版です。他の機種で使う場合は自己責任でお願いします。</string>
<string name="custom_scripts_uad">Universal Android Debloater</string>
<string name="custom_scripts_uad_disabled">このスクリプトは現在無効です</string>
<string name="custom_scripts_uad_enabled">このスクリプトは現在有効です</string>
<string name="custom_scripts_uad_summary">W1nst0n 氏が作成した Universal Android Debloater の改変版です。不要で不明瞭なシステムアプリを削除することで、バッテリー性能とプライバシーを改善することを目的としています。</string>
<string name="donate">寄付</string>
<string name="donate_summary">寄付で開発を支援する</string>
<string name="download_failed">ダウンロードに失敗したか、ファイルが破損しています</string>
<string name="downloading">%s をダウンロード中</string>
<string name="extreme">Extreme</string>
<string name="fdroid">F-Droid</string>
<string name="fdroid_summary">F-Droid ページを開く</string>
<string name="google">Google</string>
<string name="get_it">適用</string>
<string name="huawei">Huawei</string>
<string name="inactive">無効</string>
<string name="inactive_apps_summary">システムレスに削除されたか、削除対象に選んだアプリ一覧</string>
<string name="invisible">Invisible</string>
<string name="invite_friend">友だちを招待</string>
<string name="invite_friend_summary">De-Bloater を勧める</string>
<string name="lg">LG</string>
<string name="licence">ライセンス</string>
<string name="licence_summary">GPL V3 ライセンスを表示</string>
<string name="light">Light</string>
<string name="miscellaneous">その他</string>
<string name="module_status_reset">初期状態に戻す</string>
<string name="more_apps">他のアプリ</string>
<string name="more_apps_summary">開発者の他のアプリ</string>
<string name="motorola">Motorola</string>
<string name="name">名前</string>
<string name="nokia">Nokia</string>
<string name="no_internet">インターネット接続を確認してください</string>
<string name="no_magisk">Magisk が検出されませんでした</string>
<string name="no_root">root 権限がありません</string>
<string name="oneplus">OnePlus</string>
<string name="oppo">Oppo</string>
<string name="package_id">パッケージ名</string>
<string name="press_back_exit">もう一度押すと終了します</string>
<string name="rate_us">アプリを評価</string>
<string name="rate_us_Summary">Play ストアで De-Bloater を評価・レビュー</string>
<string name="reboot">再起動</string>
<string name="remove">削除</string>
<string name="report_issue">問題を報告</string>
<string name="report_issue_summary">GitHub で問題を報告</string>
<string name="restore">復元</string>
<string name="restore_error_message">このバックアップは使えません。中断します</string>
<string name="restore_mismatch_message">異なる機種または Android バージョンで作成されたバックアップのようです。続行しますか?</string>
<string name="restore_question">%s から復元しますか?</string>
<string name="restoring">復元中</string>
<string name="samsung">Samsung</string>
<string name="search_hint">検索</string>
<string name="share_app_message">De-Bloater (%s) を入手しましょう:</string>
<string name="share_profile">プロファイルを共有</string>
<string name="sony">Sony</string>
<string name="sort_by">並べ替え</string>
<string name="source_code">ソースコード</string>
<string name="source_code_summary">GitHub でソースコードを見る</string>
<string name="start">開始</string>
<string name="status_message_remove">再起動後に削除</string>
<string name="status_message_restore">再起動後に復元</string>
<string name="storage_access_denied">ストレージへの書き込み権限がありません</string>
<string name="support">サポート</string>
<string name="support_summary">サポートページを開く</string>
<string name="uninstall">アンインストール</string>
<string name="update_available">新しいアップデートです
(%s)</string>
<string name="updated_dialog">De-Bloater は最新バージョンです</string>
<string name="updated_system_app_warning">「%s」は、更新済みのシステムアプリです。完全に削除したい場合は、アプリを出荷時の状態に戻してください。そうしない場合、再起動後にユーザーアプリとして残ります。</string>
<string name="version">バージョン</string>
<string name="warning_summary">De-Bloater は非常に強力なツールです。注意して使ってください。不適切に使って問題が発生した場合でも、開発者は一切の責任を負いません。</string>
<string name="xiaomi">Xiaomi</string>
<string name="zte">ZTE</string>
</resources>

View file

@ -0,0 +1,107 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"O"</string>
<string name="about_summary">"De-Bloater jest aplikacją używającą Magiska aby usunąć zbędne aplikacje."</string>
<string name="active">"Aktywny"</string>
<string name="active_app_summary">"Pełna lista aplikacji jest szczegółowo opisana poniżej. Aplikacje, które mają zostać usunięte zostaną sprzątnięte po ponownym uruchomieniu!"</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"Zastosuj"</string>
<string name="apps">"%s Aplikacje"</string>
<string name="apps_system">"/system"</string>
<string name="apps_vendor">"/vendor"</string>
<string name="apps_product">"/product"</string>
<string name="app_summary">"Użyj Magiska aby usunąć zbędne aplikacje."</string>
<string name="asus">"ASUS"</string>
<string name="backup">"Backup"</string>
<string name="backup_list_empty">"Nie usunąłeś jeszcze żadnych aplikacji!"</string>
<string name="backup_message">"Pliki do backupu stworzone jako %s!"</string>
<string name="carrier">"Operator"</string>
<string name="change_logs">"Change-log"</string>
<string name="change_logs_summary">"Zobacz ostatnie zmiany w aplikacji"</string>
<string name="check_update">"Sprawdź aktualizacje"</string>
<string name="check_update_summary">"Sprawdź czy są nowsze wersje De-Bloater"</string>
<string name="custom_scripts">"Własne skrypty"</string>
<string name="custom_scripts_applied_message">"Gotowe! Aby zatwierdzić zmiany uruchom ponownie telefon."</string>
<string name="custom_scripts_tomatot">"Tomatot Debloater"</string>
<string name="custom_scripts_tomatot_list">"W skrypcie znajdują się następujące aplikacje!"</string>
<string name="custom_scripts_tomatot_extreme">"Usuń wszystkie aplikacje znajdujące się na niewidocznej i lekkiej liście, oraz kilka aplikacji Google i funkcje które nie są absolutnie konieczne, ale przydatne dla niektórych osób."</string>
<string name="custom_scripts_tomatot_invisible">"Usuń tylko aplikacje związane z telemetrią lub nie posiadające żadnej funkcji. "</string>
<string name="custom_scripts_tomatot_light">"Usuń wszystkie aplikacje znajdujące się na niewidocznej liście, a także inne rzadko używane aplikacje."</string>
<string name="custom_scripts_tomatot_Summary">"Adaptacja skryptu debloater pierwotnie została opracowanego przez Tomatot dla OnePlus 6! Użycie tego skryptu na innych urządzeniach robisz na własne ryzyko."</string>
<string name="custom_scripts_uad">"Universalny Android Debloater"</string>
<string name="custom_scripts_uad_disabled">"Skrypt nieaktywny"</string>
<string name="custom_scripts_uad_enabled">"Skrypt aktywny"</string>
<string name="custom_scripts_uad_summary">"Adaptacja Universal Android Debloater pierwotnie opracowana przez W1nst0n w celu poprawy wydajności baterii i prywatności poprzez usunięcie niepotrzebnych i niejasnych aplikacji systemowych."</string>
<string name="donate">"Dotacja"</string>
<string name="donate_summary">"Wpłać na wsparcie rozwoju projektu!"</string>
<string name="download_failed">"Wygląda na to, że pobieranie nie powiodło się lub został pobrany uszkodzony plik! "</string>
<string name="downloading">"Pobrano %s"</string>
<string name="extreme">"Radykalny"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"Odwiedź stronę F-Droid"</string>
<string name="google">"Google"</string>
<string name="get_it">"Weź to"</string>
<string name="huawei">"Huawei"</string>
<string name="inactive">"Nieaktywne"</string>
<string name="inactive_apps_summary">"Na liście są aplikacje niesystemowe lub przypisane do usunięcia!"</string>
<string name="invisible">"Niewidoczne"</string>
<string name="invite_friend">"Zaproś przyjaciół"</string>
<string name="invite_friend_summary">"Zaproś przyjaciół by wypróbowali De-Bloater"</string>
<string name="lg">"LG"</string>
<string name="licence">"Licencja"</string>
<string name="licence_summary">"Zobacz licencję GPL V3"</string>
<string name="light">"Lekki"</string>
<string name="miscellaneous">"Różne"</string>
<string name="module_status_reset">"Resetuj aplikację"</string>
<string name="more_apps">"Więcej apliakcji"</string>
<string name="more_apps_summary">"Więcej aplikacji od dewelopera"</string>
<string name="motorola">"Motorola"</string>
<string name="name">"Nazwa"</string>
<string name="nokia">"Nokia"</string>
<string name="no_internet">"Sprawdź połączenie z internetem"</string>
<string name="no_magisk">"Nie wykryto Magisk"</string>
<string name="no_root">"Brak Roota"</string>
<string name="oneplus">"OnePlus"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"ID aplikacji"</string>
<string name="press_back_exit">"Naciśnij ponownie 'wstecz' aby wyjść!"</string>
<string name="rate_us">"Oceń nas"</string>
<string name="rate_us_Summary">"Oceń lub/i zrecenzuj De-Bloater w PlayStore"</string>
<string name="reboot">"Uruchom ponownie"</string>
<string name="remove">"Usuń"</string>
<string name="report_issue">"Zgłoś problem"</string>
<string name="report_issue_summary">"Zgłoś problem na GitHubie"</string>
<string name="restore">"Przywróc"</string>
<string name="restore_error_message">"Wybrałeś nieprawidłowy plik kopii zapasowej. Przerywam!"</string>
<string name="restore_question">"Przywrócono %s?"</string>
<string name="restoring">"Przywracanie…"</string>
<string name="samsung">"Samsung"</string>
<string name="search_hint">"Szukaj…"</string>
<string name="share_app_message">"Pobrano De-Bloater %s od"</string>
<string name="sony">"Sony"</string>
<string name="sort_by">"Sortuj aplikacje"</string>
<string name="source_code">"Kod źródłowy"</string>
<string name="source_code_summary">"Odwiedź stronę na Github"</string>
<string name="status_message_remove">"Zostanie usunięte po ponownym uruchomieniu"</string>
<string name="status_message_restore">"Zostanie przywrócone po ponownym uruchomieniu"</string>
<string name="storage_access_denied">"Brak pozwolenia na zapis w pamięci!"</string>
<string name="support">"Wsparcie"</string>
<string name="support_summary">"Odwiedź grupę wsparcia"</string>
<string name="update_available">"Dostępna nowa aktuaizacja!
(%s)"</string>
<string name="updated_dialog">"Gratulacje! Masz aktualną wersję De-Bloatera!"</string>
<string name="version">"Wersja"</string>
<string name="warning_summary">"De-Bloater to bardzo potężne narzędzie! Używaj go ostrożnie. Twórca tej aplikacji nie ponosi żadnej odpowiedzialności, jeśli by coś poszło nie tak z powodu jej niewłaściwego użycia!"</string>
<string name="xiaomi">"Xiaomi"</string>
<string name="zte">"ZTE"</string>
<string name="apps_all">"Wszystko"</string>
<string name="start">"Zacznij"</string>
<string name="backup_share_message">"Aby stworzyć bazę danych predefiniowanych profili do użytku publicznego, rozważ udostępnienie twórcom De-Bloater najlepszych profili de-bloater stworzonych przez Ciebie. Dziękuję!
E-mail: smartpack.org@gmail.com
Telegram: https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"Wybrano plik kopii zapasowej utworzony dla innego urządzenia lub wersji Androida. Czy nadal chcesz przywrócić?"</string>
<string name="share_profile">"Udostępnij profil"</string>
<string name="uninstall">"Odinstaluj"</string>
<string name="updated_system_app_warning">"Zdecydowałeś się na usunięcie aplikacji systemowej '%s', która jest już zaktualizowana. Jeśli chcesz całkowicie usunąć tę aplikację, rozważ również odinstalowanie lokalnych aktualizacji. W przeciwnym razie po ponownym uruchomieniu aplikacja będzie się zachowywać jak normalna aplikacja użytkownika!"</string>
</resources>

View file

@ -0,0 +1,107 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"Sobre"</string>
<string name="about_summary">"De-Bloater é um aplicativo que se ultiliza do Magisk para \"remover\" aplicativo do sistema indesejados."</string>
<string name="active">"Ativo"</string>
<string name="active_app_summary">"A lista de aplicativos esta abaixo. Os aplicativos selecionados para remoção serão debloateados do sistema após uma reinicialização."</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"Aplicar"</string>
<string name="apps">"%s Aplicativos"</string>
<string name="apps_system">"/system"</string>
<string name="apps_vendor">"/vendor"</string>
<string name="apps_product">"/product"</string>
<string name="app_summary">"Use o poder do Magisk para diminuir o volume de aplicativos do sistema "</string>
<string name="asus">"Asus"</string>
<string name="backup">"Cópia de segurança"</string>
<string name="backup_list_empty">"Você ainda não removeu nenhum aplicativo!"</string>
<string name="backup_message">"Os arquivos de backup são criados como %s!"</string>
<string name="carrier">"Operadora"</string>
<string name="change_logs">"Logs de alterações"</string>
<string name="change_logs_summary">"Ver mudanças recentes neste app"</string>
<string name="check_update">"Checar Atualizações"</string>
<string name="check_update_summary">"Checar por novas versões do De-Bloater"</string>
<string name="custom_scripts">"Scripts Personalizados"</string>
<string name="custom_scripts_applied_message">"Pronto. As alterações terão efeito após o reinício."</string>
<string name="custom_scripts_tomatot">"Debloater Tomatot"</string>
<string name="custom_scripts_tomatot_list">"Os seguintes aplicativos estão inclusos no script"</string>
<string name="custom_scripts_tomatot_extreme">"Remove todos os aplicativos inclusos na lista oculta e leve, como alguns recursos e apps do Google que não são tão necessários, mas úteis para algumas pessoas."</string>
<string name="custom_scripts_tomatot_invisible">"Remove apenas aplicativos ligados à telemetria ou sem nenhuma função."</string>
<string name="custom_scripts_tomatot_light">"Remove todos os aplicativos inclusos na lista oculta e alguns outros raramente usados."</string>
<string name="custom_scripts_tomatot_Summary">"Adaptação do script debloater originalmente desenvolvido pela Tomatot para OnePlus 6. Use este script em outros dispositivos por sua conta e risco."</string>
<string name="custom_scripts_uad">"Universal Android Debloater"</string>
<string name="custom_scripts_uad_disabled">"O script está inativo no momento"</string>
<string name="custom_scripts_uad_enabled">"O script está ativo no momento"</string>
<string name="custom_scripts_uad_summary">"Adaptação do UAD, originalmente desenvolvido pela W1nst0n com o objetivo de melhorar o desempenho da bateria e a privacidade ao remover aplicativos ocultos e desnecessários."</string>
<string name="donate">"Doação"</string>
<string name="donate_summary">"Doe para dar suporte ao desenvolvimento"</string>
<string name="download_failed">"Parece que o download falhou, ou o arquivo baixado está corrompido"</string>
<string name="downloading">"Baixando %s"</string>
<string name="extreme">"Extremo"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"Visite a página F-Droid do app"</string>
<string name="google">"Google"</string>
<string name="get_it">"Pegue"</string>
<string name="huawei">"Huawei"</string>
<string name="inactive">"Inativo"</string>
<string name="inactive_apps_summary">"Os apps que serão usados para o Debloated do sistema ou atribuídos para remoção estão listados nesta página"</string>
<string name="invisible">"Invisível"</string>
<string name="invite_friend">"Convidar os amigos"</string>
<string name="invite_friend_summary">"Convide um amigo ara testar o De-Bloater"</string>
<string name="lg">"LG"</string>
<string name="licence">"Licença"</string>
<string name="licence_summary">"Ver GPL V3"</string>
<string name="light">"Claro"</string>
<string name="miscellaneous">"Diversos"</string>
<string name="module_status_reset">"Resetar Módulo"</string>
<string name="more_apps">"Mais Apps"</string>
<string name="more_apps_summary">"Mais apps do desenvolvedor"</string>
<string name="motorola">"Motorola"</string>
<string name="name">"Nome"</string>
<string name="nokia">"Nokia"</string>
<string name="no_internet">"Por favor cheque sua conexão de internet"</string>
<string name="no_magisk">"Magisk não detectado"</string>
<string name="no_root">"Sem Root"</string>
<string name="oneplus">"OnePlus"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"ID do pacote"</string>
<string name="press_back_exit">"Aperte \"Voltar\" novamente para sair"</string>
<string name="rate_us">"Nos Avalie"</string>
<string name="rate_us_Summary">"Avalie e/ou analise o De-Bloater na PlayStore"</string>
<string name="reboot">"Reiniciar Dispositivo"</string>
<string name="remove">"Remover"</string>
<string name="report_issue">"Relatar Problemas"</string>
<string name="report_issue_summary">"Relatar um problema no GitHub"</string>
<string name="restore">"Restaurar"</string>
<string name="restore_error_message">"Você selecionou um backup inválido. Cancelando"</string>
<string name="restore_question">"Restarurar de %s?"</string>
<string name="restoring">"Restaurando…"</string>
<string name="samsung">"Samsung"</string>
<string name="search_hint">"Procurar…"</string>
<string name="share_app_message">"Obter De-Bloater de %s"</string>
<string name="sony">"Sony"</string>
<string name="sort_by">"Classificar aplicativos por"</string>
<string name="source_code">"Código fonte"</string>
<string name="source_code_summary">"Visite a nossa página no GitHub"</string>
<string name="status_message_remove">"Será removido após uma reinicialização"</string>
<string name="status_message_restore">"Será restaurado após uma reinicialização"</string>
<string name="storage_access_denied">"Permissão negada para gravar no armazenamento"</string>
<string name="support">"Suporte"</string>
<string name="support_summary">"Visite o grupo de suporte"</string>
<string name="update_available">"Nova atualização disponível
(%s)"</string>
<string name="updated_dialog">"Parabéns. Você já tem uma versão atualizada do De-Bloater"</string>
<string name="version">"Versão"</string>
<string name="warning_summary">"O De-Bloater é poderoso. Por favor, use com cuidado. O desenvolvedor deste aplicativo não irá assumir qualquer responsabilidade se algo der errado devido ao uso inadequado."</string>
<string name="xiaomi">"Xiaomi"</string>
<string name="zte">"ZTE"</string>
<string name="apps_all">"Todos"</string>
<string name="start">"Começar"</string>
<string name="backup_share_message">"Para a criação de um banco de dados de perfis pré-definidos público, considere compartilhar os melhores perfis de de-bloater feitos por você com o desenvolvedor do De-Bloater.
E-mail: smartpack.org@gmail.com
Telegrama: https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"Você selecionou um arquivo de backup criado para outro dispositivo ou versão do Android. Ainda deseja restaurar?"</string>
<string name="share_profile">"Compartilhar Perfil"</string>
<string name="uninstall">"Desinstalar"</string>
<string name="updated_system_app_warning">"Você decidiu remover o '%s', um aplicativo do sistema que já está atualizado. Portanto, se você realmente deseja remover este aplicativo completamente, considere desinstalar também as atualizações locais. Caso contrário, o aplicativo se comportará como um aplicativo de usuário normal após uma reinicialização."</string>
</resources>

View file

@ -0,0 +1,107 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"О программе"</string>
<string name="about_summary">"De-Bloater - это приложение, использующее возможности Magisk для удаления нежелательных приложений несистемно."</string>
<string name="active">"Активные"</string>
<string name="active_app_summary">"Полный список приложений подробно описан ниже. Приложения, назначенные на удаление, после перезагрузки будут удалены несистемно."</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"Применить"</string>
<string name="apps">"%s приложений"</string>
<string name="apps_system">"/system"</string>
<string name="apps_vendor">"/vendor"</string>
<string name="apps_product">"/product"</string>
<string name="app_summary">"Используйте возможности Magisk для очистки от bloatware несистемно"</string>
<string name="asus">"ASUS"</string>
<string name="backup">"Бэкап"</string>
<string name="backup_list_empty">"Вы еще не удалили ни одного приложения"</string>
<string name="backup_message">"Бэкапы создаются как %s"</string>
<string name="carrier">"Поставщик"</string>
<string name="change_logs">"Изменения"</string>
<string name="change_logs_summary">"Посмотреть последние изменения в этом приложении"</string>
<string name="check_update">"Проверка обновлений"</string>
<string name="check_update_summary">"Проверьте наличие новых версий De-Bloater"</string>
<string name="custom_scripts">"Пользовательские скрипты"</string>
<string name="custom_scripts_applied_message">"Все сделано. Изменения будут применены после перезагрузки."</string>
<string name="custom_scripts_tomatot">"Tomatot Debloater"</string>
<string name="custom_scripts_tomatot_list">"В этот скрипт включены следующие приложения"</string>
<string name="custom_scripts_tomatot_extreme">"Удалите все приложения, включенные в список invisible и light, а также несколько приложений Google и функций, которые не являются абсолютно необходимыми, но полезны для некоторых людей."</string>
<string name="custom_scripts_tomatot_invisible">"Удалите только приложения, связанные с телеметрией или не имеющие никакой функции."</string>
<string name="custom_scripts_tomatot_light">"Удалите все приложения, включенные в список invisible, а также некоторые другие редко используемые приложения."</string>
<string name="custom_scripts_tomatot_Summary">"Адаптация debloater скрипта, изначально разработанного Tomatot для OnePlus 6. Используйте этот сценарий на других устройствах на свой страх и риск."</string>
<string name="custom_scripts_uad">"Universal Android Debloater"</string>
<string name="custom_scripts_uad_disabled">"Этот скрип в настоящее время отключен"</string>
<string name="custom_scripts_uad_enabled">"Этот скрипт в настоящее время включен"</string>
<string name="custom_scripts_uad_summary">"Адаптация Universal Android Debloater, изначально разработанная W1nst0n с целью повышения экономии аккумулятора и повышения конфиденциальности за счет удаления ненужных и непонятных системных приложений."</string>
<string name="donate">"Пожертвовать"</string>
<string name="donate_summary">"Пожертвуйте, чтобы поддержать разработчика"</string>
<string name="download_failed">"Похоже, что загрузка не удалась, или загружен поврежденный файл"</string>
<string name="downloading">"Скачивание %s"</string>
<string name="extreme">"Extreme"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"Посетить страницу F-Droid"</string>
<string name="google">"Google"</string>
<string name="get_it">"Скачать"</string>
<string name="huawei">"Huawei"</string>
<string name="inactive">"Неактивные"</string>
<string name="inactive_apps_summary">"На этой странице перечислены приложения, которые будут удалены/назначены для удаления несистемно"</string>
<string name="invisible">"Invisible"</string>
<string name="invite_friend">"Пригласить друзей"</string>
<string name="invite_friend_summary">"Пригласите друга попробовать De-Bloater"</string>
<string name="lg">"LG"</string>
<string name="licence">"Лицензия"</string>
<string name="licence_summary">"Смотреть GPL V3"</string>
<string name="light">"Light"</string>
<string name="miscellaneous">"Разное"</string>
<string name="module_status_reset">"Сброс модуля"</string>
<string name="more_apps">"Больше приложений"</string>
<string name="more_apps_summary">"Еще приложения от разработчика"</string>
<string name="motorola">"Motorola"</string>
<string name="name">"Имя"</string>
<string name="nokia">"Nokia"</string>
<string name="no_internet">"Пожалуйста, проверьте ваше интернет-соединение"</string>
<string name="no_magisk">"Magisk не обнаружен"</string>
<string name="no_root">"Нет Root"</string>
<string name="oneplus">"OnePlus"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"Идентификатор пакета"</string>
<string name="press_back_exit">"Нажмите \"Назад\" еще раз, чтобы выйти"</string>
<string name="rate_us">"Оцените нас"</string>
<string name="rate_us_Summary">"Оцените нас или напишите отзыв о De-Bloater в PlayМаркет"</string>
<string name="reboot">"Перезагрузите устройство"</string>
<string name="remove">"Удалить"</string>
<string name="report_issue">"Сообщить о проблеме"</string>
<string name="report_issue_summary">"Сообщить о проблеме на GitHub"</string>
<string name="restore">"Восстановить"</string>
<string name="restore_error_message">"Вы выбрали недопустимый файл бэкапа. Отмена"</string>
<string name="restore_question">"Восстановить из %s?"</string>
<string name="restoring">"Восстановление…"</string>
<string name="samsung">"Samsung"</string>
<string name="search_hint">"Поиск…"</string>
<string name="share_app_message">"Получите De-Bloater %s с"</string>
<string name="sony">"Sony"</string>
<string name="sort_by">"Сортировать приложения по"</string>
<string name="source_code">"Исходный код"</string>
<string name="source_code_summary">"Посетите страницу GitHub"</string>
<string name="status_message_remove">"Будет удален после перезагрузки"</string>
<string name="status_message_restore">"Будет восстановлен после перезагрузки"</string>
<string name="storage_access_denied">"Запрещено разрешение на запись в хранилище"</string>
<string name="support">"Группа поддержки"</string>
<string name="support_summary">"Посетите группу поддержки"</string>
<string name="update_available">"Доступно обновление
(%s)"</string>
<string name="updated_dialog">"Поздравляю. У вас уже установлена последняя версия De-Bloater."</string>
<string name="version">"Версия"</string>
<string name="warning_summary">"De-Bloater очень силен! Пожалуйста, используйте его c осторожноcтью. Разработчик этого приложения не несет никакой ответственности, если что-то пошло не так из-за ненадлежащего использования."</string>
<string name="xiaomi">"Xiaomi"</string>
<string name="zte">"ZTE"</string>
<string name="apps_all">"Все"</string>
<string name="start">"Начать"</string>
<string name="backup_share_message">"Чтобы создать базу данных предопределенных профилей для публичного использования, пожалуйста предоставьте лучшие Ваши профили разработчику. Спасибо.
Email: smartpack.org@gmail.com
Telegram: https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"Вы выбрали файл резервной копии, созданный для другого устройства или версии Android. Вы все еще хотите восстановить?"</string>
<string name="share_profile">"Поделиться профилем"</string>
<string name="uninstall">"Удалить"</string>
<string name="updated_system_app_warning">"Вы решили удалить '%s', системное приложение, которое было обновлено. Если вы действительно хотите полностью удалить это приложение, то также удалите обновления этого приложения. В противном случае после перезагрузки приложение будет вести себя как обычное пользовательское приложение."</string>
</resources>

View file

@ -0,0 +1,108 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"O programe"</string>
<string name="about_summary">"De-Bloater je program využívajúci silu Magisk na odstránenie nechcených aplikácií bez nutnosti priameho prístupu k systému."</string>
<string name="active">"Aktívne"</string>
<string name="active_app_summary">"Celý zoznam aplikácií je nižšie. Aplikácie označené na odstránenie budú \"debloatované\" po reštarte."</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"Aplikovať"</string>
<string name="apps">"%s Applikácií"</string>
<string name="apps_system">"/system"</string>
<string name="apps_vendor">"/dodávateľ"</string>
<string name="apps_product">"/produkt"</string>
<string name="app_summary">"Využi silu Magisk k \"debloatovaniu\" systémových aplikácií."</string>
<string name="asus">"ASUS"</string>
<string name="backup">"Záloha"</string>
<string name="backup_list_empty">"Žiadne aplikácie ešte neboli odstránené"</string>
<string name="backup_message">"Zálohové súbory vytvorené ako %s"</string>
<string name="carrier">"Nosič(?)"</string>
<string name="change_logs">"Záznam zmien"</string>
<string name="change_logs_summary">"Pozrieť záznamy posledných zmien"</string>
<string name="check_update">"Skontrolovať aktualizácie"</string>
<string name="check_update_summary">"Skontrolovať nové verzie De-Bloater(a)"</string>
<string name="custom_scripts">"Prispôsobené skripty"</string>
<string name="custom_scripts_applied_message">"Hotovo. Zmeny sa dokončia po reštarte."</string>
<string name="custom_scripts_tomatot">"Tomatot Debloater skript"</string>
<string name="custom_scripts_tomatot_list">"V tomto skripte sú nasledujúce aplikácie"</string>
<string name="custom_scripts_tomatot_extreme">"Odstrániť všetky aplikácie zahrnuté v zozname neviditeľných a odľahčených spolu s niekoľko Google Apps a funkciami, ktoré nie sú absolútne potrebné ale pre nikoho môžu byť užitočné."</string>
<string name="custom_scripts_tomatot_invisible">"Odstrániť iba aplikácie telemetrie alebo také, ktoré nemajú žiadnu funkcie."</string>
<string name="custom_scripts_tomatot_light">"Odstrániť všetky aplikácie v zozname neviditeľných spolu s aplikáciami používanými zriedka."</string>
<string name="custom_scripts_tomatot_Summary">"Prispôsobenie Debloater skriptu pôvodne vyvinutého pre OnePlus 6 \"Tomatot\"-om. Na iných zariadeniach používate tento skript na vlastné riziko."</string>
<string name="custom_scripts_uad">"Univerzálny Androidový Debloater"</string>
<string name="custom_scripts_uad_disabled">"Tento skript je aktuálne deaktivovaný"</string>
<string name="custom_scripts_uad_enabled">"Tento skript je aktuálne povolený."</string>
<string name="custom_scripts_uad_summary">"Prispôsobenie Univerzálneho Androidového Debloater-a originálne vyvinutého \"W1nst0n\"-om s cieľom zlepšiť výdrž batérie a zabezpečenie súkromia odstránením nepotrebných a záhadných systémových aplikácií."</string>
<string name="donate">"Podporiť darom"</string>
<string name="donate_summary">"Podporiť darom na vývoj"</string>
<string name="download_failed">"Vyzerá to ako zlyhanie sťahovania alebo bol stiahnutý poškodený súbor."</string>
<string name="downloading">"Sťahovanie %s"</string>
<string name="extreme">"Extrém"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"Návšteva F-Droid stránky"</string>
<string name="google">"Google"</string>
<string name="get_it">"Získať to"</string>
<string name="huawei">"Huawei"</string>
<string name="inactive">"Neaktívne"</string>
<string name="inactive_apps_summary">"Na tejto stránke je zoznam aplikácií, ktoré boli odstránené (Debloated) alebo označené na odstránenie."</string>
<string name="invisible">"Neviditeľné"</string>
<string name="invite_friend">"Navrhnúť priateľom"</string>
<string name="invite_friend_summary">"Navrhnúť priateľovi vyskúšanie \"De-Bloater\"-a"</string>
<string name="lg">"LG"</string>
<string name="licence">"Licencia"</string>
<string name="licence_summary">"Pozrieť GPL V3"</string>
<string name="light">"Svetlo(?)"</string>
<string name="miscellaneous">"Rozličné"</string>
<string name="module_status_reset">"Reset modulu"</string>
<string name="more_apps">"Viac programov"</string>
<string name="more_apps_summary">"Viac programov od vývojára"</string>
<string name="motorola">"Motorola"</string>
<string name="name">"Meno"</string>
<string name="nokia">"Nokia"</string>
<string name="no_internet">"Prosím, preverte pripojenie na internet"</string>
<string name="no_magisk">"Magisk nenájdený"</string>
<string name="no_root">"Bez \"root\"-a"</string>
<string name="oneplus">"OnePlus"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"ID balíčka (Package ID)"</string>
<string name="press_back_exit">"Znovu stlačte \"Späť\" pre ukončenie"</string>
<string name="rate_us">"Ohodnoťte nás"</string>
<string name="rate_us_Summary">"Hodnotiť a/alebo recenzovať De-Bloater v PlayStore"</string>
<string name="reboot">"Reštartovať zariadenie"</string>
<string name="remove">"Odstrániť"</string>
<string name="report_issue">"Nahlásiť problém"</string>
<string name="report_issue_summary">"Vytvoriť incident na GitHub-e"</string>
<string name="restore">"Obnoviť"</string>
<string name="restore_error_message">"Zvolený nesprávny zálohový súbor. Končím"</string>
<string name="restore_question">"Obnoviť z %s?"</string>
<string name="restoring">"Obnovovanie…"</string>
<string name="samsung">"Samsung"</string>
<string name="search_hint">"Hľadať…"</string>
<string name="share_app_message">"Získať De-Bloater %s z"</string>
<string name="sony">"Sony"</string>
<string name="sort_by">"Triediť aplikácie podľa"</string>
<string name="source_code">"Zdrojový kód"</string>
<string name="source_code_summary">"Navštíviť GitHub"</string>
<string name="status_message_remove">"Bude odstránené po reštarte"</string>
<string name="status_message_restore">"Bude obnovené po reštarte"</string>
<string name="storage_access_denied">"Chýbajúce oprávnenia pre zápis na úložisko"</string>
<string name="support">"Podpora"</string>
<string name="support_summary">"Navštíviť podporu"</string>
<string name="update_available">"Dostupná nová aktualizácia
(%s)"</string>
<string name="updated_dialog">"Blahoželáme. Máte aktuálnu verziu \"De-Bloater\"-a"</string>
<string name="version">"Verzia"</string>
<string name="warning_summary">"De-Bloater je veľmi silný nástroj. Prosím, používajte ho opatrne. Vývojár programu nenesie žiadnu zodpovednosť aj sa niečo zlé stane z dôvodu nesprávneho použitia."</string>
<string name="xiaomi">"Xiaomi"</string>
<string name="zte">"ZTE"</string>
<string name="apps_all">"Všetky"</string>
<string name="start">"Štart"</string>
<string name="backup_share_message">"Za účelom vytvorenia databázy preddefinovaných profilov pre verejné použitie, prosíme zvážte zdieľanie najlepších de-bloater—ových profilov vami vytvorených s vývojárom. Ďakujem
Email: smartpack.org@gmail.com
Telegram: https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"Zvolili ste zálohovú súbor vytvorený pre iné zariadenie alebo Android verziu. Chcete aj tak obnoviť?"</string>
<string name="share_profile">"Zdieľať profil"</string>
<string name="uninstall">"Odinštalovať"</string>
<string name="updated_system_app_warning">"Rozhodli ste sa de-bloatovať '%s' - systémovú aplikáciu, ktorá už bola aktualizované. Takže ak naozaj chcete túto aplikáciu úplne odstrániť, zvážte odinštalovanie aj lokálnych aktualizácií. V opačnom prípade sa aplikácia po reštarte zariadenia bude správať ako normálna užívateľská aplikácia."</string>
<string name="backup_list_as">"Zálohovať de-bloater profil ako?"</string>
</resources>

View file

@ -0,0 +1,106 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"Hakkında"</string>
<string name="about_summary">"De-Bloater, Magisk'in gücünü kullanarak önyüklü gelen uygulamalardan sistemsiz olarak kurtulmanızı sağlar!"</string>
<string name="active">"Aktif"</string>
<string name="active_app_summary">"Bütün uygulamalar aşağıda listelenmiştir. Kaldırmayı seçtiğiniz uygulamaların işleme alınması için yeniden başlatın!"</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"Uygula"</string>
<string name="apps">"%s Uygulamalar"</string>
<string name="apps_system">"/Sistem uygulamaları"</string>
<string name="apps_vendor">"/Satıcı uygulamaları"</string>
<string name="apps_product">"/Kullanıcı uygulamaları"</string>
<string name="app_summary">"Magisk'in gücünü kullanarak sistemsiz olarak önyüklü uygulamaları kaldırın!"</string>
<string name="asus">"ASUS"</string>
<string name="backup">"Yedekle"</string>
<string name="backup_list_empty">"Henüz hiçbir uygulamayı kaldırmadın!"</string>
<string name="backup_message">"Yedekleme dosyası oluşturuldu. %s!"</string>
<string name="carrier">"Operatör"</string>
<string name="change_logs">"Değişiklikleri göster"</string>
<string name="change_logs_summary">"Bu uygulamadaki son değişiklikleri gösterir."</string>
<string name="check_update">"Güncellemeleri kontrol et"</string>
<string name="check_update_summary">"Yeni sürüm kontrolü yap"</string>
<string name="custom_scripts">"Özel Scriptler"</string>
<string name="custom_scripts_applied_message">"Her şey tamamlandı! Değişiklikler yeniden başlattıktan sonra etkili olacak."</string>
<string name="custom_scripts_tomatot">"Tomatot Debloater"</string>
<string name="custom_scripts_tomatot_list">"Listedeki uygulamalar scripte dahildir!"</string>
<string name="custom_scripts_tomatot_extreme">"Görünmez ve açık listede yer alan tüm uygulamaların yanı sıra birkaç Google Uygulamasını ve kesinlikle gerekli olmayan ancak bazı kişiler için yararlı olan uygulamaları ve özellikleri kaldırın."</string>
<string name="custom_scripts_tomatot_invisible">"Yalnızca telemetri ile ilgili veya herhangi bir işlevi olmayan uygulamaları kaldırın."</string>
<string name="custom_scripts_tomatot_light">"Görünmez listede bulunan tüm uygulamaları ve nadiren kullanılan diğer bazı uygulamaları kaldırın."</string>
<string name="custom_scripts_tomatot_Summary">"Başlangıçta Tomatot tarafından OnePlus 6 için geliştirilen debloater betiğinin genele uyarlanması! Bu komut dosyasını çalıştırmak sonucunda oluşacak riskler size aittir."</string>
<string name="custom_scripts_uad">"Evrensel Android De-bloater"</string>
<string name="custom_scripts_uad_disabled">"Script şuanda devre dışı!"</string>
<string name="custom_scripts_uad_enabled">"Script şuanda aktif!"</string>
<string name="custom_scripts_uad_summary">"Gereksiz ve belirsiz sistem uygulamalarını kaldırarak pil performansını ve gizliliği artırmak amacıyla orijinal olarak W1nst0n tarafından geliştirilen Evrensel Android Debloater'ın uyarlanmasıdır."</string>
<string name="donate">"Bağış yap!"</string>
<string name="donate_summary">"Gelişimi desteklemek için bağış yap!"</string>
<string name="download_failed">"Görünüşe göre yükleme başarısız oldu ya da yükleme dosyası zarar görmüş!"</string>
<string name="downloading">"Yükleniyor %s"</string>
<string name="extreme">"Ekstrem"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"F-droid'i ziyaret et!"</string>
<string name="google">"Google"</string>
<string name="get_it">"Onu al"</string>
<string name="huawei">"Huawei"</string>
<string name="inactive">"İnaktif"</string>
<string name="inactive_apps_summary">"Burada listenen uygulamalar sistemsiz olarak kaldırılmıştır!"</string>
<string name="invisible">"Görünmez"</string>
<string name="invite_friend">"Arkadaşları davet et"</string>
<string name="invite_friend_summary">"De-Bloater'ı denemek için arkadaşlarını davet et!"</string>
<string name="lg">"LG"</string>
<string name="licence">"Lisans"</string>
<string name="licence_summary">"GPL V3'i göster"</string>
<string name="light">"Hafif"</string>
<string name="miscellaneous">"Çeşitli"</string>
<string name="module_status_reset">"Modülü yeniden başlat"</string>
<string name="more_apps">"Daha fazla uygulama"</string>
<string name="more_apps_summary">"Geliştirici tarafından sunulan diğer uygulamaları kontrol et!"</string>
<string name="motorola">"Motorola"</string>
<string name="name">"İsim"</string>
<string name="nokia">"Nokia"</string>
<string name="no_internet">"Internet bağlantını kontrol et!"</string>
<string name="no_magisk">"Magisk bulunamadı."</string>
<string name="no_root">"Kök erişimi yok."</string>
<string name="oneplus">"OnePlus"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"Paket ismi"</string>
<string name="press_back_exit">"Lütfen çıkmak için geri tuşuna tekrar basın!"</string>
<string name="rate_us">"Bizi değerlendir"</string>
<string name="rate_us_Summary">"Debloater'ı PlayStore'da değerlendir"</string>
<string name="reboot">"Cihazı yeniden başlat!"</string>
<string name="remove">"Kaldır"</string>
<string name="report_issue">"Sorunu rapor et"</string>
<string name="report_issue_summary">"GitHub'da sorunu paylaş"</string>
<string name="restore">"Geri yükleme"</string>
<string name="restore_error_message">"Geçersiz bir yedekleme dosyası seçtiniz. İptal ediliyor!"</string>
<string name="restore_question">"Geri yükleme dosyası seç %s?"</string>
<string name="restoring">"Geri yükleniyor…"</string>
<string name="samsung">"Samsung"</string>
<string name="search_hint">"Ara…"</string>
<string name="share_app_message">"De-bloater'ı şuradan %s al "</string>
<string name="sony">"Sony"</string>
<string name="sort_by">"Ugulamaları sıralama ölçütü"</string>
<string name="source_code">"Kaynak kodu"</string>
<string name="source_code_summary">"GitHub sayfasını ziyaret et"</string>
<string name="status_message_remove">"Yeniden başlatmadan sonra kaldırılacak"</string>
<string name="status_message_restore">"Yeniden başlatmadan sonra geri yükleme yapılacak"</string>
<string name="storage_access_denied">"Depolamaya erişim izni reddedildi!"</string>
<string name="support">"Destek"</string>
<string name="support_summary">"Destek grubunu ziyaret et"</string>
<string name="update_available">"Yeni güncelleme mevcut!\n(%s)"</string>
<string name="updated_dialog">"Tebrikler! De-Bloater'ın güncel sürümüne sahipsiniz!"</string>
<string name="version">"Versiyon"</string>
<string name="warning_summary">"De-Bloater çok güçlü! Lütfen dikkatli kullanın. Bu uygulamanın geliştiricisi, uygunsuz kullanımı nedeniyle bir şeyler ters giderse herhangi bir sorumluluk kabul etmez."</string>
<string name="xiaomi">"Xiaomi"</string>
<string name="zte">"ZTE"</string>
<string name="apps_all">"Tamamı"</string>
<string name="start">"Başla"</string>
<string name="backup_share_message">"Herkese açık kullanıma uygun, önceden tanımlanmış profillerden oluşan bir veritabanı oluşturmak için lütfen sizin tarafınızdan yapılan en iyi De-Bloater profillerini De-Bloater geliştiricisi ile paylaşmayı düşünün. Teşekkür ederim.
Email: smartpack.org@gmail.com
Telegram: https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"Farklı bir cihaz veya Android sürümü için oluşturulmuş bir yedekleme dosyası seçtiniz. Hala geri yüklemek istiyor musun?"</string>
<string name="share_profile">"Profili Paylaş"</string>
<string name="uninstall">"Kaldır"</string>
<string name="updated_system_app_warning">"Zaten güncellenmiş bir sistem uygulaması olan '% s' yi kaldırmaya karar verdiniz. Bu nedenle, bu uygulamayı gerçekten tamamen kaldırmak istiyorsanız, lütfen yerel güncellemeleri de kaldırmayı düşünün. Aksi takdirde, uygulama yeniden başlatıldıktan sonra normal bir kullanıcı uygulaması gibi davranır."</string>
</resources>

View file

@ -0,0 +1,68 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"Про додаток"</string>
<string name="about_summary">"De-Bloater - це програма, яка використовує силу Magisk, щоб видалити небажані програми безсистемно!"</string>
<string name="active">"Активні"</string>
<string name="active_app_summary">"Весь список програм детально описаний нижче. Програми, призначені для видалення, будуть безсистемно видалені після перезавантаження!"</string>
<string name="apply">"Застосувати"</string>
<string name="apps">"%s додатки"</string>
<string name="apps_system">"/system"</string>
<string name="apps_vendor">"/vendor"</string>
<string name="apps_product">"/product"</string>
<string name="backup">"Бекап"</string>
<string name="backup_list_empty">"Ви ще не видалили жодної програми!"</string>
<string name="backup_message">"Бекапи створюються як %s!"</string>
<string name="change_logs">"Зміни"</string>
<string name="change_logs_summary">"Переглянути останні зміни в цьому додатку"</string>
<string name="check_update">"Перевірка оновлення"</string>
<string name="check_update_summary">"Перевірте наявність нових версій De-Bloater"</string>
<string name="custom_scripts">"Спеціальні сценарії"</string>
<string name="custom_scripts_tomatot">"Tomatot Debloater"</string>
<string name="custom_scripts_tomatot_list">"Наступні додатки включені в цей сценарій!"</string>
<string name="custom_scripts_tomatot_extreme">"Видаліть усі додатки, включені до invisible та light списку, а також кілька Google додаткаів і функцій, які не є абсолютно необхідними, але корисними для деяких людей."</string>
<string name="custom_scripts_tomatot_invisible">"Видаліть лише додатки, пов’язані з телеметрією, або які не мають жодної функції."</string>
<string name="custom_scripts_tomatot_light">"Видаліть усі додатки, включені до invisible списку, а також деякі інші програми, які рідко використовуються."</string>
<string name="custom_scripts_tomatot_Summary">"Адаптація сценарію debloater, спочатку розробленого Tomatot для OnePlus 6! Будь ласка, використовуйте цей сценарій на інших пристроях на свій страх і ризик."</string>
<string name="donate">"Пожертвувати"</string>
<string name="donate_summary">"Пожертвуйте на підтримку розвитку!"</string>
<string name="download_failed">"Здається, завантаження не вдалося або завантажений пошкоджений файл!"</string>
<string name="downloading">"Завантаження %s"</string>
<string name="extreme">"Extreme"</string>
<string name="get_it">"Завантажити"</string>
<string name="inactive">"Неактивні"</string>
<string name="inactive_apps_summary">"На цій сторінці перелічені програми, які безсистемно видалені/призначені для видалення!"</string>
<string name="invisible">"Invisible"</string>
<string name="invite_friend">"Запросити друзів"</string>
<string name="invite_friend_summary">"Запросіть друга спробувати De-Bloater"</string>
<string name="light">"Light"</string>
<string name="module_status_reset">"Скидання модуля"</string>
<string name="more_apps">"Більше від розробника"</string>
<string name="more_apps_summary">"Інші додатки від розробника"</string>
<string name="name">"Ім'я"</string>
<string name="no_internet">"Перевірте підключення до Інтернету!"</string>
<string name="no_magisk">"Magisk не виявлено"</string>
<string name="no_root">"Немає Root"</string>
<string name="package_id">"Ідентифікатор пакета"</string>
<string name="press_back_exit">"Натисніть 'Назад' ще раз, щоб вийти!"</string>
<string name="reboot">"Перезавантажити пристрій"</string>
<string name="remove">"Видалити"</string>
<string name="report_issue">"Повідомте про проблему"</string>
<string name="report_issue_summary">"Повідомте про проблему на GitHub"</string>
<string name="restore">"Відновити"</string>
<string name="restore_error_message">"Ви вибрали недійсний файл бекапу. Невдача!"</string>
<string name="restore_question">"Відновити з %s?"</string>
<string name="restoring">"Відновлення…"</string>
<string name="search_hint">"Пошук…"</string>
<string name="share_app_message">"Отримайте De-Bloater %s з"</string>
<string name="sort_by">"Сортувати програми за"</string>
<string name="source_code">"Вихідний код"</string>
<string name="source_code_summary">"Відвідайте сторінку GitHub"</string>
<string name="status_message_remove">"Буде видалено після перезавантаження"</string>
<string name="status_message_restore">"Буде відновлено після перезавантаження"</string>
<string name="storage_access_denied">"Заборонено дозвіл на запис в сховище!"</string>
<string name="support">"Група підтримки"</string>
<string name="support_summary">"Відвідайте групу підтримки"</string>
<string name="update_available">"Доступне нове оновлення!\n(%s)"</string>
<string name="updated_dialog">"Вітаємо! У вас вже встановлена остання версія De-Bloater!"</string>
<string name="version">"Версія"</string>
</resources>

View file

@ -0,0 +1,7 @@
<resources>
<style name="AppTheme" parent="Theme.Material3.DynamicColors.DayNight.NoActionBar">
<item name="windowNoTitle">true</item>
<item name="android:statusBarColor">@color/colorBlack</item>
<item name="android:windowOptOutEdgeToEdgeEnforcement">true</item>
</style>
</resources>

View file

@ -0,0 +1,107 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<string name="about">"Giới thiệu"</string>
<string name="about_summary">"De-Bloater là một ứng dụng sử dụng Magisk để xoá các ứng dụng systemless-ly."</string>
<string name="active">"Hoạt động"</string>
<string name="active_app_summary">"Tất cả các ứng dụng đã được hiển thị chi tiết dưới đây. Các ứng dụng được gỡ cài đặt systemless-ly sau khi khởi động lại."</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"Áp dụng"</string>
<string name="apps">"%s ứng dụng"</string>
<string name="apps_system">"/system"</string>
<string name="apps_vendor">"/vendor"</string>
<string name="apps_product">"/product"</string>
<string name="app_summary">"Sử dụng Magisk để xoá các ứng dụng hệ thống một cách systemless-ly"</string>
<string name="asus">"ASUS"</string>
<string name="backup">"Sao lưu"</string>
<string name="backup_list_empty">"Bạn chưa xoá ứng dụng nào"</string>
<string name="backup_message">"File sao lưu đã được lưu là %s"</string>
<string name="carrier">"Vận chuyển"</string>
<string name="change_logs">"Thông tin cập nhật"</string>
<string name="change_logs_summary">"Xem các thay đổi gần đây của ứng dụng này"</string>
<string name="check_update">"Kiểm tra cập nhật"</string>
<string name="check_update_summary">"Kiểm tra phiên bản mới của De-Bloater"</string>
<string name="custom_scripts">"Scirpt tùy chỉnh"</string>
<string name="custom_scripts_applied_message">"Mọi thứ đã xong. Các thay đổi sẽ được áp dụng sau khi khởi động lại."</string>
<string name="custom_scripts_tomatot">"Tomatot Debloater"</string>
<string name="custom_scripts_tomatot_list">"Các ứng dụng sau đã được thêm vào script"</string>
<string name="custom_scripts_tomatot_extreme">"Xóa tất cả các ứng dụng có trong danh sách ẩn và không ẩn cũng như một số ứng dụng Google và các tính năng không thực sự cần thiết nhưng có thể hữu ích đối với một số người."</string>
<string name="custom_scripts_tomatot_invisible">"Chỉ xóa các ứng dụng liên quan đến bên thứ ba hoặc không có bất kỳ chức năng nào."</string>
<string name="custom_scripts_tomatot_light">"Xoá các ứng dụng trong danh sách hiện thị cũng như một số ứng dụng hiếm dùng."</string>
<string name="custom_scripts_tomatot_Summary">"Việc phát triển debloater script ban đầu được thực hiện bởi Tomatot cho OnePlus 6. Vui lòng tự chịu trách nhiệm cho các rủi ro khi sử dụng tập lệnh này trên các thiết bị khác."</string>
<string name="custom_scripts_uad">"Universal Android Debloater"</string>
<string name="custom_scripts_uad_disabled">"Script đang bị vô hiệu"</string>
<string name="custom_scripts_uad_enabled">"Script đang được kích hoạt"</string>
<string name="custom_scripts_uad_summary">"Việc phát triển Universal Android Debloater ban đầu được thực hiện bởi W1nst0n với mục đích cải thiện hiệu suất pin và quyền riêng tư bằng cách xóa các ứng dụng hệ thống không cần thiết và hiếm khi sử dụng."</string>
<string name="donate">"Donate"</string>
<string name="donate_summary">"Donate để hỗ trợ nhà phát triển"</string>
<string name="download_failed">"Có vẻ như tải xuống đã thất bại hoặc file tải xuống đã bị lỗi"</string>
<string name="downloading">"Đang tải %s"</string>
<string name="extreme">"Cực độ"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"Xem trên F-Droid"</string>
<string name="google">"Google"</string>
<string name="get_it">"Đã hiểu"</string>
<string name="huawei">"Huawei"</string>
<string name="inactive">"Không hoạt động"</string>
<string name="inactive_apps_summary">"Các ứng dụng đã được loại bỏ systemless-ly hoặc được chỉ định loại bọ đã được liệt kê trong trang này"</string>
<string name="invisible">"Ẩn"</string>
<string name="invite_friend">"Giới thiệu với bạn bè"</string>
<string name="invite_friend_summary">"Gợi ý bạn bè sử dụng De-Bloater"</string>
<string name="lg">"LG"</string>
<string name="licence">"Giấy phép"</string>
<string name="licence_summary">"Xem GLP V3"</string>
<string name="light">"Không ẩn"</string>
<string name="miscellaneous">"Điều khoản khác"</string>
<string name="module_status_reset">"Reset Module"</string>
<string name="more_apps">"Ứng dụng khác"</string>
<string name="more_apps_summary">"Ứng dùng khác từ nhà phát triển"</string>
<string name="motorola">"Motorola"</string>
<string name="name">"Tên"</string>
<string name="nokia">"Nokia"</string>
<string name="no_internet">"Vui lòng kiểm tra kết nối internet"</string>
<string name="no_magisk">"Không phát hiện Magisk"</string>
<string name="no_root">"Chưa Root"</string>
<string name="oneplus">"OnePlus"</string>
<string name="oppo">"Oppo"</string>
<string name="package_id">"ID gói"</string>
<string name="press_back_exit">"Bấm \"Quay lại\" một lần nữa để thoát"</string>
<string name="rate_us">"Đánh giá"</string>
<string name="rate_us_Summary">"Đánh giá hoặc/và review De-Bloater trên PlayStore"</string>
<string name="reboot">"Khởi động lại thiết bị"</string>
<string name="remove">"Xoá"</string>
<string name="report_issue">"Báo lỗi"</string>
<string name="report_issue_summary">"Báo lỗi trên GitHub"</string>
<string name="restore">"Khôi phục"</string>
<string name="restore_error_message">"Bạn đã chọn một file sao lưu không hợp lệ. Hủy bỏ"</string>
<string name="restore_question">"Khôi phục từ %s?"</string>
<string name="restoring">"Đang khôi phục…"</string>
<string name="samsung">"Samsung"</string>
<string name="search_hint">"Tìm kiếm"</string>
<string name="share_app_message">"Tải De-Bloater %s từ"</string>
<string name="sony">"Sony"</string>
<string name="sort_by">"Sắp xếp ứng dụng theo"</string>
<string name="source_code">"Mã nguồn"</string>
<string name="source_code_summary">"Xem trang GitHub"</string>
<string name="status_message_remove">"Sẽ bị xoá sau khi khởi động lại"</string>
<string name="status_message_restore">"Sẽ được khôi phục sau khi khởi động lại"</string>
<string name="storage_access_denied">"Quyền truy cập lưu trữ bị từ chối"</string>
<string name="support">"Hỗ trợ"</string>
<string name="support_summary">"Xem nhóm hỗ trợ"</string>
<string name="update_available">"Bản cập nhật mới có sẵn
(%s)"</string>
<string name="updated_dialog">"Chúc mừng. Bạn đã có phiên bản mới nhất của De-Bloater."</string>
<string name="version">"Phiên bản"</string>
<string name="warning_summary">"De-Bloater rất nguy hiểm. Xin hãy sử dụng cẩn thận. Nhà phát triển không chịu bất cứ trách nhiệm nào cho việc sử dụng sai cách."</string>
<string name="xiaomi">"Xiaomi"</string>
<string name="zte">"ZTE"</string>
<string name="apps_all">"Tất cả"</string>
<string name="start">"Bắt đầu"</string>
<string name="backup_share_message">"Để tạo cơ sở dữ liệu gồm các cấu hình được xét duyệt để công khai, vui lòng xem xét việc chia sẻ các cấu hình de-bloater tốt nhất do bạn tạo với nhà phát triển De-Bloater. Xin cảm ơn.
Email: smartpack.org@gmail.com
Telegram: https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"Bạn đã chọn một file sao lưu được tạo cho một thiết bị hoặc phiên bản Android khác. Bạn vẫn muốn khôi phục?"</string>
<string name="share_profile">"Chia sẻ Cấu hình"</string>
<string name="uninstall">"Gỡ cài đặt"</string>
<string name="updated_system_app_warning">"Bạn đã quyết định loại bỏ '%s', một ứng dụng hệ thống đã được cập nhật. Do đó, nếu bạn thực sự muốn xóa hoàn toàn ứng dụng này, vui lòng xem xét gỡ cài đặt các bản cập nhật cục bộ. Nếu không, ứng dụng sẽ hoạt động như một ứng dụng người dùng sau khi khởi động lại."</string>
</resources>

View file

@ -0,0 +1,108 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<!-- zh-CN (Simplified, China) -->
<string name="about">"关于"</string>
<string name="about_summary">"De-Bloater 是一个使用 Magisk 的强大功能来无系统地去除不需要的应用程序。"</string>
<string name="active">"激活的应用"</string>
<string name="active_app_summary">"整个应用程序列表详细如下。要删除的应用程序将在重新启动后无系统地去除。"</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"应用"</string>
<string name="apps">"%s 应用程序"</string>
<string name="apps_system">"/system"</string>
<string name="apps_vendor">"/vendor"</string>
<string name="apps_product">"/product"</string>
<string name="app_summary">"使用 Magisk 的强大功能无系统地去除系统应用程序"</string>
<string name="asus">"华硕"</string>
<string name="backup">"备份"</string>
<string name="backup_list_empty">"您尚未删除任何应用"</string>
<string name="backup_message">"备份文件创建为 %s"</string>
<string name="carrier">"运营商"</string>
<string name="change_logs">"更新日志"</string>
<string name="change_logs_summary">"查看此应用的最新更新"</string>
<string name="check_update">"更新检查"</string>
<string name="check_update_summary">"检查 De-Bloater 的新版本"</string>
<string name="custom_scripts">"自定义脚本"</string>
<string name="custom_scripts_applied_message">"完成。更改将在重新启动后完成。"</string>
<string name="custom_scripts_tomatot">"Tomatot Debloater"</string>
<string name="custom_scripts_tomatot_list">"此脚本中包含以下应用程序"</string>
<string name="custom_scripts_tomatot_extreme">"删除隐藏列表和白名单中所有应用程序以及一些并非绝对必要但对某些人有用的 Google Apps 和功能。"</string>
<string name="custom_scripts_tomatot_invisible">"仅删除与遥测相关或没有任何功能的应用。"</string>
<string name="custom_scripts_tomatot_light">"删除隐藏列表中的所有应用程序以及一些很少使用的其他应用程序。"</string>
<string name="custom_scripts_tomatot_Summary">"改编最初由 Tomatot 为 OnePlus 6 开发的 debloater 脚本。请在其他设备上使用此脚本,风险自负。"</string>
<string name="custom_scripts_uad">"通用 Android Debloater"</string>
<string name="custom_scripts_uad_disabled">"此脚本当前已禁用"</string>
<string name="custom_scripts_uad_enabled">"此脚本当前已启用"</string>
<string name="custom_scripts_uad_summary">"改编最初由 W1nst0n 开发的 Universal Android Debloater旨在通过删除不必要和晦涩的系统应用程序来提高电池性能和隐私。"</string>
<string name="donate">"捐赠"</string>
<string name="donate_summary">"捐款支持发展"</string>
<string name="download_failed">"似乎下载失败,或者下载了损坏的文件"</string>
<string name="downloading">"正在下载 %s"</string>
<string name="extreme">"极端"</string>
<string name="fdroid">"F-Droid"</string>
<string name="fdroid_summary">"访问 F-Droid 页面"</string>
<string name="google">"谷歌"</string>
<string name="get_it">"知道了"</string>
<string name="huawei">"华为"</string>
<string name="inactive">"已禁用"</string>
<string name="inactive_apps_summary">"此页面中列出了无系统地去除或即将删除的应用程序"</string>
<string name="invisible">"隐形"</string>
<string name="invite_friend">"邀请朋友"</string>
<string name="invite_friend_summary">"邀请朋友试用 De-Bloater"</string>
<string name="lg">"LG"</string>
<string name="licence">"许可证"</string>
<string name="licence_summary">"查看 GPL V3"</string>
<string name="light">"轻量"</string>
<string name="miscellaneous">"其他"</string>
<string name="module_status_reset">"重置模块"</string>
<string name="more_apps">"更多应用"</string>
<string name="more_apps_summary">"来自开发者的更多应用"</string>
<string name="motorola">"摩托罗拉"</string>
<string name="name">"名称"</string>
<string name="nokia">"诺基亚"</string>
<string name="no_internet">"请检查您的互联网连接"</string>
<string name="no_magisk">"未检测到 Magisk"</string>
<string name="no_root">"无根"</string>
<string name="oneplus">"一加"</string>
<string name="oppo">"OPPO"</string>
<string name="package_id">"软件包ID"</string>
<string name="press_back_exit">"再次按“返回”按钮退出"</string>
<string name="rate_us">"评价我们"</string>
<string name="rate_us_Summary">"在 PlayStore 中评价或/和评论 De-Bloater"</string>
<string name="reboot">"重启设备"</string>
<string name="remove">"移除"</string>
<string name="report_issue">"报告问题"</string>
<string name="report_issue_summary">"在 GitHub 上提出问题"</string>
<string name="restore">"恢复"</string>
<string name="restore_error_message">"您选择了一个无效的备份文件。中止"</string>
<string name="restore_question">"要从 %s 恢复吗?"</string>
<string name="restoring">"正在恢复…"</string>
<string name="samsung">"三星"</string>
<string name="search_hint">"搜索…"</string>
<string name="share_app_message">"从以下位置获取 De-Bloater %s"</string>
<string name="sony">"索尼"</string>
<string name="sort_by">"排序应用程序"</string>
<string name="source_code">"源代码"</string>
<string name="source_code_summary">"访问 GitHub 页面"</string>
<string name="status_message_remove">"重启后将被删除"</string>
<string name="status_message_restore">"重启后将被恢复"</string>
<string name="storage_access_denied">"写入存储的权限被拒绝"</string>
<string name="support">"支持"</string>
<string name="support_summary">"访问支持小组"</string>
<string name="update_available">"有新的更新可用
(%s)"</string>
<string name="updated_dialog">"恭喜。您已经获得了最新版本的 De-Bloater。"</string>
<string name="version">"版本"</string>
<string name="warning_summary">"De-Bloater 太强大了。请谨慎使用。如果由于使用不当而发生错误,此应用程序的开发人员不承担任何责任。"</string>
<string name="xiaomi">"小米"</string>
<string name="zte">"中兴通讯"</string>
<string name="apps_all">"全部"</string>
<string name="start">"开始"</string>
<string name="backup_share_message">"为了创建供公众使用的预定义配置文件数据库,请考虑与 De-Bloater 的开发人员共享您制作的最佳 de-bloater 配置文件。谢谢你。
电子邮件smartpack.org@gmail.com
Telegramhttps://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"您已选择为其他设备或 Android 版本创建的备份文件。你仍然想继续恢复吗?"</string>
<string name="share_profile">"分享资料"</string>
<string name="uninstall">"卸载"</string>
<string name="updated_system_app_warning">"您决定对已更新的系统应用程序“%s”进行删除。因此如果您真的想完全删除此应用程序请考虑同时卸载本地更新。否则应用程序将在重新启动后像普通用户应用程序一样运行。"</string>
</resources>

View file

@ -0,0 +1,108 @@
<resources xmlns:tools="http://schemas.android.com/tools" tools:ignore="MissingTranslation">
<!-- zh-Hant (Traditional, generic) -->
<string name="about">"關於"</string>
<string name="about_summary">"De-Bloater 是一個應用程序,它使用 Magisk 的強大功能來無系統地去除不需要的應用程序。"</string>
<string name="active">"積極的"</string>
<string name="active_app_summary">"整個應用程序列表詳細如下。分配要刪除的應用程序將在重新啟動後無系統地去膨脹。"</string>
<string name="aosp">"AOSP"</string>
<string name="apply">"申請"</string>
<string name="apps">"%s 應用程序"</string>
<string name="apps_system">"/系統"</string>
<string name="apps_vendor">"/小販"</string>
<string name="apps_product">"/產品"</string>
<string name="app_summary">"使用 Magisk 的強大功能無系統地去膨脹系統應用程序"</string>
<string name="asus">"華碩"</string>
<string name="backup">"備份"</string>
<string name="backup_list_empty">"您尚未刪除任何應用"</string>
<string name="backup_message">"備份文件創建為 %s"</string>
<string name="carrier">"載體"</string>
<string name="change_logs">"變更日誌"</string>
<string name="change_logs_summary">"查看此應用的最新更改"</string>
<string name="check_update">"更新檢查"</string>
<string name="check_update_summary">"檢查 De-Bloater 的新版本"</string>
<string name="custom_scripts">"自定義腳本"</string>
<string name="custom_scripts_applied_message">"一切都完成了。更改將在重新啟動後完成。"</string>
<string name="custom_scripts_tomatot">"番茄去脹劑"</string>
<string name="custom_scripts_tomatot_list">"此腳本中包含以下應用程序"</string>
<string name="custom_scripts_tomatot_extreme">"刪除不可見和輕列表中包含的所有應用程序以及一些並非絕對必要但對某些人有用的 Google Apps 和功能。"</string>
<string name="custom_scripts_tomatot_invisible">"僅刪除與遙測相關或沒有任何功能的應用。"</string>
<string name="custom_scripts_tomatot_light">"刪除隱藏列表中包含的所有應用程序以及一些很少使用的其他應用程序。"</string>
<string name="custom_scripts_tomatot_Summary">"改編最初由 Tomatot 為 OnePlus 6 開發的 debloater 腳本。請在其他設備上使用此腳本,風險自負。"</string>
<string name="custom_scripts_uad">"通用 Android Debloater"</string>
<string name="custom_scripts_uad_disabled">"此腳本當前已禁用"</string>
<string name="custom_scripts_uad_enabled">"此腳本當前已啟用"</string>
<string name="custom_scripts_uad_summary">"改編最初由 W1nst0n 開發的 Universal Android Debloater旨在通過刪除不必要和晦澀的系統應用程序來提高電池性能和隱私。"</string>
<string name="donate">"捐"</string>
<string name="donate_summary">"捐款支持發展"</string>
<string name="download_failed">"似乎下載失敗,或者下載了損壞的文件"</string>
<string name="downloading">"正在下載 %s"</string>
<string name="extreme">"極端"</string>
<string name="fdroid">"F-機器人"</string>
<string name="fdroid_summary">"訪問 F-Droid 頁面"</string>
<string name="google">"谷歌"</string>
<string name="get_it">"得到它"</string>
<string name="huawei">"華為"</string>
<string name="inactive">"不活躍"</string>
<string name="inactive_apps_summary">"此頁面中列出了無系統地debloated 或分配刪除的應用程序"</string>
<string name="invisible">"無形的"</string>
<string name="invite_friend">"邀請朋友"</string>
<string name="invite_friend_summary">"邀請朋友試用 De-Bloater"</string>
<string name="lg">"LG"</string>
<string name="licence">"執照"</string>
<string name="licence_summary">"查看 GPL V3"</string>
<string name="light">"光"</string>
<string name="miscellaneous">"各種各樣的"</string>
<string name="module_status_reset">"重置模塊"</string>
<string name="more_apps">"更多的應用"</string>
<string name="more_apps_summary">"來自開發者的更多應用"</string>
<string name="motorola">"摩托羅拉"</string>
<string name="name">"姓名"</string>
<string name="nokia">"諾基亞"</string>
<string name="no_internet">"請檢查您的互聯網連接"</string>
<string name="no_magisk">"未檢測到 Magisk"</string>
<string name="no_root">"無根"</string>
<string name="oneplus">"一加"</string>
<string name="oppo">"OPPO"</string>
<string name="package_id">"包裹編號"</string>
<string name="press_back_exit">"再次按“返回”按鈕退出"</string>
<string name="rate_us">"評價我們"</string>
<string name="rate_us_Summary">"在 PlayStore 中評價或/和評論 De-Bloater"</string>
<string name="reboot">"重啟設備"</string>
<string name="remove">"消除"</string>
<string name="report_issue">"報告問題"</string>
<string name="report_issue_summary">"在 GitHub 上提出問題"</string>
<string name="restore">"恢復"</string>
<string name="restore_error_message">"您選擇了一個無效的備份文件。中止"</string>
<string name="restore_question">"從 %s 恢復?"</string>
<string name="restoring">"正在恢復…"</string>
<string name="samsung">"三星"</string>
<string name="search_hint">"搜索…"</string>
<string name="share_app_message">"從以下位置獲取 De-Bloater %s"</string>
<string name="sony">"索尼"</string>
<string name="sort_by">"排序應用程序"</string>
<string name="source_code">"源代碼"</string>
<string name="source_code_summary">"訪問 GitHub 頁面"</string>
<string name="status_message_remove">"重啟後將被刪除"</string>
<string name="status_message_restore">"重啟後會恢復"</string>
<string name="storage_access_denied">"寫入存儲的權限被拒絕"</string>
<string name="support">"支持"</string>
<string name="support_summary">"訪問支持小組"</string>
<string name="update_available">"有新的更新可用
(%s)"</string>
<string name="updated_dialog">"恭喜。您已經獲得了最新版本的 De-Bloater。"</string>
<string name="version">"版本"</string>
<string name="warning_summary">"De-Bloater 太強大了。請謹慎使用。如果由於使用不當而發生錯誤,此應用程序的開發人員不承擔任何責任。"</string>
<string name="xiaomi">"小米"</string>
<string name="zte">"中興通訊"</string>
<string name="apps_all">"全部"</string>
<string name="start">"開始"</string>
<string name="backup_share_message">"為了創建供公眾使用的預定義配置文件數據庫,請考慮與 De-Bloater 的開發人員分享您製作的最佳 de-bloater 配置文件。謝謝你。
電子郵件smartpack.org@gmail.com
電報https://t.me/smartpack_kmanager"</string>
<string name="restore_mismatch_message">"您已選擇為其他設備或 Android 版本創建的備份文件。你還想恢復嗎?"</string>
<string name="share_profile">"分享資料"</string>
<string name="uninstall">"卸載"</string>
<string name="updated_system_app_warning">"您決定對已更新的系統應用程序“%s”進行去膨脹。因此如果您真的想完全刪除此應用程序請考慮同時卸載本地更新。否則應用程序將在重新啟動後像普通用戶應用程序一樣運行。"</string>
</resources>

Some files were not shown because too many files have changed in this diff Show more