commit 2f823927a5278e9c4f60b4c9b4dfe2d36082a41d Author: AlphaX-Projects <77661270+AlphaX-Projects@users.noreply.github.com> Date: Sat Dec 25 14:39:47 2021 +0100 Initial commit diff --git a/.editorconfig b/.editorconfig new file mode 100644 index 00000000..a3f46be1 --- /dev/null +++ b/.editorconfig @@ -0,0 +1,17 @@ +root = true + +[*] + +charset = utf-8 + +# New Line formating +end_of_line = lf +insert_final_newline = true +trim_trailing_whitespace = true + + +# Indentation +indent_style = tab +indent_size = 4 + +quote_type = single diff --git a/.gitattributes b/.gitattributes new file mode 100644 index 00000000..dfe07704 --- /dev/null +++ b/.gitattributes @@ -0,0 +1,2 @@ +# Auto detect text files and perform LF normalization +* text=auto diff --git a/.gitignore b/.gitignore new file mode 100644 index 00000000..592d8ab0 --- /dev/null +++ b/.gitignore @@ -0,0 +1,18 @@ +# Yarn +yarn.lock + +# Derived js files +qortal-ui-plugins/plugins/core/**/*.js +!*.src.js + +# Node modules +node_modules/ + +# Mac .DS_Store files +.DS_Store + +# Build script related +watch.pid + +# Built WWW +qortal-ui/builtWWW diff --git a/.travis.yml b/.travis.yml new file mode 100644 index 00000000..2c62f062 --- /dev/null +++ b/.travis.yml @@ -0,0 +1,71 @@ + +branches: + except: + - master + +language: node_js +node_js: "14.17.0" + +cache: + yarn: true + directories: + - node_modules + # - qortal-ui-core/node_modules + # - qortal-ui-plugins/node_modules + # - qortal-ui-crypto/node_modules + - $HOME/.cache/electron + - $HOME/.cache/electron-builder + +install: + - sh install-dependencies.sh + +env: + global: + - ELECTRON_CACHE=$HOME/.cache/electron + - ELECTRON_BUILDER_CACHE=$HOME/.cache/electron-builder + - ELECTRON_ENABLE_LOGGING=true + +jobs: + include: + - stage: Deploy Linux + if: tag IS present + os: linux + dist: bionic + sudo: required + addons: + apt: + packages: + # default Electron dependencies + - build-essential + - gconf2 + - gconf-service + - libgtk-3-0 + - libnotify4 + - libxss-dev + - libxss1 + - xdg-utils + - libatspi2.0-0 + - libappindicator1 + - libxext-dev + - libxtst6 + - libxtst-dev + - libnss3 + script: + - newVersion=$(git describe --abbrev=0) + - yarn version --new-version $newVersion + - sh set-up-snap.sh + - yarn run release + - stage: Deploy Windows & Mac + if: tag IS present + os: osx + osx_image: xcode10.2 + script: + - newVersion=$(git describe --abbrev=0) + - yarn version --new-version $newVersion + - yarn run release -- --mac --win + before_cache: + - rm -rf $HOME/.cache/electron-builder/wine + # - stage: Update GitHub with Builds + # if: tag IS present + # script: + # - sh push-updates-with-travis-build.sh diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md new file mode 100644 index 00000000..3c456662 --- /dev/null +++ b/CONTRIBUTING.md @@ -0,0 +1,8 @@ +# Anyone can contribute to the project! + +1) Fork the repository +2) Make changes +3) Push changes to your repository +4) Push changes to parent repository (make a pull request) + +As long the code change is good we will merge it. diff --git a/LICENSE b/LICENSE new file mode 100644 index 00000000..f288702d --- /dev/null +++ b/LICENSE @@ -0,0 +1,674 @@ + GNU GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + 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. + + + Copyright (C) + + 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 . + +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: + + Copyright (C) + 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 +. + + 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 +. diff --git a/README.md b/README.md new file mode 100644 index 00000000..b958c1e9 --- /dev/null +++ b/README.md @@ -0,0 +1,88 @@ +# Qortal UI + +[![License](https://img.shields.io/badge/license-GPL--3.0-blue)](https://opensource.org/licenses/GPL-3.0) + +Decentralizing The World + +Building and Running Qortal UI Server from source: +---------------------------------------------------- +Follow the steps below to download, install, build and run Qortal UI locally on Linux. + + +Installation +------------ +Packages required: + - Node.js + - npm + - yarn + +Easiest way to install the lastest required packages on Linux is via nvm. + +``` sudo apt update && sudo apt install curl -y ```
+``` curl https://raw.githubusercontent.com/creationix/nvm/master/install.sh | bash ```
+``` source ~/.profile ``` (For Debian based distro)
+``` source ~/.bashrc ``` (For Fedora / CentOS)
+``` nvm ls-remote ``` (Fetch list of available versions)
+``` nvm install v14.17.0 ``` (Latest LTS: Fermium as of writing)
+``` npm -g install yarn ```
+ +On BSD do a ``` pkg_add node followed by npm install -g yarn ``` + +Adding via binary package mirror will only work if you have set the package path. You can do a node or java build via ports instead by downloading ports with portsnap fetch method. + +Verify your installtion with node --version
+- ``` If you have an older installation of npm, please do not forget to update that with npm update -g. ``` + +Clone the main UI repo + - ``` git clone https://github.com/Qortal/UI.git ``` + +Installation and linking +------------------------ +In `qortal-ui-core/`, `qortal-ui-plugins/`, `qortal-ui-crypto/` directories, run: +``` +yarn install +yarn link +``` + +Finally, in the `qortal-ui` directory, run: +``` +yarn link qortal-ui-core +yarn link qortal-ui-plugins +yarn link qortal-ui-crypto +``` + + + +Build UI server and files +------------------------- +In `qortal-ui` directory, run: +``` +yarn run build +``` + +Start UI Server ( preferred way ) +--------------- +``` +yarn run server & +``` +The "&" at the end puts the UI server in the background. + +Run UI using electron +--------------------- +``` +yarn run start-electron +``` + +Build script (unix-like systems only) +------------------------------------- +To automate the above process, run ./build.sh, optionally specifying the following options: + +`-s`: run UI server after completing the build
+`-e`: run electron server after completing the build
+`-f`: force relink and reinstall dependencies
+`-h`: show help
+ +Example command to build and run the UI server: +``` +./build.sh -s +``` diff --git a/build-setup.js b/build-setup.js new file mode 100644 index 00000000..e69de29b diff --git a/build.bat b/build.bat new file mode 100644 index 00000000..0f6c7fdd --- /dev/null +++ b/build.bat @@ -0,0 +1,34 @@ +@echo off + +:: BatchGotAdmin +:------------------------------------- +REM --> Check for permissions + IF "%PROCESSOR_ARCHITECTURE%" EQU "amd64" ( +>nul 2>&1 "%SYSTEMROOT%\SysWOW64\cacls.exe" "%SYSTEMROOT%\SysWOW64\config\system" +) ELSE ( +>nul 2>&1 "%SYSTEMROOT%\system32\cacls.exe" "%SYSTEMROOT%\system32\config\system" +) + +REM --> If error flag set, we do not have admin. +if '%errorlevel%' NEQ '0' ( + echo Requesting administrative privileges... + goto UACPrompt +) else ( goto gotAdmin ) + +:UACPrompt + echo Set UAC = CreateObject^("Shell.Application"^) > "%temp%\getadmin.vbs" + set params= %* + echo UAC.ShellExecute "cmd.exe", "/c ""%~s0"" %params:"=""%", "", "runas", 1 >> "%temp%\getadmin.vbs" + + "%temp%\getadmin.vbs" + del "%temp%\getadmin.vbs" + exit /B + +:gotAdmin + pushd "%CD%" + CD /D "%~dp0" +:-------------------------------------- +call npm run build +REM start /WAIT /B npm run install +REM sleep 1 +PAUSE diff --git a/build.js b/build.js new file mode 100644 index 00000000..a35e926b --- /dev/null +++ b/build.js @@ -0,0 +1,28 @@ +const path = require('path') +const uiCore = require('qortal-ui-core') + +const generateBuildConfig = uiCore('generate_build_config') +const build = uiCore('build') + +const config = require('./config/config.js') + +const pluginsController = require('qortal-ui-plugins') +const buildDefalutPlugins = pluginsController('build') + + +srcConfig = { + ...config.build, + options: { + ...config.build.options, + outputDir: path.join(__dirname, '/builtWWW'), + sassOutputDir: path.join(__dirname, '/builtWWW/styles.bundle.css'), + } +} + +const { buildConfig, inlineConfigs } = generateBuildConfig(srcConfig) + +build(buildConfig.options, buildConfig.outputs, buildConfig.outputOptions, buildConfig.inputOptions, inlineConfigs) + .then(() => { + console.log("Building and Bundling Plugins"); + buildDefalutPlugins() + }) diff --git a/build.sh b/build.sh new file mode 100644 index 00000000..b5b47b11 --- /dev/null +++ b/build.sh @@ -0,0 +1,106 @@ +#!/usr/bin/env bash + +declare -a YARN_PACKAGE_DEPS=("qortal-ui-core" "qortal-ui-plugins" "qortal-ui-crypto") +YARN_LINK_DIR="${HOME}/.config/yarn/link" + +SHOW_HELP=0 +FORCE_LINK=0 +YARN_WATCH=0 +RUN_SERVER=0 +RUN_ELECTRON=0 + +while [ -n "$*" ]; do + case $1 in + -h) + # Show help + SHOW_HELP=1 + ;; + + -f) + # Force relink and reinstall dependencies + FORCE_LINK=1 + ;; + + -w) + # Use "yarn watch" instead of "yarn build", to enable hot swapping + YARN_WATCH=1 + ;; + + -s) + # Run server after building + RUN_SERVER=1 + ;; + + -e) + # Run electron after building + RUN_ELECTRON=1 + ;; + esac + shift +done + +if [ "${SHOW_HELP}" -eq 1 ]; then + echo + echo "Usage:" + echo "build.sh [-h] [-f] [-s] [-e]" + echo + echo "-h: show help" + echo "-f: force relink and reinstall dependencies" + echo "-w: use 'yarn watch' instead of 'yarn build', to enable hot swapping" + echo "-s: run UI server after completing the build" + echo "-e: run electron server after completing the build" + echo + exit +fi + +echo "Checking dependencies..." +for PACKAGE in "${YARN_PACKAGE_DEPS[@]}"; do + if [ "${FORCE_LINK}" -eq 1 ]; then + echo "Unlinking ${PACKAGE}..." + yarn --cwd "${PACKAGE}" unlink "${PACKAGE}" + yarn --cwd "${PACKAGE}" unlink + fi + if [ ! -d "${YARN_LINK_DIR}/${PACKAGE}" ]; then + echo "Installing and linking ${PACKAGE}..." + yarn --cwd "${PACKAGE}" install + yarn --cwd "${PACKAGE}" link + yarn --cwd qortal-ui link "${PACKAGE}" + else + echo "${PACKAGE} is already linked." + fi +done + +WATCH_PID=$(cat "watch.pid" || echo "") +if [ ! -z "${WATCH_PID}" ]; then + echo "Stopping existing watch process..." + kill "${WATCH_PID}" + rm -f "watch.pid" +fi + +if [ "${YARN_WATCH}" -eq 1 ]; then + echo "Building qortal-ui in watch mode..." + yarn --cwd qortal-ui run watch & + echo "$!" > "watch.pid"; +else + yarn --cwd qortal-ui run build +fi + +if [ "${RUN_SERVER}" -eq 1 ]; then + echo "Running UI server..." + trap : INT + yarn --cwd qortal-ui run server +elif [ "${RUN_ELECTRON}" -eq 1 ]; then + echo "Starting electron..." + trap : INT + yarn --cwd qortal-ui run start-electron +fi + +WATCH_PID=$(cat "watch.pid" || echo "") +if [ ! -z "${WATCH_PID}" ]; then + echo "Stopping watch process..." + kill "${WATCH_PID}" + rm -f "watch.pid" +fi + +# Catch-all to kill any remaining processes +pkill -P $$ diff --git a/config/build.config.js b/config/build.config.js new file mode 100644 index 00000000..c1ffeaf4 --- /dev/null +++ b/config/build.config.js @@ -0,0 +1,14 @@ +const path = require('path') +const defaultConfig = require('./default.config.js') + +const build = { + options: { + outputDir: path.join(__dirname, '../build'), + imgDir: path.join(__dirname, '../img') + }, + aliases: { + 'qortal-ui-crypto': path.join(__dirname, '../node_modules/qortal-ui-crypto/api.js') + } +} + +module.exports = build diff --git a/config/coin.config.js b/config/coin.config.js new file mode 100644 index 00000000..bcd320e9 --- /dev/null +++ b/config/coin.config.js @@ -0,0 +1,8 @@ +const defaultConfig = require('./default.config.js') + +module.exports = { + name: 'Qortal', + symbol: 'Qort', + addressVersion: 58, // Q for Qortal + logo: '/img/QORT_LOGO.svg' +} diff --git a/config/config.js b/config/config.js new file mode 100644 index 00000000..8fd79649 --- /dev/null +++ b/config/config.js @@ -0,0 +1,27 @@ +let config = require('./default.config.js') +let userConfig = {} +try { + userConfig = require('./customConfig.js') +} catch (e) { + console.warn(e) + console.warn('Error loading user config') +} +const checkKeys = (storeObj, newObj) => { + for (const key in newObj) { + if (!Object.prototype.hasOwnProperty.call(storeObj, key)) return + + if (typeof newObj[key] === 'object') { + storeObj[key] = checkKeys(storeObj[key], newObj[key]) + } else { + storeObj[key] = newObj[key] + } + } + return storeObj +} + +const getConfig = customConfig => { + config = checkKeys(config, customConfig) + return config +} + +module.exports = getConfig(userConfig) diff --git a/config/crypto.config.js b/config/crypto.config.js new file mode 100644 index 00000000..968d2e8e --- /dev/null +++ b/config/crypto.config.js @@ -0,0 +1,3 @@ +const defaultConfig = require('./default.config.js') + +module.exports = {} diff --git a/config/customConfig.js b/config/customConfig.js new file mode 100644 index 00000000..6c6d12f3 --- /dev/null +++ b/config/customConfig.js @@ -0,0 +1,13 @@ +const coin = require('./coin.config.js') +const crypto = require('./crypto.config.js') +const styles = require('./styles.config.js') +const build = require('./build.config.js') +const user = require('./user.config.js') + +module.exports = { + coin, + styles, + build, + user, + crypto +} diff --git a/config/default.config.js b/config/default.config.js new file mode 100644 index 00000000..bf22d466 --- /dev/null +++ b/config/default.config.js @@ -0,0 +1,5 @@ +const uiCore = require('qortal-ui-core') +const defaultConfig = uiCore('default_config') + + +module.exports = defaultConfig diff --git a/config/styles.config.js b/config/styles.config.js new file mode 100644 index 00000000..4ba52ba2 --- /dev/null +++ b/config/styles.config.js @@ -0,0 +1 @@ +module.exports = {} diff --git a/config/user.config.js b/config/user.config.js new file mode 100644 index 00000000..ef45ffdb --- /dev/null +++ b/config/user.config.js @@ -0,0 +1,10 @@ +const user = require('./default.config.js').user +module.exports = { + node: 0, // set to mainnet + server: { + primary: { + port: 12388, // set as default UI port + address: '0.0.0.0', // can specify an IP for a fixed bind + }, + }, +} diff --git a/electron-builder.yml b/electron-builder.yml new file mode 100644 index 00000000..63e779db --- /dev/null +++ b/electron-builder.yml @@ -0,0 +1,93 @@ +appId: org.qortal.QortalUi +productName: "Qortal UI" +copyright: "Copyright © 2021" + +# forceCodeSigning: false + +# nodeGypRebuild: false + +compression: maximum + +asar: true + +files: + - from: "." + to: "." + filter: + - "electron.js" + - "img/" + - "node_modules/" + - "server.js" + - "package.json" + - "builtWWW/" + - "config/" + - "scripts/" + +afterPack: "./scripts/afterPack.js" + +# Mac OS configuration +mac: + icon: "./img/icons/icns/256x256.icns" + target: + - { target: dmg } + +# Config for OSX dmg +dmg: + icon: "./img/icons/icns/256x256.icns" + iconSize: 100 + contents: + - x: 130 + y: 220 + - x: 410 + y: 220 + type: "link" + path: "/Applications" + +# Windows configuration +win: + legalTrademarks: "QORTAL.ORG" + icon: "./img/icons/ico/256x256.ico" + installerSidebar: "./img/win-installer-sidebar.bmp" + uninstallerSidebar: "./img/win-uninstaller-sidebar.bmp" + target: + - "nsis" + +# Config for the windows installer +nsis: + oneClick: false + perMachine: false + runAfterFinish: true + deleteAppDataOnUninstall: true + createDesktopShortcut: true + createStartMenuShortcut: true + +# Linux configuration +linux: + icon: "./img/icons/png/" + category: "Network" + packageCategory: "Network" + desktop: + StartupWMClass: qortal-ui + executableArgs: + - --no-sandbox + - '--js-flags="--max-old-space-size=6144"' + target: + - "deb" + - "AppImage" + - "snap" + +deb: + synopsis: "Qortal UI for Linux" + afterInstall: "./scripts/add-debian-apt-repo.sh" + afterRemove: "./scripts/uninstall-debian-conf.sh" + +snap: + synopsis: "Qortal UI for Linux" + +directories: + output: dist + +publish: + provider: github + owner: Qortal + repo: qortal-ui diff --git a/electron.js b/electron.js new file mode 100644 index 00000000..e9606b96 --- /dev/null +++ b/electron.js @@ -0,0 +1,149 @@ +const { app, BrowserWindow, ipcMain, Menu, Notification, Tray, nativeImage } = require('electron'); +const { autoUpdater } = require('electron-updater'); +const server = require('./server.js'); +const log = require('electron-log'); +const path = require('path'); + +// THOUGHTS: Make this APP more modularize and platform agnostic... + +process.env['APP_PATH'] = app.getAppPath(); + +autoUpdater.logger = log; +log.info('App starting...'); + +const editMenu = Menu.buildFromTemplate([ + { + label: "Qortal", + submenu: [{ + label: "Quit", + click() { + app.quit(); + } + }] + }, + { + label: "Edit", + submenu: [ + {label: "Undo", accelerator: "CommandOrControl+Z", selector: "undo:"}, + {label: "Redo", accelerator: "CommandOrControl+Shift+Z", selector: "redo:"}, + {type: "separator"}, + {label: "Cut", accelerator: "CommandOrControl+X", selector: "cut:"}, + {label: "Copy", accelerator: "CommandOrControl+C", selector: "copy:"}, + {label: "Paste", accelerator: "CommandOrControl+V", selector: "paste:"}, + {label: "Select All", accelerator: "CommandOrControl+A", selector: "selectAll:"} + ] + } +]); + +Menu.setApplicationMenu(editMenu); + +let myWindow = null; + +// TODO: Move the Tray function into another file (maybe Tray.js) -_- +// const tray = new Tray(nativeImage.createEmpty()); + +const APP_ICON = path.join(__dirname, 'img', 'icons'); + +const iconPath = () => { + return APP_ICON + (process.platform === 'win32' ? '/ico/256x256.ico' : '/png/256x256.png'); +}; + +function createWindow() { + myWindow = new BrowserWindow({ + backgroundColor: '#eee', + width: 1280, + height: 720, + minWidth: 700, + minHeight: 640, + icon: iconPath(), + title: "Qortal", + autoHideMenuBar: true, + webPreferences: { + nodeIntegration: false, + partition: 'persist:webviewsession', + enableRemoteModule: false, + sandbox: true + }, + show: false + }) + myWindow.maximize(); + myWindow.show(); + myWindow.loadURL('http://localhost:12388/app/wallet') + myWindow.on('closed', function () { + myWindow = null + }) +} + +const createTray = () => { + let myTray = new Tray(path.join(__dirname, 'img', 'icons', 'png', '32x32.png')) + const contextMenu = Menu.buildFromTemplate([{ + label: "Quit", click() { + myTray.destroy(); + app.quit(); + }, + }]) + myTray.setTitle("QORTAL UI") + myTray.setToolTip("QORTAL UI") + myTray.setContextMenu(contextMenu) +} + +const isLock = app.requestSingleInstanceLock(); + +if (!isLock) { + app.quit() +} else { + app.on('second-instance', (event, cmd, dir) => { + if (myWindow) { + if (myWindow.isMinimized()) myWindow.restore() + myWindow.focus() + } + }) + app.allowRendererProcessReuse = true + app.on('ready', () => { + createWindow(); + createTray(); + if (process.platform === 'win32') { + app.setAppUserModelId("org.qortal.QortalUi"); + } + autoUpdater.checkForUpdatesAndNotify(); + }) + app.on('window-all-closed', function () { + if (process.platform !== 'darwin') { + app.quit(); + } + }) + app.on('activate', function () { + if (myWindow === null) { + createWindow(); + createTray(); + } + }) + ipcMain.on('app_version', (event) => { + log.info(app.getVersion()); + myWindow.webContents.send("app_version", { + version: app.getVersion(); + }); + }) + autoUpdater.on('update-available', () => { + const n = new Notification({ + title: 'Update Available!', + body: 'It will be downloaded in the background and installed after download.' + }) + n.show(); + }) + autoUpdater.on('error', (err) => { + const n = new Notification({ + title: 'Error while Updating...', + body: err + }) + n.show(); + }) + autoUpdater.on('update-downloaded', () => { + const n = new Notification({ + title: 'Update Downloaded!', + body: 'Restarting to Update' + }) + n.show(); + autoUpdater.quitAndInstall(); + }) +} diff --git a/img/QORT_LOGO.png b/img/QORT_LOGO.png new file mode 100644 index 00000000..3b126401 Binary files /dev/null and b/img/QORT_LOGO.png differ diff --git a/img/QORT_LOGO.svg b/img/QORT_LOGO.svg new file mode 100644 index 00000000..72012ede --- /dev/null +++ b/img/QORT_LOGO.svg @@ -0,0 +1 @@ +Asset 3 \ No newline at end of file diff --git a/img/arrr.png b/img/arrr.png new file mode 100644 index 00000000..d2745657 Binary files /dev/null and b/img/arrr.png differ diff --git a/img/arrr_transparent.png b/img/arrr_transparent.png new file mode 100644 index 00000000..285fe891 Binary files /dev/null and b/img/arrr_transparent.png differ diff --git a/img/ascii-art.txt b/img/ascii-art.txt new file mode 100644 index 00000000..9ea1f7e9 --- /dev/null +++ b/img/ascii-art.txt @@ -0,0 +1,12 @@ + .... + ,,,, ,,,, + ,.,,. ,,., .,,, + ,,,,,.,,,,,,, .,,,,,,,. ,,., ,,,,,.,,,,,,,.,,,,,,,.,,,,,, ,,,, +.,.,.,. ..,.,., ..,.,.,.,.,.,. .,.,.,. .,., ..,.,. .,., +.,,,, ,,., ,,,,. .,,, ,,.,. ,,,, ,.,,,,,,,. ,,,, +.,,,. ,,., .,,, .,,, ,,., ,,., ,.,,,.....,,,. .,,, +.,,,,,,. .,,,,., ,,,.. ,.,,, ,,., ,,,, ,,,, ,,,,. ,,,, + ............... ............ .... ....... .............. .... + ,.,, ,,., + ,,., + ,,., diff --git a/img/btc.png b/img/btc.png new file mode 100644 index 00000000..fe3fd1a0 Binary files /dev/null and b/img/btc.png differ diff --git a/img/btc_transparent.png b/img/btc_transparent.png new file mode 100644 index 00000000..f242a343 Binary files /dev/null and b/img/btc_transparent.png differ diff --git a/img/doge.png b/img/doge.png new file mode 100644 index 00000000..d99fa2ff Binary files /dev/null and b/img/doge.png differ diff --git a/img/doge_transparent.png b/img/doge_transparent.png new file mode 100644 index 00000000..1f142e2e Binary files /dev/null and b/img/doge_transparent.png differ diff --git a/img/favicon/android-icon-144x144.png b/img/favicon/android-icon-144x144.png new file mode 100644 index 00000000..2e61cc45 Binary files /dev/null and b/img/favicon/android-icon-144x144.png differ diff --git a/img/favicon/android-icon-192x192.png b/img/favicon/android-icon-192x192.png new file mode 100644 index 00000000..cc2d2c3d Binary files /dev/null and b/img/favicon/android-icon-192x192.png differ diff --git a/img/favicon/android-icon-36x36.png b/img/favicon/android-icon-36x36.png new file mode 100644 index 00000000..eaa12c06 Binary files /dev/null and b/img/favicon/android-icon-36x36.png differ diff --git a/img/favicon/android-icon-48x48.png b/img/favicon/android-icon-48x48.png new file mode 100644 index 00000000..35075386 Binary files /dev/null and b/img/favicon/android-icon-48x48.png differ diff --git a/img/favicon/android-icon-72x72.png b/img/favicon/android-icon-72x72.png new file mode 100644 index 00000000..9e17dc29 Binary files /dev/null and b/img/favicon/android-icon-72x72.png differ diff --git a/img/favicon/android-icon-96x96.png b/img/favicon/android-icon-96x96.png new file mode 100644 index 00000000..340a399a Binary files /dev/null and b/img/favicon/android-icon-96x96.png differ diff --git a/img/favicon/apple-icon-114x114.png b/img/favicon/apple-icon-114x114.png new file mode 100644 index 00000000..e74716a0 Binary files /dev/null and b/img/favicon/apple-icon-114x114.png differ diff --git a/img/favicon/apple-icon-120x120.png b/img/favicon/apple-icon-120x120.png new file mode 100644 index 00000000..5f5835d2 Binary files /dev/null and b/img/favicon/apple-icon-120x120.png differ diff --git a/img/favicon/apple-icon-144x144.png b/img/favicon/apple-icon-144x144.png new file mode 100644 index 00000000..2e61cc45 Binary files /dev/null and b/img/favicon/apple-icon-144x144.png differ diff --git a/img/favicon/apple-icon-152x152.png b/img/favicon/apple-icon-152x152.png new file mode 100644 index 00000000..8f19aa78 Binary files /dev/null and b/img/favicon/apple-icon-152x152.png differ diff --git a/img/favicon/apple-icon-180x180.png b/img/favicon/apple-icon-180x180.png new file mode 100644 index 00000000..da71fd54 Binary files /dev/null and b/img/favicon/apple-icon-180x180.png differ diff --git a/img/favicon/apple-icon-57x57.png b/img/favicon/apple-icon-57x57.png new file mode 100644 index 00000000..d4f2d5bb Binary files /dev/null and b/img/favicon/apple-icon-57x57.png differ diff --git a/img/favicon/apple-icon-60x60.png b/img/favicon/apple-icon-60x60.png new file mode 100644 index 00000000..f94ca544 Binary files /dev/null and b/img/favicon/apple-icon-60x60.png differ diff --git a/img/favicon/apple-icon-72x72.png b/img/favicon/apple-icon-72x72.png new file mode 100644 index 00000000..9e17dc29 Binary files /dev/null and b/img/favicon/apple-icon-72x72.png differ diff --git a/img/favicon/apple-icon-76x76.png b/img/favicon/apple-icon-76x76.png new file mode 100644 index 00000000..e2b7106d Binary files /dev/null and b/img/favicon/apple-icon-76x76.png differ diff --git a/img/favicon/apple-icon-precomposed.png b/img/favicon/apple-icon-precomposed.png new file mode 100644 index 00000000..7ace1659 Binary files /dev/null and b/img/favicon/apple-icon-precomposed.png differ diff --git a/img/favicon/apple-icon.png b/img/favicon/apple-icon.png new file mode 100644 index 00000000..7ace1659 Binary files /dev/null and b/img/favicon/apple-icon.png differ diff --git a/img/favicon/browserconfig.xml b/img/favicon/browserconfig.xml new file mode 100644 index 00000000..c5541482 --- /dev/null +++ b/img/favicon/browserconfig.xml @@ -0,0 +1,2 @@ + +#ffffff \ No newline at end of file diff --git a/img/favicon/favicon-16x16.png b/img/favicon/favicon-16x16.png new file mode 100644 index 00000000..430a064c Binary files /dev/null and b/img/favicon/favicon-16x16.png differ diff --git a/img/favicon/favicon-32x32.png b/img/favicon/favicon-32x32.png new file mode 100644 index 00000000..65305cd2 Binary files /dev/null and b/img/favicon/favicon-32x32.png differ diff --git a/img/favicon/favicon-96x96.png b/img/favicon/favicon-96x96.png new file mode 100644 index 00000000..340a399a Binary files /dev/null and b/img/favicon/favicon-96x96.png differ diff --git a/img/favicon/favicon.ico b/img/favicon/favicon.ico new file mode 100644 index 00000000..a37b2cb1 Binary files /dev/null and b/img/favicon/favicon.ico differ diff --git a/img/favicon/manifest.json b/img/favicon/manifest.json new file mode 100644 index 00000000..386c9229 --- /dev/null +++ b/img/favicon/manifest.json @@ -0,0 +1,41 @@ +{ + "name": "Qortal", + "icons": [ + { + "src": "\/android-icon-36x36.png", + "sizes": "36x36", + "type": "image\/png", + "density": "0.75" + }, + { + "src": "\/android-icon-48x48.png", + "sizes": "48x48", + "type": "image\/png", + "density": "1.0" + }, + { + "src": "\/android-icon-72x72.png", + "sizes": "72x72", + "type": "image\/png", + "density": "1.5" + }, + { + "src": "\/android-icon-96x96.png", + "sizes": "96x96", + "type": "image\/png", + "density": "2.0" + }, + { + "src": "\/android-icon-144x144.png", + "sizes": "144x144", + "type": "image\/png", + "density": "3.0" + }, + { + "src": "\/android-icon-192x192.png", + "sizes": "192x192", + "type": "image\/png", + "density": "4.0" + } + ] +} \ No newline at end of file diff --git a/img/favicon/ms-icon-144x144.png b/img/favicon/ms-icon-144x144.png new file mode 100644 index 00000000..2e61cc45 Binary files /dev/null and b/img/favicon/ms-icon-144x144.png differ diff --git a/img/favicon/ms-icon-150x150.png b/img/favicon/ms-icon-150x150.png new file mode 100644 index 00000000..76c7b9f0 Binary files /dev/null and b/img/favicon/ms-icon-150x150.png differ diff --git a/img/favicon/ms-icon-310x310.png b/img/favicon/ms-icon-310x310.png new file mode 100644 index 00000000..f081e4c9 Binary files /dev/null and b/img/favicon/ms-icon-310x310.png differ diff --git a/img/favicon/ms-icon-70x70.png b/img/favicon/ms-icon-70x70.png new file mode 100644 index 00000000..b9354a12 Binary files /dev/null and b/img/favicon/ms-icon-70x70.png differ diff --git a/img/hexagon_bg.png b/img/hexagon_bg.png new file mode 100644 index 00000000..812324b6 Binary files /dev/null and b/img/hexagon_bg.png differ diff --git a/img/icons/icns/256x256.icns b/img/icons/icns/256x256.icns new file mode 100644 index 00000000..a96cdfc5 Binary files /dev/null and b/img/icons/icns/256x256.icns differ diff --git a/img/icons/icns/64x64.icns b/img/icons/icns/64x64.icns new file mode 100644 index 00000000..facb28d8 Binary files /dev/null and b/img/icons/icns/64x64.icns differ diff --git a/img/icons/ico/128x128.ico b/img/icons/ico/128x128.ico new file mode 100644 index 00000000..b34cf901 Binary files /dev/null and b/img/icons/ico/128x128.ico differ diff --git a/img/icons/ico/16x16.ico b/img/icons/ico/16x16.ico new file mode 100644 index 00000000..dae58a4f Binary files /dev/null and b/img/icons/ico/16x16.ico differ diff --git a/img/icons/ico/24x24.ico b/img/icons/ico/24x24.ico new file mode 100644 index 00000000..026aeffe Binary files /dev/null and b/img/icons/ico/24x24.ico differ diff --git a/img/icons/ico/256x256.ico b/img/icons/ico/256x256.ico new file mode 100644 index 00000000..99f19efc Binary files /dev/null and b/img/icons/ico/256x256.ico differ diff --git a/img/icons/ico/32x32.ico b/img/icons/ico/32x32.ico new file mode 100644 index 00000000..25fc38d6 Binary files /dev/null and b/img/icons/ico/32x32.ico differ diff --git a/img/icons/ico/48x48.ico b/img/icons/ico/48x48.ico new file mode 100644 index 00000000..b08ed0eb Binary files /dev/null and b/img/icons/ico/48x48.ico differ diff --git a/img/icons/ico/64x64.ico b/img/icons/ico/64x64.ico new file mode 100644 index 00000000..4d66e198 Binary files /dev/null and b/img/icons/ico/64x64.ico differ diff --git a/img/icons/ico/96x96.ico b/img/icons/ico/96x96.ico new file mode 100644 index 00000000..7284849c Binary files /dev/null and b/img/icons/ico/96x96.ico differ diff --git a/img/icons/icon.icns b/img/icons/icon.icns new file mode 100644 index 00000000..585a50c7 Binary files /dev/null and b/img/icons/icon.icns differ diff --git a/img/icons/icon.ico b/img/icons/icon.ico new file mode 100644 index 00000000..99f19efc Binary files /dev/null and b/img/icons/icon.ico differ diff --git a/img/icons/icon.png b/img/icons/icon.png new file mode 100644 index 00000000..35b247a3 Binary files /dev/null and b/img/icons/icon.png differ diff --git a/img/icons/png/1024x1024.png b/img/icons/png/1024x1024.png new file mode 100644 index 00000000..2b4e0d83 Binary files /dev/null and b/img/icons/png/1024x1024.png differ diff --git a/img/icons/png/128x128.png b/img/icons/png/128x128.png new file mode 100644 index 00000000..35b247a3 Binary files /dev/null and b/img/icons/png/128x128.png differ diff --git a/img/icons/png/16x16.png b/img/icons/png/16x16.png new file mode 100644 index 00000000..8804297b Binary files /dev/null and b/img/icons/png/16x16.png differ diff --git a/img/icons/png/24x24.png b/img/icons/png/24x24.png new file mode 100644 index 00000000..c24eb414 Binary files /dev/null and b/img/icons/png/24x24.png differ diff --git a/img/icons/png/256x256.png b/img/icons/png/256x256.png new file mode 100644 index 00000000..5b1df7a8 Binary files /dev/null and b/img/icons/png/256x256.png differ diff --git a/img/icons/png/32x32.png b/img/icons/png/32x32.png new file mode 100644 index 00000000..f97882fd Binary files /dev/null and b/img/icons/png/32x32.png differ diff --git a/img/icons/png/48x48.png b/img/icons/png/48x48.png new file mode 100644 index 00000000..16683daf Binary files /dev/null and b/img/icons/png/48x48.png differ diff --git a/img/icons/png/512x512.png b/img/icons/png/512x512.png new file mode 100644 index 00000000..548576f4 Binary files /dev/null and b/img/icons/png/512x512.png differ diff --git a/img/icons/png/64x64.png b/img/icons/png/64x64.png new file mode 100644 index 00000000..5bcfd37e Binary files /dev/null and b/img/icons/png/64x64.png differ diff --git a/img/icons/png/96x96.png b/img/icons/png/96x96.png new file mode 100644 index 00000000..bb882a0e Binary files /dev/null and b/img/icons/png/96x96.png differ diff --git a/img/icons/qortal-ui.png b/img/icons/qortal-ui.png new file mode 100644 index 00000000..548576f4 Binary files /dev/null and b/img/icons/qortal-ui.png differ diff --git a/img/ltc.png b/img/ltc.png new file mode 100644 index 00000000..d743e57f Binary files /dev/null and b/img/ltc.png differ diff --git a/img/ltc_transparent.png b/img/ltc_transparent.png new file mode 100644 index 00000000..a4db0b83 Binary files /dev/null and b/img/ltc_transparent.png differ diff --git a/img/qort.png b/img/qort.png new file mode 100644 index 00000000..39d090f7 Binary files /dev/null and b/img/qort.png differ diff --git a/img/qort_transparent.png b/img/qort_transparent.png new file mode 100644 index 00000000..2d29afa4 Binary files /dev/null and b/img/qort_transparent.png differ diff --git a/img/qortal.ico b/img/qortal.ico new file mode 100644 index 00000000..df8ac70f Binary files /dev/null and b/img/qortal.ico differ diff --git a/img/qortal_background_light_.jpg b/img/qortal_background_light_.jpg new file mode 100644 index 00000000..b9a93c79 Binary files /dev/null and b/img/qortal_background_light_.jpg differ diff --git a/img/qortdoge.png b/img/qortdoge.png new file mode 100644 index 00000000..b8d0a420 Binary files /dev/null and b/img/qortdoge.png differ diff --git a/img/qortltc.png b/img/qortltc.png new file mode 100644 index 00000000..9526946a Binary files /dev/null and b/img/qortltc.png differ diff --git a/img/rvn.png b/img/rvn.png new file mode 100644 index 00000000..31d7fddd Binary files /dev/null and b/img/rvn.png differ diff --git a/img/rvn_transparent.png b/img/rvn_transparent.png new file mode 100644 index 00000000..c5205d03 Binary files /dev/null and b/img/rvn_transparent.png differ diff --git a/img/win-installer-sidebar.bmp b/img/win-installer-sidebar.bmp new file mode 100644 index 00000000..02dc6796 Binary files /dev/null and b/img/win-installer-sidebar.bmp differ diff --git a/img/win-uninstaller-sidebar.bmp b/img/win-uninstaller-sidebar.bmp new file mode 100644 index 00000000..02dc6796 Binary files /dev/null and b/img/win-uninstaller-sidebar.bmp differ diff --git a/install-dependencies.sh b/install-dependencies.sh new file mode 100644 index 00000000..23cdec1d --- /dev/null +++ b/install-dependencies.sh @@ -0,0 +1,71 @@ +#!/bin/sh + +# Qortal Blockchain Project - 2021 + +# Travis Script to install dependencies... + +set -ev + +# install every repository needed, install dependencies, clone git repos, do yarn linking and building, and build and run final UI + +install_dependencies() +{ + echo -e '---INSTALLING DEPENDENCIES!---' + echo -e '---INSTALLING ALL UI REPOSITORIES---' + + cd ../ + cd qortal-ui-core + yarn install --pure-lockfile + cd ../ + mkdir qortal-ui/qortal-ui-core + rsync -a qortal-ui-core/ qortal-ui/qortal-ui-core --exclude .git + cd qortal-ui/qortal-ui-core + yarn link + cd ../../ + + cd qortal-ui-plugins + yarn install --pure-lockfile + cd ../ + mkdir qortal-ui/qortal-ui-plugins + rsync -a qortal-ui-plugins/ qortal-ui/qortal-ui-plugins --exclude .git + cd qortal-ui/qortal-ui-plugins + yarn link + cd ../../ + + cd qortal-ui-crypto + yarn install --pure-lockfile + cd ../ + mkdir qortal-ui/qortal-ui-crypto + rsync -a qortal-ui-crypto/ qortal-ui/qortal-ui-crypto --exclude .git + cd qortal-ui/qortal-ui-crypto + yarn link + cd ../ + + echo -e '---INSTALL ALL DEPENDENCIES---' + yarn install --pure-lockfile + + echo -e '---LINKING UI FOLDERS ---' + yarn link qortal-ui-core + yarn link qortal-ui-crypto + yarn link qortal-ui-plugins + + echo -e '---BUILDING UI DEPENDENCIES!---' + yarn build + + echo -e '---UPDATE PACKAGE-JSON UI DEPENDENCIES!---' + yarn update-package-json + + echo -e '---REMOVE MODULES AND UNUSED DEPENDENCIES!---' + cd qortal-ui-core + yarn install --production --ignore-scripts --prefer-offline + cd ../ + cd qortal-ui-plugins + rm -R node_modules + cd ../ + cd qortal-ui-crypto + rm -R node_modules + cd ../ + rm -R qortal-ui-crypto +} + +install_dependencies diff --git a/package.json b/package.json new file mode 100644 index 00000000..e58cf92d --- /dev/null +++ b/package.json @@ -0,0 +1,44 @@ +{ + "name": "qortal-ui", + "version": "1.6.2", + "description": "Qortal Project - decentralize the world - Data storage, communications, web hosting, decentralized trading, complete infrastructure for the future blockchain-based Internet", + "keywords": [ + "QORT", + "QORTAL", + "DECENTRALIZED" + ], + "main": "electron.js", + "repository": { + "type": "git", + "url": "git+https://github.com/Qortal/qortal-ui.git" + }, + "homepage": "https://qortal.org", + "author": "QORTAL ", + "license": "GPL-3.0", + "scripts": { + "dev": "node server.js", + "build-dev": "node build.js", + "build": "NODE_ENV=production node build.js", + "server": "NODE_ENV=production node server.js", + "watch": "node watch.js", + "watch-inline": "node watch-inline.js", + "start-electron": "NODE_ENV=production electron .", + "build-electron": "electron-builder build --publish never", + "deploy-electron": "electron-builder build --win --publish never", + "release": "NODE_ENV=production electron-builder build --publish never", + "update-package-json": "node update-package-json.js", + "publish": "electron-builder -p always" + }, + "dependencies": { + "electron-updater": "4.3.9", + "electron-log": "4.4.1" + }, + "devDependencies": { + "electron": "11.5.0", + "electron-builder": "22.14.5" + "shelljs": "0.8.4" + }, + "engines": { + "node": ">=14.17.0" + } +} diff --git a/push-updates-with-travis-build.sh b/push-updates-with-travis-build.sh new file mode 100644 index 00000000..7abe8254 --- /dev/null +++ b/push-updates-with-travis-build.sh @@ -0,0 +1,42 @@ +#!/bin/sh + +set -x + +setup_git() { + git config --global user.email "travis@travis-ci.org" + git config --global user.name "Travis CI" +} + +commit_version_push() { + # Add New Remote + git remote add ci https://${GH_TOKEN}@github.com/${TRAVIS_REPO_SLUG}.git > /dev/null 2>&1 + # Show Remotes + git remote -v + # Create Version variable + newVersion=$(git describe --abbrev=0) + # Checkout and Switch to master branch + # git checkout master + # Disable yarn version-git-tag + yarn config set version-git-tag false + # Update package.json version + yarn version --new-version $newVersion + # Stage file for commit + git add package.json + # Create a new commit with a build version + git commit --message "Build Version: $newVersion" + # PUSH TO GITHUB + git push ci master +} + +setup_git + +commit_version_push + + +# # Attempt to commit to git only if "git commit" succeeded +# if [ $? -eq 0 ]; then +# echo "Commit the new version. Built and Pushing to GitHub" +# push_build +# else +# echo "Cannot commit new version" +# fi diff --git a/qortal-ui-core/.eslintignore b/qortal-ui-core/.eslintignore new file mode 100644 index 00000000..30bc1627 --- /dev/null +++ b/qortal-ui-core/.eslintignore @@ -0,0 +1 @@ +/node_modules \ No newline at end of file diff --git a/qortal-ui-core/.eslintrc.json b/qortal-ui-core/.eslintrc.json new file mode 100644 index 00000000..f7ac8a1b --- /dev/null +++ b/qortal-ui-core/.eslintrc.json @@ -0,0 +1,22 @@ +{ + "extends" : "standard", + "rules": { + "indent": [ + "error", + 4, + { + "SwitchCase": 1 + } + ] + }, + "env": { + "es6": true, + "browser": true, + "worker": true + }, + "parser": "babel-eslint", + "parserOptions": { + "sourceType": "module", + "allowImportExportEverywhere": true + } +} \ No newline at end of file diff --git a/qortal-ui-core/config/config.js b/qortal-ui-core/config/config.js new file mode 100644 index 00000000..2e228fbc --- /dev/null +++ b/qortal-ui-core/config/config.js @@ -0,0 +1,7 @@ +const coin = require('./default.coin.config.js') +const crypto = require('./default.crypto.config.js') +const user = require('./default.user.config.js') +const styles = require('./default.styles.config.js') +const build = require('./default.build.options.js') + +module.exports = { coin, crypto, user, styles, build } diff --git a/qortal-ui-core/config/default.build.options.js b/qortal-ui-core/config/default.build.options.js new file mode 100644 index 00000000..fd72d49e --- /dev/null +++ b/qortal-ui-core/config/default.build.options.js @@ -0,0 +1,134 @@ +const path = require('path') + +const { makeSourceAbsolute } = require('../tooling/utils.js') +const srcDir = '../src' + +const options = { + inputFile: path.join(__dirname, '../src/main.js'), + outputDir: path.join(__dirname, '../build'), + sassOutputDir: path.join(__dirname, '../build/styles.bundle.css'), + imgDir: path.join(__dirname, '../img') +} + +const aliases = { + 'qortal-ui-crypto': 'node_modules/qortal-ui-crypto/api.js' +} + +const apiComponents = { + // All the do stuff imports...such as login(...) and logout() + api: { + file: 'api/api.js', + className: 'api' + } +} + + +const functionalComponents = { + 'loading-ripple': { + file: 'functional-components/loading-ripple.js', + className: 'LoadingRipple' + }, + 'confirm-transaction-dialog': { + file: 'functional-components/confirm-transaction-dialog', + className: 'ConfirmTransactionDialog' + } +} + +// Inlines all dependencies... transpiles to es5 +const inlineComponents = [ + { + className: 'worker', + input: path.join(__dirname, srcDir, 'worker.js'), + output: 'worker.js' + }, + { + className: 'PluginMainJSLoader', + input: path.join(__dirname, srcDir, '/plugins/plugin-mainjs-loader.js'), + output: 'plugins/plugin-mainjs-loader.js' + } +] + +const elementComponents = { + 'main-app': { + file: 'components/main-app.js', + className: 'MainApp', + children: { + 'app-styles': { + file: 'styles/app-styles.js', + className: 'AppStyles', + children: { + 'app-theme': { + className: 'AppTheme', + file: 'styles/app-theme.js' + } + } + }, + 'app-view': { + file: 'components/app-view.js', + className: 'AppView', + children: { + 'show-plugin': { + file: 'components/show-plugin.js', + className: 'ShowPlugin' + }, + 'sidenav-menu': { + file: 'components/sidenav-menu.js', + className: 'SidenavMenu' + }, + 'wallet-profile': { + file: 'components/wallet-profile.js', + className: 'WalletProfile' + }, + 'app-info': { + file: 'components/app-info.js', + className: 'AppInfo' + } + } + }, + 'login-view': { + file: 'components/login-view/login-view.js', + className: 'LoginView', + children: { + 'create-account-section': { + file: 'components/login-view/create-account-section.js', + className: 'CreateAccountSection' + }, + 'login-section': { + file: 'components/login-view/login-section.js', + className: 'LoginSection' + } + } + }, + 'settings-view': { + file: 'components/settings-view/user-settings.js', + className: 'UserSettings', + children: { + 'account-view': { + file: 'components/settings-view/account-view.js', + className: 'AccountView' + }, + 'security-view': { + file: 'components/settings-view/security-view.js', + className: 'SecurityView' + }, + 'notifications-view': { + file: 'components/settings-view/notifications-view.js', + className: 'NotificationsView' + } + } + } + } + } +} + +makeSourceAbsolute(path.join(__dirname, srcDir), elementComponents) +makeSourceAbsolute(path.join(__dirname, srcDir), functionalComponents) + +module.exports = { + options, + elementComponents, + functionalComponents, + inlineComponents, + apiComponents, + aliases +} diff --git a/qortal-ui-core/config/default.coin.config.js b/qortal-ui-core/config/default.coin.config.js new file mode 100644 index 00000000..ef1dbb00 --- /dev/null +++ b/qortal-ui-core/config/default.coin.config.js @@ -0,0 +1,11 @@ +const coin = { + name: 'Qortal', + symbol: 'QORT', + addressCount: 1, + addressVersion: 58, + decimals: 100000000, + logo: '/img/QORT_LOGO.png', + icon: '/img/QORT_LOGO.png' +} + +module.exports = coin diff --git a/qortal-ui-core/config/default.crypto.config.js b/qortal-ui-core/config/default.crypto.config.js new file mode 100644 index 00000000..f8a1b22d --- /dev/null +++ b/qortal-ui-core/config/default.crypto.config.js @@ -0,0 +1,11 @@ +const crypto = { + kdfThreads: 16, + staticSalt: '4ghkVQExoneGqZqHTMMhhFfxXsVg2A75QeS1HCM5KAih', // Base58 encoded + bcryptRounds: 11, // Note it's kinda bcryptRounds * log.2.16, cause it runs on all 16 threads + bcryptVersion: '2a', + get staticBcryptSalt () { + return `$${this.bcryptVersion}$${this.bcryptRounds}$IxVE941tXVUD4cW0TNVm.O` + } +} + +module.exports = crypto diff --git a/qortal-ui-core/config/default.styles.config.js b/qortal-ui-core/config/default.styles.config.js new file mode 100644 index 00000000..572e7bc8 --- /dev/null +++ b/qortal-ui-core/config/default.styles.config.js @@ -0,0 +1,51 @@ +const styles = { + breakpoints: { + tablet: '', + desktop: '', + mobile: '' + }, + theme: { + colors: { + // primary: '#64ffda', /* Sets the text color to the theme primary color. */ + primary: '#03a9f4', /* Sets the text color to the theme primary color. */ + primaryBg: '#e8eaf6', /* Sets the background color to the theme primary color. */ + onPrimary: '#fff', /* Sets the text color to the color configured for text on the primary color. */ + + secondary: '#03a9f4', /* Sets the text color to the theme secondary color. */ + secondaryBg: '#fce4ec', /* Sets the background color to the theme secondary color. */ + onSecondary: '#fff', /* Sets the text color to the color configured for text on the secondary color. */ + + surface: '#fff', /* Sets the background color to the surface background color. */ + onSurface: '#333', /* Sets the text color to the color configured for text on the surface color. */ + background: '#eee', /* Sets the background color to the theme background color. */ + + warning: '#FFA000', + error: '#F44336' + }, + + addressColors: [ + '#256480', + '#002530', + '#02564e', + '#d32f2f', + '#795548', + '#004d40', + '#006064', + '#9c27b0', + '#2196f3', + '#d81b60' + ] + }, + // Will make theme be calculated from config.styles.themes[config.user.theme]... or make theme the base..so it becomes theme = {...config.styles.theme, ...config.styles.themes[config.user.theme]} + themes: { + light: { + // ... + }, + dark: { + // ... + } + // And more... perhaps installable or user definable, like slack (...used to be? haven't been on it in ages) + } +} + +module.exports = styles diff --git a/qortal-ui-core/config/default.user.config.js b/qortal-ui-core/config/default.user.config.js new file mode 100644 index 00000000..209755b1 --- /dev/null +++ b/qortal-ui-core/config/default.user.config.js @@ -0,0 +1,92 @@ +const path = require('path') + +const user = { + // management can be enabled as explicit for public API servers when needed + node: 0, + knownNodes: [ + // Mainnet nodes + { + protocol: 'http', + domain: '127.0.0.1', + port: 12391, + enableManagement: true, + }, + { + protocol: 'http', + domain: 'node1.qortal.org', + port: 12391, + enableManagement: false, + }, + { + protocol: 'http', + domain: 'node2.qortal.org', + port: 12391, + enableManagement: false, + }, + // Testnet nodes + { + protocol: 'http', + domain: '127.0.0.1', + port: 62391, + enableManagement: false, + }, + { + protocol: 'http', + domain: 'node1.qortal.org', + port: 62391, + enableManagement: false, + }, + { + protocol: 'http', + domain: 'node2.qortal.org', + port: 62391, + enableManagement: false, + }, + + ], + nodeSettings: { + pingInterval: 10 * 1000, // (10 secs) + }, + version: '1.6.2', // TODO: Set this dynamically... + language: 'english', // default...english + theme: 'light', + server: { + writeHosts: { + enabled: true, + }, + relativeTo: path.join(__dirname, '../'), + primary: { + domain: '0.0.0.0', + address: '0.0.0.0', + port: 12388, + directory: './src/', + page404: './src/404.html', + host: '0.0.0.0', + }, + }, + tls: { + enabled: false, + options: { + key: '', + cert: '', + }, + }, + constants: { + pollingInterval: 10000, // How long between checking for new unconfirmed transactions and new blocks (in milliseconds). + workerURL: '/build/worker.js', + }, + + // Notification Settings (All defaults to true) + notifications: { + q_chat: { + playSound: true, + showNotification: true, + }, + block: { + playSound: true, + showNotification: true, + }, + }, +} + +module.exports = user diff --git a/qortal-ui-core/config/load-config.js b/qortal-ui-core/config/load-config.js new file mode 100644 index 00000000..c6d7ae44 --- /dev/null +++ b/qortal-ui-core/config/load-config.js @@ -0,0 +1,21 @@ +let config = require('./config.js') + +const checkKeys = (storeObj, newObj) => { + for (const key in newObj) { + if (!Object.prototype.hasOwnProperty.call(storeObj, key)) return + + if (typeof newObj[key] === 'object') { + storeObj[key] = checkKeys(storeObj[key], newObj[key]) + } else { + storeObj[key] = newObj[key] + } + } + return storeObj +} + +const getConfig = customConfig => { + config = checkKeys(config, customConfig) + return config +} + +module.exports = getConfig diff --git a/qortal-ui-core/emoji/LICENSE b/qortal-ui-core/emoji/LICENSE new file mode 100644 index 00000000..9aabe2db --- /dev/null +++ b/qortal-ui-core/emoji/LICENSE @@ -0,0 +1,19 @@ +Copyright (c) 2018 Twitter, Inc and other contributors + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. \ No newline at end of file diff --git a/qortal-ui-core/emoji/LICENSE-GRAPHICS b/qortal-ui-core/emoji/LICENSE-GRAPHICS new file mode 100644 index 00000000..dc8853a7 --- /dev/null +++ b/qortal-ui-core/emoji/LICENSE-GRAPHICS @@ -0,0 +1,393 @@ +Attribution 4.0 International + +======================================================================= + +Creative Commons Corporation ("Creative Commons") is not a law firm and +does not provide legal services or legal advice. Distribution of +Creative Commons public licenses does not create a lawyer-client or +other relationship. Creative Commons makes its licenses and related +information available on an "as-is" basis. Creative Commons gives no +warranties regarding its licenses, any material licensed under their +terms and conditions, or any related information. Creative Commons +disclaims all liability for damages resulting from their use to the +fullest extent possible. + +Using Creative Commons Public Licenses + +Creative Commons public licenses provide a standard set of terms and +conditions that creators and other rights holders may use to share +original works of authorship and other material subject to copyright +and certain other rights specified in the public license below. The +following considerations are for informational purposes only, are not +exhaustive, and do not form part of our licenses. + + Considerations for licensors: Our public licenses are + intended for use by those authorized to give the public + permission to use material in ways otherwise restricted by + copyright and certain other rights. Our licenses are + irrevocable. Licensors should read and understand the terms + and conditions of the license they choose before applying it. + Licensors should also secure all rights necessary before + applying our licenses so that the public can reuse the + material as expected. Licensors should clearly mark any + material not subject to the license. This includes other CC- + licensed material, or material used under an exception or + limitation to copyright. More considerations for licensors: + wiki.creativecommons.org/Considerations_for_licensors + + Considerations for the public: By using one of our public + licenses, a licensor grants the public permission to use the + licensed material under specified terms and conditions. If + the licensor's permission is not necessary for any reason--for + example, because of any applicable exception or limitation to + copyright--then that use is not regulated by the license. Our + licenses grant only permissions under copyright and certain + other rights that a licensor has authority to grant. Use of + the licensed material may still be restricted for other + reasons, including because others have copyright or other + rights in the material. A licensor may make special requests, + such as asking that all changes be marked or described. + Although not required by our licenses, you are encouraged to + respect those requests where reasonable. More_considerations + for the public: + wiki.creativecommons.org/Considerations_for_licensees + +======================================================================= + +Creative Commons Attribution 4.0 International Public License + +By exercising the Licensed Rights (defined below), You accept and agree +to be bound by the terms and conditions of this Creative Commons +Attribution 4.0 International Public License ("Public License"). To the +extent this Public License may be interpreted as a contract, You are +granted the Licensed Rights in consideration of Your acceptance of +these terms and conditions, and the Licensor grants You such rights in +consideration of benefits the Licensor receives from making the +Licensed Material available under these terms and conditions. + + +Section 1 -- Definitions. + + a. Adapted Material means material subject to Copyright and Similar + Rights that is derived from or based upon the Licensed Material + and in which the Licensed Material is translated, altered, + arranged, transformed, or otherwise modified in a manner requiring + permission under the Copyright and Similar Rights held by the + Licensor. For purposes of this Public License, where the Licensed + Material is a musical work, performance, or sound recording, + Adapted Material is always produced where the Licensed Material is + synched in timed relation with a moving image. + + b. Adapter's License means the license You apply to Your Copyright + and Similar Rights in Your contributions to Adapted Material in + accordance with the terms and conditions of this Public License. + + c. Copyright and Similar Rights means copyright and/or similar rights + closely related to copyright including, without limitation, + performance, broadcast, sound recording, and Sui Generis Database + Rights, without regard to how the rights are labeled or + categorized. For purposes of this Public License, the rights + specified in Section 2(b)(1)-(2) are not Copyright and Similar + Rights. + + d. Effective Technological Measures means those measures that, in the + absence of proper authority, may not be circumvented under laws + fulfilling obligations under Article 11 of the WIPO Copyright + Treaty adopted on December 20, 1996, and/or similar international + agreements. + + e. Exceptions and Limitations means fair use, fair dealing, and/or + any other exception or limitation to Copyright and Similar Rights + that applies to Your use of the Licensed Material. + + f. Licensed Material means the artistic or literary work, database, + or other material to which the Licensor applied this Public + License. + + g. Licensed Rights means the rights granted to You subject to the + terms and conditions of this Public License, which are limited to + all Copyright and Similar Rights that apply to Your use of the + Licensed Material and that the Licensor has authority to license. + + h. Licensor means the individual(s) or entity(ies) granting rights + under this Public License. + + i. Share means to provide material to the public by any means or + process that requires permission under the Licensed Rights, such + as reproduction, public display, public performance, distribution, + dissemination, communication, or importation, and to make material + available to the public including in ways that members of the + public may access the material from a place and at a time + individually chosen by them. + + j. Sui Generis Database Rights means rights other than copyright + resulting from Directive 96/9/EC of the European Parliament and of + the Council of 11 March 1996 on the legal protection of databases, + as amended and/or succeeded, as well as other essentially + equivalent rights anywhere in the world. + + k. You means the individual or entity exercising the Licensed Rights + under this Public License. Your has a corresponding meaning. + + +Section 2 -- Scope. + + a. License grant. + + 1. Subject to the terms and conditions of this Public License, + the Licensor hereby grants You a worldwide, royalty-free, + non-sublicensable, non-exclusive, irrevocable license to + exercise the Licensed Rights in the Licensed Material to: + + a. reproduce and Share the Licensed Material, in whole or + in part; and + + b. produce, reproduce, and Share Adapted Material. + + 2. Exceptions and Limitations. For the avoidance of doubt, where + Exceptions and Limitations apply to Your use, this Public + License does not apply, and You do not need to comply with + its terms and conditions. + + 3. Term. The term of this Public License is specified in Section + 6(a). + + 4. Media and formats; technical modifications allowed. The + Licensor authorizes You to exercise the Licensed Rights in + all media and formats whether now known or hereafter created, + and to make technical modifications necessary to do so. The + Licensor waives and/or agrees not to assert any right or + authority to forbid You from making technical modifications + necessary to exercise the Licensed Rights, including + technical modifications necessary to circumvent Effective + Technological Measures. For purposes of this Public License, + simply making modifications authorized by this Section 2(a) + (4) never produces Adapted Material. + + 5. Downstream recipients. + + a. Offer from the Licensor -- Licensed Material. Every + recipient of the Licensed Material automatically + receives an offer from the Licensor to exercise the + Licensed Rights under the terms and conditions of this + Public License. + + b. No downstream restrictions. You may not offer or impose + any additional or different terms or conditions on, or + apply any Effective Technological Measures to, the + Licensed Material if doing so restricts exercise of the + Licensed Rights by any recipient of the Licensed + Material. + + 6. No endorsement. Nothing in this Public License constitutes or + may be construed as permission to assert or imply that You + are, or that Your use of the Licensed Material is, connected + with, or sponsored, endorsed, or granted official status by, + the Licensor or others designated to receive attribution as + provided in Section 3(a)(1)(A)(i). + + b. Other rights. + + 1. Moral rights, such as the right of integrity, are not + licensed under this Public License, nor are publicity, + privacy, and/or other similar personality rights; however, to + the extent possible, the Licensor waives and/or agrees not to + assert any such rights held by the Licensor to the limited + extent necessary to allow You to exercise the Licensed + Rights, but not otherwise. + + 2. Patent and trademark rights are not licensed under this + Public License. + + 3. To the extent possible, the Licensor waives any right to + collect royalties from You for the exercise of the Licensed + Rights, whether directly or through a collecting society + under any voluntary or waivable statutory or compulsory + licensing scheme. In all other cases the Licensor expressly + reserves any right to collect such royalties. + + +Section 3 -- License Conditions. + +Your exercise of the Licensed Rights is expressly made subject to the +following conditions. + + a. Attribution. + + 1. If You Share the Licensed Material (including in modified + form), You must: + + a. retain the following if it is supplied by the Licensor + with the Licensed Material: + + i. identification of the creator(s) of the Licensed + Material and any others designated to receive + attribution, in any reasonable manner requested by + the Licensor (including by pseudonym if + designated); + + ii. a copyright notice; + + iii. a notice that refers to this Public License; + + iv. a notice that refers to the disclaimer of + warranties; + + v. a URI or hyperlink to the Licensed Material to the + extent reasonably practicable; + + b. indicate if You modified the Licensed Material and + retain an indication of any previous modifications; and + + c. indicate the Licensed Material is licensed under this + Public License, and include the text of, or the URI or + hyperlink to, this Public License. + + 2. You may satisfy the conditions in Section 3(a)(1) in any + reasonable manner based on the medium, means, and context in + which You Share the Licensed Material. For example, it may be + reasonable to satisfy the conditions by providing a URI or + hyperlink to a resource that includes the required + information. + + 3. If requested by the Licensor, You must remove any of the + information required by Section 3(a)(1)(A) to the extent + reasonably practicable. + + 4. If You Share Adapted Material You produce, the Adapter's + License You apply must not prevent recipients of the Adapted + Material from complying with this Public License. + + +Section 4 -- Sui Generis Database Rights. + +Where the Licensed Rights include Sui Generis Database Rights that +apply to Your use of the Licensed Material: + + a. for the avoidance of doubt, Section 2(a)(1) grants You the right + to extract, reuse, reproduce, and Share all or a substantial + portion of the contents of the database; + + b. if You include all or a substantial portion of the database + contents in a database in which You have Sui Generis Database + Rights, then the database in which You have Sui Generis Database + Rights (but not its individual contents) is Adapted Material; and + + c. You must comply with the conditions in Section 3(a) if You Share + all or a substantial portion of the contents of the database. + +For the avoidance of doubt, this Section 4 supplements and does not +replace Your obligations under this Public License where the Licensed +Rights include other Copyright and Similar Rights. + + +Section 5 -- Disclaimer of Warranties and Limitation of Liability. + + a. UNLESS OTHERWISE SEPARATELY UNDERTAKEN BY THE LICENSOR, TO THE + EXTENT POSSIBLE, THE LICENSOR OFFERS THE LICENSED MATERIAL AS-IS + AND AS-AVAILABLE, AND MAKES NO REPRESENTATIONS OR WARRANTIES OF + ANY KIND CONCERNING THE LICENSED MATERIAL, WHETHER EXPRESS, + IMPLIED, STATUTORY, OR OTHER. THIS INCLUDES, WITHOUT LIMITATION, + WARRANTIES OF TITLE, MERCHANTABILITY, FITNESS FOR A PARTICULAR + PURPOSE, NON-INFRINGEMENT, ABSENCE OF LATENT OR OTHER DEFECTS, + ACCURACY, OR THE PRESENCE OR ABSENCE OF ERRORS, WHETHER OR NOT + KNOWN OR DISCOVERABLE. WHERE DISCLAIMERS OF WARRANTIES ARE NOT + ALLOWED IN FULL OR IN PART, THIS DISCLAIMER MAY NOT APPLY TO YOU. + + b. TO THE EXTENT POSSIBLE, IN NO EVENT WILL THE LICENSOR BE LIABLE + TO YOU ON ANY LEGAL THEORY (INCLUDING, WITHOUT LIMITATION, + NEGLIGENCE) OR OTHERWISE FOR ANY DIRECT, SPECIAL, INDIRECT, + INCIDENTAL, CONSEQUENTIAL, PUNITIVE, EXEMPLARY, OR OTHER LOSSES, + COSTS, EXPENSES, OR DAMAGES ARISING OUT OF THIS PUBLIC LICENSE OR + USE OF THE LICENSED MATERIAL, EVEN IF THE LICENSOR HAS BEEN + ADVISED OF THE POSSIBILITY OF SUCH LOSSES, COSTS, EXPENSES, OR + DAMAGES. WHERE A LIMITATION OF LIABILITY IS NOT ALLOWED IN FULL OR + IN PART, THIS LIMITATION MAY NOT APPLY TO YOU. + + c. The disclaimer of warranties and limitation of liability provided + above shall be interpreted in a manner that, to the extent + possible, most closely approximates an absolute disclaimer and + waiver of all liability. + + +Section 6 -- Term and Termination. + + a. This Public License applies for the term of the Copyright and + Similar Rights licensed here. However, if You fail to comply with + this Public License, then Your rights under this Public License + terminate automatically. + + b. Where Your right to use the Licensed Material has terminated under + Section 6(a), it reinstates: + + 1. automatically as of the date the violation is cured, provided + it is cured within 30 days of Your discovery of the + violation; or + + 2. upon express reinstatement by the Licensor. + + For the avoidance of doubt, this Section 6(b) does not affect any + right the Licensor may have to seek remedies for Your violations + of this Public License. + + c. For the avoidance of doubt, the Licensor may also offer the + Licensed Material under separate terms or conditions or stop + distributing the Licensed Material at any time; however, doing so + will not terminate this Public License. + + d. Sections 1, 5, 6, 7, and 8 survive termination of this Public + License. + + +Section 7 -- Other Terms and Conditions. + + a. The Licensor shall not be bound by any additional or different + terms or conditions communicated by You unless expressly agreed. + + b. Any arrangements, understandings, or agreements regarding the + Licensed Material not stated herein are separate from and + independent of the terms and conditions of this Public License. + + +Section 8 -- Interpretation. + + a. For the avoidance of doubt, this Public License does not, and + shall not be interpreted to, reduce, limit, restrict, or impose + conditions on any use of the Licensed Material that could lawfully + be made without permission under this Public License. + + b. To the extent possible, if any provision of this Public License is + deemed unenforceable, it shall be automatically reformed to the + minimum extent necessary to make it enforceable. If the provision + cannot be reformed, it shall be severed from this Public License + without affecting the enforceability of the remaining terms and + conditions. + + c. No term or condition of this Public License will be waived and no + failure to comply consented to unless expressly agreed to by the + Licensor. + + d. Nothing in this Public License constitutes or may be interpreted + as a limitation upon, or waiver of, any privileges and immunities + that apply to the Licensor or You, including from the legal + processes of any jurisdiction or authority. + + +======================================================================= + +Creative Commons is not a party to its public licenses. +Notwithstanding, Creative Commons may elect to apply one of its public +licenses to material it publishes and in those instances will be +considered the "Licensor." Except for the limited purpose of indicating +that material is shared under a Creative Commons public license or as +otherwise permitted by the Creative Commons policies published at +creativecommons.org/policies, Creative Commons does not authorize the +use of the trademark "Creative Commons" or any other trademark or logo +of Creative Commons without its prior written consent including, +without limitation, in connection with any unauthorized modifications +to any of its public licenses or any other arrangements, +understandings, or agreements concerning use of licensed material. For +the avoidance of doubt, this paragraph does not form part of the public +licenses. + +Creative Commons may be contacted at creativecommons.org. diff --git a/qortal-ui-core/emoji/svg/1f004.svg b/qortal-ui-core/emoji/svg/1f004.svg new file mode 100644 index 00000000..f4fa5844 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f004.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f0cf.svg b/qortal-ui-core/emoji/svg/1f0cf.svg new file mode 100644 index 00000000..0d05191c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f0cf.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f170.svg b/qortal-ui-core/emoji/svg/1f170.svg new file mode 100644 index 00000000..5555b84a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f170.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f171.svg b/qortal-ui-core/emoji/svg/1f171.svg new file mode 100644 index 00000000..f77618af --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f171.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f17e.svg b/qortal-ui-core/emoji/svg/1f17e.svg new file mode 100644 index 00000000..62f2f6d3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f17e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f17f.svg b/qortal-ui-core/emoji/svg/1f17f.svg new file mode 100644 index 00000000..8a494b8f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f17f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f18e.svg b/qortal-ui-core/emoji/svg/1f18e.svg new file mode 100644 index 00000000..d19a2a43 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f18e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f191.svg b/qortal-ui-core/emoji/svg/1f191.svg new file mode 100644 index 00000000..eaebb558 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f191.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f192.svg b/qortal-ui-core/emoji/svg/1f192.svg new file mode 100644 index 00000000..3207dcf6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f192.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f193.svg b/qortal-ui-core/emoji/svg/1f193.svg new file mode 100644 index 00000000..2dc2d6aa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f193.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f194.svg b/qortal-ui-core/emoji/svg/1f194.svg new file mode 100644 index 00000000..57962599 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f194.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f195.svg b/qortal-ui-core/emoji/svg/1f195.svg new file mode 100644 index 00000000..dcf5702a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f195.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f196.svg b/qortal-ui-core/emoji/svg/1f196.svg new file mode 100644 index 00000000..ccd7c36d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f196.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f197.svg b/qortal-ui-core/emoji/svg/1f197.svg new file mode 100644 index 00000000..1c42dae3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f197.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f198.svg b/qortal-ui-core/emoji/svg/1f198.svg new file mode 100644 index 00000000..6fe35a17 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f198.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f199.svg b/qortal-ui-core/emoji/svg/1f199.svg new file mode 100644 index 00000000..19ab1844 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f199.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f19a.svg b/qortal-ui-core/emoji/svg/1f19a.svg new file mode 100644 index 00000000..2d36646a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f19a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1e8.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1e8.svg new file mode 100644 index 00000000..53f90dc4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1e9.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1e9.svg new file mode 100644 index 00000000..be105947 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1ea.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1ea.svg new file mode 100644 index 00000000..be8e114a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1eb.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1eb.svg new file mode 100644 index 00000000..769efcad --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1ec.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1ec.svg new file mode 100644 index 00000000..27166172 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1ee.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1ee.svg new file mode 100644 index 00000000..6a91dd9d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1ee.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1f1.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1f1.svg new file mode 100644 index 00000000..2c8655dd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1f1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1f2.svg new file mode 100644 index 00000000..0a966ab8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1f4.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1f4.svg new file mode 100644 index 00000000..65803b64 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1f6.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1f6.svg new file mode 100644 index 00000000..fd29680f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1f6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1f7.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1f7.svg new file mode 100644 index 00000000..e8e60efd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1f8.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1f8.svg new file mode 100644 index 00000000..8b275322 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1f9.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1f9.svg new file mode 100644 index 00000000..bfe1ec7f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1fa.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1fa.svg new file mode 100644 index 00000000..989da76d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1fc.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1fc.svg new file mode 100644 index 00000000..f3839512 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1fd.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1fd.svg new file mode 100644 index 00000000..03bc680c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6-1f1ff.svg b/qortal-ui-core/emoji/svg/1f1e6-1f1ff.svg new file mode 100644 index 00000000..b5848545 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6-1f1ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e6.svg b/qortal-ui-core/emoji/svg/1f1e6.svg new file mode 100644 index 00000000..d3753d4a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1e6.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1e6.svg new file mode 100644 index 00000000..bbcd3b5e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1e7.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1e7.svg new file mode 100644 index 00000000..7f9e8c9d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1e7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1e9.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1e9.svg new file mode 100644 index 00000000..6edc8443 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1ea.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1ea.svg new file mode 100644 index 00000000..e9561943 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1eb.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1eb.svg new file mode 100644 index 00000000..8bceec74 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1ec.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1ec.svg new file mode 100644 index 00000000..6e81fba5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1ed.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1ed.svg new file mode 100644 index 00000000..73de5829 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1ee.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1ee.svg new file mode 100644 index 00000000..e53644c5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1ee.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1ef.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1ef.svg new file mode 100644 index 00000000..133d7112 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1ef.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1f1.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1f1.svg new file mode 100644 index 00000000..9d4904dd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1f1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1f2.svg new file mode 100644 index 00000000..5e7b7f69 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1f3.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1f3.svg new file mode 100644 index 00000000..3c20edb2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1f4.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1f4.svg new file mode 100644 index 00000000..ad0a8c9a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1f6.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1f6.svg new file mode 100644 index 00000000..bde49217 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1f6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1f7.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1f7.svg new file mode 100644 index 00000000..956e39d0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1f8.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1f8.svg new file mode 100644 index 00000000..a75f68bb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1f9.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1f9.svg new file mode 100644 index 00000000..e822f94f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1fb.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1fb.svg new file mode 100644 index 00000000..3d104a61 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1fc.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1fc.svg new file mode 100644 index 00000000..5edeb5d5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1fe.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1fe.svg new file mode 100644 index 00000000..3fef573b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7-1f1ff.svg b/qortal-ui-core/emoji/svg/1f1e7-1f1ff.svg new file mode 100644 index 00000000..6f43e4a7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7-1f1ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e7.svg b/qortal-ui-core/emoji/svg/1f1e7.svg new file mode 100644 index 00000000..52dcf7e9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1e6.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1e6.svg new file mode 100644 index 00000000..d9c386db --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1e8.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1e8.svg new file mode 100644 index 00000000..ce130d70 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1e9.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1e9.svg new file mode 100644 index 00000000..d1b15c99 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1eb.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1eb.svg new file mode 100644 index 00000000..72166cbe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1ec.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1ec.svg new file mode 100644 index 00000000..3d466e3d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1ed.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1ed.svg new file mode 100644 index 00000000..741b5214 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1ee.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1ee.svg new file mode 100644 index 00000000..bd2c3e06 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1ee.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1f0.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1f0.svg new file mode 100644 index 00000000..04e03444 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1f1.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1f1.svg new file mode 100644 index 00000000..52b3a007 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1f1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1f2.svg new file mode 100644 index 00000000..7da7b66a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1f3.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1f3.svg new file mode 100644 index 00000000..c10116d0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1f4.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1f4.svg new file mode 100644 index 00000000..dc825d24 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1f5.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1f5.svg new file mode 100644 index 00000000..4eafe7aa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1f5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1f7.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1f7.svg new file mode 100644 index 00000000..acecc895 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1fa.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1fa.svg new file mode 100644 index 00000000..13b63701 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1fb.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1fb.svg new file mode 100644 index 00000000..9b2cc18d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1fc.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1fc.svg new file mode 100644 index 00000000..c53d09f7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1fd.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1fd.svg new file mode 100644 index 00000000..6a322f57 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1fe.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1fe.svg new file mode 100644 index 00000000..19bead4d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8-1f1ff.svg b/qortal-ui-core/emoji/svg/1f1e8-1f1ff.svg new file mode 100644 index 00000000..fd3b4706 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8-1f1ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e8.svg b/qortal-ui-core/emoji/svg/1f1e8.svg new file mode 100644 index 00000000..80b6405c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e9-1f1ea.svg b/qortal-ui-core/emoji/svg/1f1e9-1f1ea.svg new file mode 100644 index 00000000..10a53999 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e9-1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e9-1f1ec.svg b/qortal-ui-core/emoji/svg/1f1e9-1f1ec.svg new file mode 100644 index 00000000..565a7aa4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e9-1f1ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e9-1f1ef.svg b/qortal-ui-core/emoji/svg/1f1e9-1f1ef.svg new file mode 100644 index 00000000..42cbb243 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e9-1f1ef.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e9-1f1f0.svg b/qortal-ui-core/emoji/svg/1f1e9-1f1f0.svg new file mode 100644 index 00000000..5ab629ba --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e9-1f1f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e9-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1e9-1f1f2.svg new file mode 100644 index 00000000..750424f7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e9-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e9-1f1f4.svg b/qortal-ui-core/emoji/svg/1f1e9-1f1f4.svg new file mode 100644 index 00000000..c627c34e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e9-1f1f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e9-1f1ff.svg b/qortal-ui-core/emoji/svg/1f1e9-1f1ff.svg new file mode 100644 index 00000000..c29a7e29 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e9-1f1ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1e9.svg b/qortal-ui-core/emoji/svg/1f1e9.svg new file mode 100644 index 00000000..24d64af3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ea-1f1e6.svg b/qortal-ui-core/emoji/svg/1f1ea-1f1e6.svg new file mode 100644 index 00000000..d1fd565c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ea-1f1e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ea-1f1e8.svg b/qortal-ui-core/emoji/svg/1f1ea-1f1e8.svg new file mode 100644 index 00000000..c035be7a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ea-1f1e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ea-1f1ea.svg b/qortal-ui-core/emoji/svg/1f1ea-1f1ea.svg new file mode 100644 index 00000000..47a55895 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ea-1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ea-1f1ec.svg b/qortal-ui-core/emoji/svg/1f1ea-1f1ec.svg new file mode 100644 index 00000000..2034a3e5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ea-1f1ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ea-1f1ed.svg b/qortal-ui-core/emoji/svg/1f1ea-1f1ed.svg new file mode 100644 index 00000000..9b8dc5a6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ea-1f1ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ea-1f1f7.svg b/qortal-ui-core/emoji/svg/1f1ea-1f1f7.svg new file mode 100644 index 00000000..8e1e510f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ea-1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ea-1f1f8.svg b/qortal-ui-core/emoji/svg/1f1ea-1f1f8.svg new file mode 100644 index 00000000..d1fd565c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ea-1f1f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ea-1f1f9.svg b/qortal-ui-core/emoji/svg/1f1ea-1f1f9.svg new file mode 100644 index 00000000..762cc1fb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ea-1f1f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ea-1f1fa.svg b/qortal-ui-core/emoji/svg/1f1ea-1f1fa.svg new file mode 100644 index 00000000..045024a3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ea-1f1fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ea.svg b/qortal-ui-core/emoji/svg/1f1ea.svg new file mode 100644 index 00000000..352b75e7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1eb-1f1ee.svg b/qortal-ui-core/emoji/svg/1f1eb-1f1ee.svg new file mode 100644 index 00000000..e07328ed --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1eb-1f1ee.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1eb-1f1ef.svg b/qortal-ui-core/emoji/svg/1f1eb-1f1ef.svg new file mode 100644 index 00000000..190134b5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1eb-1f1ef.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1eb-1f1f0.svg b/qortal-ui-core/emoji/svg/1f1eb-1f1f0.svg new file mode 100644 index 00000000..0091bc78 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1eb-1f1f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1eb-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1eb-1f1f2.svg new file mode 100644 index 00000000..b49556b5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1eb-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1eb-1f1f4.svg b/qortal-ui-core/emoji/svg/1f1eb-1f1f4.svg new file mode 100644 index 00000000..93a12728 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1eb-1f1f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1eb-1f1f7.svg b/qortal-ui-core/emoji/svg/1f1eb-1f1f7.svg new file mode 100644 index 00000000..4eafe7aa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1eb-1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1eb.svg b/qortal-ui-core/emoji/svg/1f1eb.svg new file mode 100644 index 00000000..22f9d3d7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1e6.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1e6.svg new file mode 100644 index 00000000..a8c6fa41 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1e7.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1e7.svg new file mode 100644 index 00000000..21b97e9f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1e7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1e9.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1e9.svg new file mode 100644 index 00000000..e4f37f95 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1ea.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1ea.svg new file mode 100644 index 00000000..8c2bd5a6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1eb.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1eb.svg new file mode 100644 index 00000000..2f10cee3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1ec.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1ec.svg new file mode 100644 index 00000000..84f60439 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1ed.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1ed.svg new file mode 100644 index 00000000..33302188 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1ee.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1ee.svg new file mode 100644 index 00000000..432a7272 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1ee.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1f1.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1f1.svg new file mode 100644 index 00000000..8a2ba3e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1f1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1f2.svg new file mode 100644 index 00000000..383cf9d3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1f3.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1f3.svg new file mode 100644 index 00000000..16f4a902 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1f5.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1f5.svg new file mode 100644 index 00000000..ca9e4c6a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1f5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1f6.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1f6.svg new file mode 100644 index 00000000..d4e7119f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1f6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1f7.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1f7.svg new file mode 100644 index 00000000..74d842d6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1f8.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1f8.svg new file mode 100644 index 00000000..d8b1e5fe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1f9.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1f9.svg new file mode 100644 index 00000000..fea623c9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1fa.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1fa.svg new file mode 100644 index 00000000..2098ecca --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1fc.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1fc.svg new file mode 100644 index 00000000..6e01b9e2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec-1f1fe.svg b/qortal-ui-core/emoji/svg/1f1ec-1f1fe.svg new file mode 100644 index 00000000..1edc6ef4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec-1f1fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ec.svg b/qortal-ui-core/emoji/svg/1f1ec.svg new file mode 100644 index 00000000..3d7d6206 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ed-1f1f0.svg b/qortal-ui-core/emoji/svg/1f1ed-1f1f0.svg new file mode 100644 index 00000000..ef5ca3bc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ed-1f1f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ed-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1ed-1f1f2.svg new file mode 100644 index 00000000..989da76d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ed-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ed-1f1f3.svg b/qortal-ui-core/emoji/svg/1f1ed-1f1f3.svg new file mode 100644 index 00000000..298ec95a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ed-1f1f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ed-1f1f7.svg b/qortal-ui-core/emoji/svg/1f1ed-1f1f7.svg new file mode 100644 index 00000000..7b8740c9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ed-1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ed-1f1f9.svg b/qortal-ui-core/emoji/svg/1f1ed-1f1f9.svg new file mode 100644 index 00000000..8ccca428 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ed-1f1f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ed-1f1fa.svg b/qortal-ui-core/emoji/svg/1f1ed-1f1fa.svg new file mode 100644 index 00000000..206baa15 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ed-1f1fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ed.svg b/qortal-ui-core/emoji/svg/1f1ed.svg new file mode 100644 index 00000000..20e48f86 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ee-1f1e8.svg b/qortal-ui-core/emoji/svg/1f1ee-1f1e8.svg new file mode 100644 index 00000000..46b09497 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ee-1f1e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ee-1f1e9.svg b/qortal-ui-core/emoji/svg/1f1ee-1f1e9.svg new file mode 100644 index 00000000..de31273f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ee-1f1e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ee-1f1ea.svg b/qortal-ui-core/emoji/svg/1f1ee-1f1ea.svg new file mode 100644 index 00000000..3c502571 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ee-1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ee-1f1f1.svg b/qortal-ui-core/emoji/svg/1f1ee-1f1f1.svg new file mode 100644 index 00000000..5cf32415 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ee-1f1f1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ee-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1ee-1f1f2.svg new file mode 100644 index 00000000..7fc9d465 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ee-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ee-1f1f3.svg b/qortal-ui-core/emoji/svg/1f1ee-1f1f3.svg new file mode 100644 index 00000000..7af1dafe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ee-1f1f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ee-1f1f4.svg b/qortal-ui-core/emoji/svg/1f1ee-1f1f4.svg new file mode 100644 index 00000000..565a7aa4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ee-1f1f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ee-1f1f6.svg b/qortal-ui-core/emoji/svg/1f1ee-1f1f6.svg new file mode 100644 index 00000000..06cfe319 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ee-1f1f6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ee-1f1f7.svg b/qortal-ui-core/emoji/svg/1f1ee-1f1f7.svg new file mode 100644 index 00000000..e8ae7b17 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ee-1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ee-1f1f8.svg b/qortal-ui-core/emoji/svg/1f1ee-1f1f8.svg new file mode 100644 index 00000000..c8e918c3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ee-1f1f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ee-1f1f9.svg b/qortal-ui-core/emoji/svg/1f1ee-1f1f9.svg new file mode 100644 index 00000000..6c380176 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ee-1f1f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ee.svg b/qortal-ui-core/emoji/svg/1f1ee.svg new file mode 100644 index 00000000..18b634ca --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ee.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ef-1f1ea.svg b/qortal-ui-core/emoji/svg/1f1ef-1f1ea.svg new file mode 100644 index 00000000..a17c379d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ef-1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ef-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1ef-1f1f2.svg new file mode 100644 index 00000000..dd82d4fa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ef-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ef-1f1f4.svg b/qortal-ui-core/emoji/svg/1f1ef-1f1f4.svg new file mode 100644 index 00000000..40710a56 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ef-1f1f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ef-1f1f5.svg b/qortal-ui-core/emoji/svg/1f1ef-1f1f5.svg new file mode 100644 index 00000000..3a724e9f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ef-1f1f5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ef.svg b/qortal-ui-core/emoji/svg/1f1ef.svg new file mode 100644 index 00000000..e0a80723 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ef.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f0-1f1ea.svg b/qortal-ui-core/emoji/svg/1f1f0-1f1ea.svg new file mode 100644 index 00000000..5bee37fd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f0-1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f0-1f1ec.svg b/qortal-ui-core/emoji/svg/1f1f0-1f1ec.svg new file mode 100644 index 00000000..2616d9e0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f0-1f1ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f0-1f1ed.svg b/qortal-ui-core/emoji/svg/1f1f0-1f1ed.svg new file mode 100644 index 00000000..54f6e904 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f0-1f1ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f0-1f1ee.svg b/qortal-ui-core/emoji/svg/1f1f0-1f1ee.svg new file mode 100644 index 00000000..233cce8d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f0-1f1ee.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f0-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1f0-1f1f2.svg new file mode 100644 index 00000000..91c12b80 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f0-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f0-1f1f3.svg b/qortal-ui-core/emoji/svg/1f1f0-1f1f3.svg new file mode 100644 index 00000000..461e0f26 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f0-1f1f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f0-1f1f5.svg b/qortal-ui-core/emoji/svg/1f1f0-1f1f5.svg new file mode 100644 index 00000000..d530523c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f0-1f1f5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f0-1f1f7.svg b/qortal-ui-core/emoji/svg/1f1f0-1f1f7.svg new file mode 100644 index 00000000..7b5ee233 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f0-1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f0-1f1fc.svg b/qortal-ui-core/emoji/svg/1f1f0-1f1fc.svg new file mode 100644 index 00000000..db949b28 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f0-1f1fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f0-1f1fe.svg b/qortal-ui-core/emoji/svg/1f1f0-1f1fe.svg new file mode 100644 index 00000000..57323f89 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f0-1f1fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f0-1f1ff.svg b/qortal-ui-core/emoji/svg/1f1f0-1f1ff.svg new file mode 100644 index 00000000..d2101ab5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f0-1f1ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f0.svg b/qortal-ui-core/emoji/svg/1f1f0.svg new file mode 100644 index 00000000..21484bf6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f1-1f1e6.svg b/qortal-ui-core/emoji/svg/1f1f1-1f1e6.svg new file mode 100644 index 00000000..0ea005db --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f1-1f1e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f1-1f1e7.svg b/qortal-ui-core/emoji/svg/1f1f1-1f1e7.svg new file mode 100644 index 00000000..4271b73a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f1-1f1e7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f1-1f1e8.svg b/qortal-ui-core/emoji/svg/1f1f1-1f1e8.svg new file mode 100644 index 00000000..12b2237e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f1-1f1e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f1-1f1ee.svg b/qortal-ui-core/emoji/svg/1f1f1-1f1ee.svg new file mode 100644 index 00000000..9e474bc1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f1-1f1ee.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f1-1f1f0.svg b/qortal-ui-core/emoji/svg/1f1f1-1f1f0.svg new file mode 100644 index 00000000..a2fe8143 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f1-1f1f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f1-1f1f7.svg b/qortal-ui-core/emoji/svg/1f1f1-1f1f7.svg new file mode 100644 index 00000000..dd4a1e47 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f1-1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f1-1f1f8.svg b/qortal-ui-core/emoji/svg/1f1f1-1f1f8.svg new file mode 100644 index 00000000..ec06e4fc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f1-1f1f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f1-1f1f9.svg b/qortal-ui-core/emoji/svg/1f1f1-1f1f9.svg new file mode 100644 index 00000000..5fcfd8bf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f1-1f1f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f1-1f1fa.svg b/qortal-ui-core/emoji/svg/1f1f1-1f1fa.svg new file mode 100644 index 00000000..e66c904e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f1-1f1fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f1-1f1fb.svg b/qortal-ui-core/emoji/svg/1f1f1-1f1fb.svg new file mode 100644 index 00000000..f5f39223 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f1-1f1fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f1-1f1fe.svg b/qortal-ui-core/emoji/svg/1f1f1-1f1fe.svg new file mode 100644 index 00000000..c6c12ed6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f1-1f1fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f1.svg b/qortal-ui-core/emoji/svg/1f1f1.svg new file mode 100644 index 00000000..d76ecd5d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1e6.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1e6.svg new file mode 100644 index 00000000..d6d689a3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1e8.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1e8.svg new file mode 100644 index 00000000..8604a1c4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1e9.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1e9.svg new file mode 100644 index 00000000..eb2d4a20 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1ea.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1ea.svg new file mode 100644 index 00000000..47c5b2e5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1eb.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1eb.svg new file mode 100644 index 00000000..4eafe7aa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1ec.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1ec.svg new file mode 100644 index 00000000..becf2f46 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1ed.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1ed.svg new file mode 100644 index 00000000..6774f9b3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1f0.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1f0.svg new file mode 100644 index 00000000..371b2358 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1f1.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1f1.svg new file mode 100644 index 00000000..3a522a0f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1f1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1f2.svg new file mode 100644 index 00000000..69db533a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1f3.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1f3.svg new file mode 100644 index 00000000..b9635cf7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1f4.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1f4.svg new file mode 100644 index 00000000..790900e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1f5.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1f5.svg new file mode 100644 index 00000000..f0a5fb45 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1f5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1f6.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1f6.svg new file mode 100644 index 00000000..f7053092 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1f6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1f7.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1f7.svg new file mode 100644 index 00000000..8335c8b5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1f8.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1f8.svg new file mode 100644 index 00000000..04a1cc1e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1f9.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1f9.svg new file mode 100644 index 00000000..55381021 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1fa.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1fa.svg new file mode 100644 index 00000000..6c249812 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1fb.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1fb.svg new file mode 100644 index 00000000..b57be9c6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1fc.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1fc.svg new file mode 100644 index 00000000..9b8ddf52 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1fd.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1fd.svg new file mode 100644 index 00000000..93d54c46 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1fe.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1fe.svg new file mode 100644 index 00000000..0480330c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2-1f1ff.svg b/qortal-ui-core/emoji/svg/1f1f2-1f1ff.svg new file mode 100644 index 00000000..cfa95772 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2-1f1ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f2.svg b/qortal-ui-core/emoji/svg/1f1f2.svg new file mode 100644 index 00000000..cc6f136e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f3-1f1e6.svg b/qortal-ui-core/emoji/svg/1f1f3-1f1e6.svg new file mode 100644 index 00000000..d2a79fd2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f3-1f1e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f3-1f1e8.svg b/qortal-ui-core/emoji/svg/1f1f3-1f1e8.svg new file mode 100644 index 00000000..e5dff934 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f3-1f1e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f3-1f1ea.svg b/qortal-ui-core/emoji/svg/1f1f3-1f1ea.svg new file mode 100644 index 00000000..53f25f50 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f3-1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f3-1f1eb.svg b/qortal-ui-core/emoji/svg/1f1f3-1f1eb.svg new file mode 100644 index 00000000..990687f0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f3-1f1eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f3-1f1ec.svg b/qortal-ui-core/emoji/svg/1f1f3-1f1ec.svg new file mode 100644 index 00000000..6c6e31ca --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f3-1f1ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f3-1f1ee.svg b/qortal-ui-core/emoji/svg/1f1f3-1f1ee.svg new file mode 100644 index 00000000..990868aa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f3-1f1ee.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f3-1f1f1.svg b/qortal-ui-core/emoji/svg/1f1f3-1f1f1.svg new file mode 100644 index 00000000..65e8be9a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f3-1f1f1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f3-1f1f4.svg b/qortal-ui-core/emoji/svg/1f1f3-1f1f4.svg new file mode 100644 index 00000000..4f5260a6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f3-1f1f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f3-1f1f5.svg b/qortal-ui-core/emoji/svg/1f1f3-1f1f5.svg new file mode 100644 index 00000000..5e5faaf2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f3-1f1f5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f3-1f1f7.svg b/qortal-ui-core/emoji/svg/1f1f3-1f1f7.svg new file mode 100644 index 00000000..72485e70 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f3-1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f3-1f1fa.svg b/qortal-ui-core/emoji/svg/1f1f3-1f1fa.svg new file mode 100644 index 00000000..dd50901a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f3-1f1fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f3-1f1ff.svg b/qortal-ui-core/emoji/svg/1f1f3-1f1ff.svg new file mode 100644 index 00000000..956a9d21 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f3-1f1ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f3.svg b/qortal-ui-core/emoji/svg/1f1f3.svg new file mode 100644 index 00000000..f8d0bbd5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f4-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1f4-1f1f2.svg new file mode 100644 index 00000000..29af8258 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f4-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f4.svg b/qortal-ui-core/emoji/svg/1f1f4.svg new file mode 100644 index 00000000..9a56c51b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f5-1f1e6.svg b/qortal-ui-core/emoji/svg/1f1f5-1f1e6.svg new file mode 100644 index 00000000..4fc55f5b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f5-1f1e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f5-1f1ea.svg b/qortal-ui-core/emoji/svg/1f1f5-1f1ea.svg new file mode 100644 index 00000000..fc93b299 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f5-1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f5-1f1eb.svg b/qortal-ui-core/emoji/svg/1f1f5-1f1eb.svg new file mode 100644 index 00000000..333c6d0a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f5-1f1eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f5-1f1ec.svg b/qortal-ui-core/emoji/svg/1f1f5-1f1ec.svg new file mode 100644 index 00000000..2d20ed8e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f5-1f1ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f5-1f1ed.svg b/qortal-ui-core/emoji/svg/1f1f5-1f1ed.svg new file mode 100644 index 00000000..e9f011d3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f5-1f1ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f5-1f1f0.svg b/qortal-ui-core/emoji/svg/1f1f5-1f1f0.svg new file mode 100644 index 00000000..a718df6c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f5-1f1f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f5-1f1f1.svg b/qortal-ui-core/emoji/svg/1f1f5-1f1f1.svg new file mode 100644 index 00000000..8169875a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f5-1f1f1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f5-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1f5-1f1f2.svg new file mode 100644 index 00000000..dc55c02f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f5-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f5-1f1f3.svg b/qortal-ui-core/emoji/svg/1f1f5-1f1f3.svg new file mode 100644 index 00000000..234f53f4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f5-1f1f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f5-1f1f7.svg b/qortal-ui-core/emoji/svg/1f1f5-1f1f7.svg new file mode 100644 index 00000000..f4c2ace3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f5-1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f5-1f1f8.svg b/qortal-ui-core/emoji/svg/1f1f5-1f1f8.svg new file mode 100644 index 00000000..6ce8ec76 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f5-1f1f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f5-1f1f9.svg b/qortal-ui-core/emoji/svg/1f1f5-1f1f9.svg new file mode 100644 index 00000000..78b29a89 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f5-1f1f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f5-1f1fc.svg b/qortal-ui-core/emoji/svg/1f1f5-1f1fc.svg new file mode 100644 index 00000000..043f7a51 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f5-1f1fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f5-1f1fe.svg b/qortal-ui-core/emoji/svg/1f1f5-1f1fe.svg new file mode 100644 index 00000000..c8e83dc3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f5-1f1fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f5.svg b/qortal-ui-core/emoji/svg/1f1f5.svg new file mode 100644 index 00000000..90d45e85 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f6-1f1e6.svg b/qortal-ui-core/emoji/svg/1f1f6-1f1e6.svg new file mode 100644 index 00000000..f3e91d04 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f6-1f1e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f6.svg b/qortal-ui-core/emoji/svg/1f1f6.svg new file mode 100644 index 00000000..e202fc22 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f7-1f1ea.svg b/qortal-ui-core/emoji/svg/1f1f7-1f1ea.svg new file mode 100644 index 00000000..ab1399fc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f7-1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f7-1f1f4.svg b/qortal-ui-core/emoji/svg/1f1f7-1f1f4.svg new file mode 100644 index 00000000..33ac6edf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f7-1f1f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f7-1f1f8.svg b/qortal-ui-core/emoji/svg/1f1f7-1f1f8.svg new file mode 100644 index 00000000..5c6c69e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f7-1f1f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f7-1f1fa.svg b/qortal-ui-core/emoji/svg/1f1f7-1f1fa.svg new file mode 100644 index 00000000..46f74d59 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f7-1f1fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f7-1f1fc.svg b/qortal-ui-core/emoji/svg/1f1f7-1f1fc.svg new file mode 100644 index 00000000..6175c02f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f7-1f1fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f7.svg b/qortal-ui-core/emoji/svg/1f1f7.svg new file mode 100644 index 00000000..8d72d991 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1e6.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1e6.svg new file mode 100644 index 00000000..d0d95800 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1e7.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1e7.svg new file mode 100644 index 00000000..a55ff606 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1e7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1e8.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1e8.svg new file mode 100644 index 00000000..40e42eaa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1e9.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1e9.svg new file mode 100644 index 00000000..ddb60bae --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1ea.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1ea.svg new file mode 100644 index 00000000..a039dc2d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1ec.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1ec.svg new file mode 100644 index 00000000..199e54e1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1ed.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1ed.svg new file mode 100644 index 00000000..57d004da --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1ee.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1ee.svg new file mode 100644 index 00000000..e25c04c8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1ee.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1ef.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1ef.svg new file mode 100644 index 00000000..4f5260a6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1ef.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1f0.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1f0.svg new file mode 100644 index 00000000..c4f7cafd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1f1.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1f1.svg new file mode 100644 index 00000000..b08dd1d7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1f1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1f2.svg new file mode 100644 index 00000000..b53d00db --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1f3.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1f3.svg new file mode 100644 index 00000000..c2334722 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1f4.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1f4.svg new file mode 100644 index 00000000..293dd348 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1f7.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1f7.svg new file mode 100644 index 00000000..c483fb95 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1f8.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1f8.svg new file mode 100644 index 00000000..0aa63d75 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1f9.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1f9.svg new file mode 100644 index 00000000..f2bb52a3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1fb.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1fb.svg new file mode 100644 index 00000000..873310c0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1fd.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1fd.svg new file mode 100644 index 00000000..20472431 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1fe.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1fe.svg new file mode 100644 index 00000000..5e32d2cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8-1f1ff.svg b/qortal-ui-core/emoji/svg/1f1f8-1f1ff.svg new file mode 100644 index 00000000..cb7f84a8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8-1f1ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f8.svg b/qortal-ui-core/emoji/svg/1f1f8.svg new file mode 100644 index 00000000..e596113c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1e6.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1e6.svg new file mode 100644 index 00000000..547fa056 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1e8.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1e8.svg new file mode 100644 index 00000000..3c61bc79 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1e9.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1e9.svg new file mode 100644 index 00000000..d106ba84 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1eb.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1eb.svg new file mode 100644 index 00000000..cf4bfacf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1ec.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1ec.svg new file mode 100644 index 00000000..4a05a303 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1ed.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1ed.svg new file mode 100644 index 00000000..ff2a66f9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1ef.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1ef.svg new file mode 100644 index 00000000..6045f465 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1ef.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1f0.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1f0.svg new file mode 100644 index 00000000..bfa93625 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1f1.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1f1.svg new file mode 100644 index 00000000..6030072a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1f1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1f2.svg new file mode 100644 index 00000000..a57c35cc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1f3.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1f3.svg new file mode 100644 index 00000000..c13e7302 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1f4.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1f4.svg new file mode 100644 index 00000000..20a9555b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1f7.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1f7.svg new file mode 100644 index 00000000..861da57e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1f9.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1f9.svg new file mode 100644 index 00000000..578c8eb4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1fb.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1fb.svg new file mode 100644 index 00000000..6558df60 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1fc.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1fc.svg new file mode 100644 index 00000000..4cd304e1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9-1f1ff.svg b/qortal-ui-core/emoji/svg/1f1f9-1f1ff.svg new file mode 100644 index 00000000..a9ddb8ed --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9-1f1ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1f9.svg b/qortal-ui-core/emoji/svg/1f1f9.svg new file mode 100644 index 00000000..fa3677ea --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fa-1f1e6.svg b/qortal-ui-core/emoji/svg/1f1fa-1f1e6.svg new file mode 100644 index 00000000..989b5c28 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fa-1f1e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fa-1f1ec.svg b/qortal-ui-core/emoji/svg/1f1fa-1f1ec.svg new file mode 100644 index 00000000..6602ca9c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fa-1f1ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fa-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1fa-1f1f2.svg new file mode 100644 index 00000000..d51f600a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fa-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fa-1f1f3.svg b/qortal-ui-core/emoji/svg/1f1fa-1f1f3.svg new file mode 100644 index 00000000..a035a767 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fa-1f1f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fa-1f1f8.svg b/qortal-ui-core/emoji/svg/1f1fa-1f1f8.svg new file mode 100644 index 00000000..d51f600a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fa-1f1f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fa-1f1fe.svg b/qortal-ui-core/emoji/svg/1f1fa-1f1fe.svg new file mode 100644 index 00000000..796244c9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fa-1f1fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fa-1f1ff.svg b/qortal-ui-core/emoji/svg/1f1fa-1f1ff.svg new file mode 100644 index 00000000..b913772e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fa-1f1ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fa.svg b/qortal-ui-core/emoji/svg/1f1fa.svg new file mode 100644 index 00000000..aed705da --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fb-1f1e6.svg b/qortal-ui-core/emoji/svg/1f1fb-1f1e6.svg new file mode 100644 index 00000000..7b2bffa7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fb-1f1e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fb-1f1e8.svg b/qortal-ui-core/emoji/svg/1f1fb-1f1e8.svg new file mode 100644 index 00000000..fb97611b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fb-1f1e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fb-1f1ea.svg b/qortal-ui-core/emoji/svg/1f1fb-1f1ea.svg new file mode 100644 index 00000000..294b5c69 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fb-1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fb-1f1ec.svg b/qortal-ui-core/emoji/svg/1f1fb-1f1ec.svg new file mode 100644 index 00000000..d8194cd0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fb-1f1ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fb-1f1ee.svg b/qortal-ui-core/emoji/svg/1f1fb-1f1ee.svg new file mode 100644 index 00000000..d0602d29 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fb-1f1ee.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fb-1f1f3.svg b/qortal-ui-core/emoji/svg/1f1fb-1f1f3.svg new file mode 100644 index 00000000..4e0e1b58 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fb-1f1f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fb-1f1fa.svg b/qortal-ui-core/emoji/svg/1f1fb-1f1fa.svg new file mode 100644 index 00000000..151e7aaa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fb-1f1fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fb.svg b/qortal-ui-core/emoji/svg/1f1fb.svg new file mode 100644 index 00000000..a5bf8647 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fc-1f1eb.svg b/qortal-ui-core/emoji/svg/1f1fc-1f1eb.svg new file mode 100644 index 00000000..98954225 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fc-1f1eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fc-1f1f8.svg b/qortal-ui-core/emoji/svg/1f1fc-1f1f8.svg new file mode 100644 index 00000000..6b075cb0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fc-1f1f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fc.svg b/qortal-ui-core/emoji/svg/1f1fc.svg new file mode 100644 index 00000000..c65cf0b9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fd-1f1f0.svg b/qortal-ui-core/emoji/svg/1f1fd-1f1f0.svg new file mode 100644 index 00000000..39890a90 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fd-1f1f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fd.svg b/qortal-ui-core/emoji/svg/1f1fd.svg new file mode 100644 index 00000000..e39fd6d2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fe-1f1ea.svg b/qortal-ui-core/emoji/svg/1f1fe-1f1ea.svg new file mode 100644 index 00000000..a82532c3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fe-1f1ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fe-1f1f9.svg b/qortal-ui-core/emoji/svg/1f1fe-1f1f9.svg new file mode 100644 index 00000000..76765b93 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fe-1f1f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1fe.svg b/qortal-ui-core/emoji/svg/1f1fe.svg new file mode 100644 index 00000000..3c4a46f0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ff-1f1e6.svg b/qortal-ui-core/emoji/svg/1f1ff-1f1e6.svg new file mode 100644 index 00000000..275c136d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ff-1f1e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ff-1f1f2.svg b/qortal-ui-core/emoji/svg/1f1ff-1f1f2.svg new file mode 100644 index 00000000..d2768963 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ff-1f1f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ff-1f1fc.svg b/qortal-ui-core/emoji/svg/1f1ff-1f1fc.svg new file mode 100644 index 00000000..15a84645 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ff-1f1fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f1ff.svg b/qortal-ui-core/emoji/svg/1f1ff.svg new file mode 100644 index 00000000..e1ae07de --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f1ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f201.svg b/qortal-ui-core/emoji/svg/1f201.svg new file mode 100644 index 00000000..c4e65413 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f201.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f202.svg b/qortal-ui-core/emoji/svg/1f202.svg new file mode 100644 index 00000000..7f1e8415 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f202.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f21a.svg b/qortal-ui-core/emoji/svg/1f21a.svg new file mode 100644 index 00000000..9b0253ad --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f21a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f22f.svg b/qortal-ui-core/emoji/svg/1f22f.svg new file mode 100644 index 00000000..112269d9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f22f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f232.svg b/qortal-ui-core/emoji/svg/1f232.svg new file mode 100644 index 00000000..4efe9bbf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f232.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f233.svg b/qortal-ui-core/emoji/svg/1f233.svg new file mode 100644 index 00000000..2e2072ce --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f233.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f234.svg b/qortal-ui-core/emoji/svg/1f234.svg new file mode 100644 index 00000000..b90b9c40 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f234.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f235.svg b/qortal-ui-core/emoji/svg/1f235.svg new file mode 100644 index 00000000..86f24ca5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f235.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f236.svg b/qortal-ui-core/emoji/svg/1f236.svg new file mode 100644 index 00000000..93c5998e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f236.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f237.svg b/qortal-ui-core/emoji/svg/1f237.svg new file mode 100644 index 00000000..459d9488 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f237.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f238.svg b/qortal-ui-core/emoji/svg/1f238.svg new file mode 100644 index 00000000..af984cb9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f238.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f239.svg b/qortal-ui-core/emoji/svg/1f239.svg new file mode 100644 index 00000000..889c0272 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f239.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f23a.svg b/qortal-ui-core/emoji/svg/1f23a.svg new file mode 100644 index 00000000..87a2cebd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f23a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f250.svg b/qortal-ui-core/emoji/svg/1f250.svg new file mode 100644 index 00000000..c7465f8a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f250.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f251.svg b/qortal-ui-core/emoji/svg/1f251.svg new file mode 100644 index 00000000..4bb227b5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f251.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f300.svg b/qortal-ui-core/emoji/svg/1f300.svg new file mode 100644 index 00000000..1de6f256 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f300.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f301.svg b/qortal-ui-core/emoji/svg/1f301.svg new file mode 100644 index 00000000..d6298de4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f301.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f302.svg b/qortal-ui-core/emoji/svg/1f302.svg new file mode 100644 index 00000000..e611e6b8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f302.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f303.svg b/qortal-ui-core/emoji/svg/1f303.svg new file mode 100644 index 00000000..d6c21b48 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f303.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f304.svg b/qortal-ui-core/emoji/svg/1f304.svg new file mode 100644 index 00000000..0709f1c4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f304.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f305.svg b/qortal-ui-core/emoji/svg/1f305.svg new file mode 100644 index 00000000..8e3f66da --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f305.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f306.svg b/qortal-ui-core/emoji/svg/1f306.svg new file mode 100644 index 00000000..9e7ae826 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f306.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f307.svg b/qortal-ui-core/emoji/svg/1f307.svg new file mode 100644 index 00000000..a783fe33 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f307.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f308.svg b/qortal-ui-core/emoji/svg/1f308.svg new file mode 100644 index 00000000..ffe6a123 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f308.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f309.svg b/qortal-ui-core/emoji/svg/1f309.svg new file mode 100644 index 00000000..e49295b4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f309.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f30a.svg b/qortal-ui-core/emoji/svg/1f30a.svg new file mode 100644 index 00000000..0e68ec36 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f30a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f30b.svg b/qortal-ui-core/emoji/svg/1f30b.svg new file mode 100644 index 00000000..88d989d7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f30b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f30c.svg b/qortal-ui-core/emoji/svg/1f30c.svg new file mode 100644 index 00000000..7853bcd4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f30c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f30d.svg b/qortal-ui-core/emoji/svg/1f30d.svg new file mode 100644 index 00000000..f8136108 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f30d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f30e.svg b/qortal-ui-core/emoji/svg/1f30e.svg new file mode 100644 index 00000000..0793e724 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f30e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f30f.svg b/qortal-ui-core/emoji/svg/1f30f.svg new file mode 100644 index 00000000..30c0186e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f30f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f310.svg b/qortal-ui-core/emoji/svg/1f310.svg new file mode 100644 index 00000000..a9ec9e69 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f310.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f311.svg b/qortal-ui-core/emoji/svg/1f311.svg new file mode 100644 index 00000000..d71e4d1a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f311.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f312.svg b/qortal-ui-core/emoji/svg/1f312.svg new file mode 100644 index 00000000..d3bb1a75 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f312.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f313.svg b/qortal-ui-core/emoji/svg/1f313.svg new file mode 100644 index 00000000..f668b758 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f313.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f314.svg b/qortal-ui-core/emoji/svg/1f314.svg new file mode 100644 index 00000000..90488ede --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f314.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f315.svg b/qortal-ui-core/emoji/svg/1f315.svg new file mode 100644 index 00000000..9a704271 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f315.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f316.svg b/qortal-ui-core/emoji/svg/1f316.svg new file mode 100644 index 00000000..9cbc981e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f316.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f317.svg b/qortal-ui-core/emoji/svg/1f317.svg new file mode 100644 index 00000000..a5813f0f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f317.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f318.svg b/qortal-ui-core/emoji/svg/1f318.svg new file mode 100644 index 00000000..bad95d5e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f318.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f319.svg b/qortal-ui-core/emoji/svg/1f319.svg new file mode 100644 index 00000000..d98dc2f9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f319.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f31a.svg b/qortal-ui-core/emoji/svg/1f31a.svg new file mode 100644 index 00000000..6ccbb68c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f31a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f31b.svg b/qortal-ui-core/emoji/svg/1f31b.svg new file mode 100644 index 00000000..3fffcdd5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f31b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f31c.svg b/qortal-ui-core/emoji/svg/1f31c.svg new file mode 100644 index 00000000..07501e92 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f31c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f31d.svg b/qortal-ui-core/emoji/svg/1f31d.svg new file mode 100644 index 00000000..4c989691 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f31d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f31e.svg b/qortal-ui-core/emoji/svg/1f31e.svg new file mode 100644 index 00000000..2da9b199 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f31e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f31f.svg b/qortal-ui-core/emoji/svg/1f31f.svg new file mode 100644 index 00000000..a4695dd6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f31f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f320.svg b/qortal-ui-core/emoji/svg/1f320.svg new file mode 100644 index 00000000..295a5a12 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f320.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f321.svg b/qortal-ui-core/emoji/svg/1f321.svg new file mode 100644 index 00000000..95a75984 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f321.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f324.svg b/qortal-ui-core/emoji/svg/1f324.svg new file mode 100644 index 00000000..8ba8c525 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f324.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f325.svg b/qortal-ui-core/emoji/svg/1f325.svg new file mode 100644 index 00000000..1efae102 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f325.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f326.svg b/qortal-ui-core/emoji/svg/1f326.svg new file mode 100644 index 00000000..3a65ae71 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f326.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f327.svg b/qortal-ui-core/emoji/svg/1f327.svg new file mode 100644 index 00000000..99f42f5a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f327.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f328.svg b/qortal-ui-core/emoji/svg/1f328.svg new file mode 100644 index 00000000..f937107a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f328.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f329.svg b/qortal-ui-core/emoji/svg/1f329.svg new file mode 100644 index 00000000..0deaddcd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f329.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f32a.svg b/qortal-ui-core/emoji/svg/1f32a.svg new file mode 100644 index 00000000..b4620106 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f32a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f32b.svg b/qortal-ui-core/emoji/svg/1f32b.svg new file mode 100644 index 00000000..fe6e480b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f32b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f32c.svg b/qortal-ui-core/emoji/svg/1f32c.svg new file mode 100644 index 00000000..7d554574 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f32c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f32d.svg b/qortal-ui-core/emoji/svg/1f32d.svg new file mode 100644 index 00000000..a450dbba --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f32d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f32e.svg b/qortal-ui-core/emoji/svg/1f32e.svg new file mode 100644 index 00000000..5b08f1f7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f32e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f32f.svg b/qortal-ui-core/emoji/svg/1f32f.svg new file mode 100644 index 00000000..c76d82c3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f32f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f330.svg b/qortal-ui-core/emoji/svg/1f330.svg new file mode 100644 index 00000000..d0e84b5e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f330.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f331.svg b/qortal-ui-core/emoji/svg/1f331.svg new file mode 100644 index 00000000..668d777f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f331.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f332.svg b/qortal-ui-core/emoji/svg/1f332.svg new file mode 100644 index 00000000..540f1860 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f332.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f333.svg b/qortal-ui-core/emoji/svg/1f333.svg new file mode 100644 index 00000000..3937fc49 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f333.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f334.svg b/qortal-ui-core/emoji/svg/1f334.svg new file mode 100644 index 00000000..55d246a2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f334.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f335.svg b/qortal-ui-core/emoji/svg/1f335.svg new file mode 100644 index 00000000..097dc13c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f335.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f336.svg b/qortal-ui-core/emoji/svg/1f336.svg new file mode 100644 index 00000000..eaeef864 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f336.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f337.svg b/qortal-ui-core/emoji/svg/1f337.svg new file mode 100644 index 00000000..86a1a36f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f337.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f338.svg b/qortal-ui-core/emoji/svg/1f338.svg new file mode 100644 index 00000000..46ba420d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f338.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f339.svg b/qortal-ui-core/emoji/svg/1f339.svg new file mode 100644 index 00000000..500d9257 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f339.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f33a.svg b/qortal-ui-core/emoji/svg/1f33a.svg new file mode 100644 index 00000000..19c2f896 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f33a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f33b.svg b/qortal-ui-core/emoji/svg/1f33b.svg new file mode 100644 index 00000000..413e6fcb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f33b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f33c.svg b/qortal-ui-core/emoji/svg/1f33c.svg new file mode 100644 index 00000000..4ee1cc00 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f33c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f33d.svg b/qortal-ui-core/emoji/svg/1f33d.svg new file mode 100644 index 00000000..6c4ae3bf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f33d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f33e.svg b/qortal-ui-core/emoji/svg/1f33e.svg new file mode 100644 index 00000000..320f1498 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f33f.svg b/qortal-ui-core/emoji/svg/1f33f.svg new file mode 100644 index 00000000..9243e968 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f33f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f340.svg b/qortal-ui-core/emoji/svg/1f340.svg new file mode 100644 index 00000000..cac00d45 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f340.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f341.svg b/qortal-ui-core/emoji/svg/1f341.svg new file mode 100644 index 00000000..7cd7ad97 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f341.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f342.svg b/qortal-ui-core/emoji/svg/1f342.svg new file mode 100644 index 00000000..1c9072a0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f342.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f343.svg b/qortal-ui-core/emoji/svg/1f343.svg new file mode 100644 index 00000000..650bfa98 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f343.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f344.svg b/qortal-ui-core/emoji/svg/1f344.svg new file mode 100644 index 00000000..0cf7a791 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f344.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f345.svg b/qortal-ui-core/emoji/svg/1f345.svg new file mode 100644 index 00000000..411c2a50 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f345.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f346.svg b/qortal-ui-core/emoji/svg/1f346.svg new file mode 100644 index 00000000..14688a6d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f346.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f347.svg b/qortal-ui-core/emoji/svg/1f347.svg new file mode 100644 index 00000000..e52e2f85 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f347.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f348.svg b/qortal-ui-core/emoji/svg/1f348.svg new file mode 100644 index 00000000..f3482735 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f348.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f349.svg b/qortal-ui-core/emoji/svg/1f349.svg new file mode 100644 index 00000000..0f5ec06a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f349.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f34a.svg b/qortal-ui-core/emoji/svg/1f34a.svg new file mode 100644 index 00000000..82c0c52b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f34a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f34b.svg b/qortal-ui-core/emoji/svg/1f34b.svg new file mode 100644 index 00000000..ffbdc088 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f34b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f34c.svg b/qortal-ui-core/emoji/svg/1f34c.svg new file mode 100644 index 00000000..b4120ba3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f34c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f34d.svg b/qortal-ui-core/emoji/svg/1f34d.svg new file mode 100644 index 00000000..e96999db --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f34d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f34e.svg b/qortal-ui-core/emoji/svg/1f34e.svg new file mode 100644 index 00000000..2fe98862 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f34e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f34f.svg b/qortal-ui-core/emoji/svg/1f34f.svg new file mode 100644 index 00000000..1423d8aa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f34f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f350.svg b/qortal-ui-core/emoji/svg/1f350.svg new file mode 100644 index 00000000..2888963f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f350.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f351.svg b/qortal-ui-core/emoji/svg/1f351.svg new file mode 100644 index 00000000..84e81f5e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f351.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f352.svg b/qortal-ui-core/emoji/svg/1f352.svg new file mode 100644 index 00000000..bdba6bd6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f352.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f353.svg b/qortal-ui-core/emoji/svg/1f353.svg new file mode 100644 index 00000000..26a41ee2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f353.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f354.svg b/qortal-ui-core/emoji/svg/1f354.svg new file mode 100644 index 00000000..a129dccb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f354.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f355.svg b/qortal-ui-core/emoji/svg/1f355.svg new file mode 100644 index 00000000..3a44bba9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f355.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f356.svg b/qortal-ui-core/emoji/svg/1f356.svg new file mode 100644 index 00000000..44fab599 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f356.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f357.svg b/qortal-ui-core/emoji/svg/1f357.svg new file mode 100644 index 00000000..77d0b872 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f357.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f358.svg b/qortal-ui-core/emoji/svg/1f358.svg new file mode 100644 index 00000000..f35a02ea --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f358.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f359.svg b/qortal-ui-core/emoji/svg/1f359.svg new file mode 100644 index 00000000..e508f8f9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f359.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f35a.svg b/qortal-ui-core/emoji/svg/1f35a.svg new file mode 100644 index 00000000..04019a1c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f35a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f35b.svg b/qortal-ui-core/emoji/svg/1f35b.svg new file mode 100644 index 00000000..be3be226 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f35b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f35c.svg b/qortal-ui-core/emoji/svg/1f35c.svg new file mode 100644 index 00000000..e9fc9700 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f35c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f35d.svg b/qortal-ui-core/emoji/svg/1f35d.svg new file mode 100644 index 00000000..3ae82eb5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f35d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f35e.svg b/qortal-ui-core/emoji/svg/1f35e.svg new file mode 100644 index 00000000..7d2af4e7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f35e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f35f.svg b/qortal-ui-core/emoji/svg/1f35f.svg new file mode 100644 index 00000000..faac7ecf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f35f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f360.svg b/qortal-ui-core/emoji/svg/1f360.svg new file mode 100644 index 00000000..c2894e35 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f360.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f361.svg b/qortal-ui-core/emoji/svg/1f361.svg new file mode 100644 index 00000000..e2537d90 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f361.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f362.svg b/qortal-ui-core/emoji/svg/1f362.svg new file mode 100644 index 00000000..f5f7653a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f362.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f363.svg b/qortal-ui-core/emoji/svg/1f363.svg new file mode 100644 index 00000000..eed2b88c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f363.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f364.svg b/qortal-ui-core/emoji/svg/1f364.svg new file mode 100644 index 00000000..91304221 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f364.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f365.svg b/qortal-ui-core/emoji/svg/1f365.svg new file mode 100644 index 00000000..fd448da0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f365.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f366.svg b/qortal-ui-core/emoji/svg/1f366.svg new file mode 100644 index 00000000..9b869f8c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f366.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f367.svg b/qortal-ui-core/emoji/svg/1f367.svg new file mode 100644 index 00000000..232dd3cf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f367.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f368.svg b/qortal-ui-core/emoji/svg/1f368.svg new file mode 100644 index 00000000..187b2f4c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f368.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f369.svg b/qortal-ui-core/emoji/svg/1f369.svg new file mode 100644 index 00000000..3c2aa582 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f369.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f36a.svg b/qortal-ui-core/emoji/svg/1f36a.svg new file mode 100644 index 00000000..4f5368a4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f36a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f36b.svg b/qortal-ui-core/emoji/svg/1f36b.svg new file mode 100644 index 00000000..a993c9b4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f36b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f36c.svg b/qortal-ui-core/emoji/svg/1f36c.svg new file mode 100644 index 00000000..f6fbf3b7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f36c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f36d.svg b/qortal-ui-core/emoji/svg/1f36d.svg new file mode 100644 index 00000000..e13447ed --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f36d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f36e.svg b/qortal-ui-core/emoji/svg/1f36e.svg new file mode 100644 index 00000000..8ec51792 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f36e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f36f.svg b/qortal-ui-core/emoji/svg/1f36f.svg new file mode 100644 index 00000000..38c4dd50 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f36f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f370.svg b/qortal-ui-core/emoji/svg/1f370.svg new file mode 100644 index 00000000..c6f2cf47 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f370.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f371.svg b/qortal-ui-core/emoji/svg/1f371.svg new file mode 100644 index 00000000..c4811840 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f371.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f372.svg b/qortal-ui-core/emoji/svg/1f372.svg new file mode 100644 index 00000000..37f9be89 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f372.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f373.svg b/qortal-ui-core/emoji/svg/1f373.svg new file mode 100644 index 00000000..733dc2ba --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f374.svg b/qortal-ui-core/emoji/svg/1f374.svg new file mode 100644 index 00000000..e7de6c04 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f374.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f375.svg b/qortal-ui-core/emoji/svg/1f375.svg new file mode 100644 index 00000000..77269639 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f375.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f376.svg b/qortal-ui-core/emoji/svg/1f376.svg new file mode 100644 index 00000000..2bb872e1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f376.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f377.svg b/qortal-ui-core/emoji/svg/1f377.svg new file mode 100644 index 00000000..b7925317 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f377.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f378.svg b/qortal-ui-core/emoji/svg/1f378.svg new file mode 100644 index 00000000..c8bc0ce1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f378.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f379.svg b/qortal-ui-core/emoji/svg/1f379.svg new file mode 100644 index 00000000..1c4db463 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f379.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f37a.svg b/qortal-ui-core/emoji/svg/1f37a.svg new file mode 100644 index 00000000..9e6a547b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f37a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f37b.svg b/qortal-ui-core/emoji/svg/1f37b.svg new file mode 100644 index 00000000..a8bcb20c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f37b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f37c.svg b/qortal-ui-core/emoji/svg/1f37c.svg new file mode 100644 index 00000000..61f6c8ff --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f37d.svg b/qortal-ui-core/emoji/svg/1f37d.svg new file mode 100644 index 00000000..7437a350 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f37d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f37e.svg b/qortal-ui-core/emoji/svg/1f37e.svg new file mode 100644 index 00000000..a02a17eb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f37e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f37f.svg b/qortal-ui-core/emoji/svg/1f37f.svg new file mode 100644 index 00000000..ddbff6d9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f37f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f380.svg b/qortal-ui-core/emoji/svg/1f380.svg new file mode 100644 index 00000000..03d4a751 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f380.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f381.svg b/qortal-ui-core/emoji/svg/1f381.svg new file mode 100644 index 00000000..1ab82981 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f381.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f382.svg b/qortal-ui-core/emoji/svg/1f382.svg new file mode 100644 index 00000000..35f9a002 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f382.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f383.svg b/qortal-ui-core/emoji/svg/1f383.svg new file mode 100644 index 00000000..591fc66a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f383.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f384.svg b/qortal-ui-core/emoji/svg/1f384.svg new file mode 100644 index 00000000..6e9b11e2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f385-1f3fb.svg b/qortal-ui-core/emoji/svg/1f385-1f3fb.svg new file mode 100644 index 00000000..ef5c6153 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f385-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f385-1f3fc.svg b/qortal-ui-core/emoji/svg/1f385-1f3fc.svg new file mode 100644 index 00000000..5adcdf4e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f385-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f385-1f3fd.svg b/qortal-ui-core/emoji/svg/1f385-1f3fd.svg new file mode 100644 index 00000000..0a56a8b1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f385-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f385-1f3fe.svg b/qortal-ui-core/emoji/svg/1f385-1f3fe.svg new file mode 100644 index 00000000..16b3b33e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f385-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f385-1f3ff.svg b/qortal-ui-core/emoji/svg/1f385-1f3ff.svg new file mode 100644 index 00000000..4923cbf4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f385-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f385.svg b/qortal-ui-core/emoji/svg/1f385.svg new file mode 100644 index 00000000..9c61da6c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f385.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f386.svg b/qortal-ui-core/emoji/svg/1f386.svg new file mode 100644 index 00000000..54a4f321 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f386.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f387.svg b/qortal-ui-core/emoji/svg/1f387.svg new file mode 100644 index 00000000..68cfb644 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f387.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f388.svg b/qortal-ui-core/emoji/svg/1f388.svg new file mode 100644 index 00000000..6d431bc8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f388.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f389.svg b/qortal-ui-core/emoji/svg/1f389.svg new file mode 100644 index 00000000..a4b8305a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f389.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f38a.svg b/qortal-ui-core/emoji/svg/1f38a.svg new file mode 100644 index 00000000..e709775f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f38a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f38b.svg b/qortal-ui-core/emoji/svg/1f38b.svg new file mode 100644 index 00000000..06363807 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f38b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f38c.svg b/qortal-ui-core/emoji/svg/1f38c.svg new file mode 100644 index 00000000..a0dd3506 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f38c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f38d.svg b/qortal-ui-core/emoji/svg/1f38d.svg new file mode 100644 index 00000000..a774540b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f38d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f38e.svg b/qortal-ui-core/emoji/svg/1f38e.svg new file mode 100644 index 00000000..56b4b80a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f38e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f38f.svg b/qortal-ui-core/emoji/svg/1f38f.svg new file mode 100644 index 00000000..5457d1e8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f38f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f390.svg b/qortal-ui-core/emoji/svg/1f390.svg new file mode 100644 index 00000000..9aebc797 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f390.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f391.svg b/qortal-ui-core/emoji/svg/1f391.svg new file mode 100644 index 00000000..37c3a7e1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f391.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f392.svg b/qortal-ui-core/emoji/svg/1f392.svg new file mode 100644 index 00000000..f44d5680 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f392.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f393.svg b/qortal-ui-core/emoji/svg/1f393.svg new file mode 100644 index 00000000..dcf38931 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f396.svg b/qortal-ui-core/emoji/svg/1f396.svg new file mode 100644 index 00000000..b5c22696 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f396.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f397.svg b/qortal-ui-core/emoji/svg/1f397.svg new file mode 100644 index 00000000..1f419d45 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f397.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f399.svg b/qortal-ui-core/emoji/svg/1f399.svg new file mode 100644 index 00000000..07881e4a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f399.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f39a.svg b/qortal-ui-core/emoji/svg/1f39a.svg new file mode 100644 index 00000000..7071931f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f39a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f39b.svg b/qortal-ui-core/emoji/svg/1f39b.svg new file mode 100644 index 00000000..9d355c4a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f39b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f39e.svg b/qortal-ui-core/emoji/svg/1f39e.svg new file mode 100644 index 00000000..01f93112 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f39e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f39f.svg b/qortal-ui-core/emoji/svg/1f39f.svg new file mode 100644 index 00000000..984f2706 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f39f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3a0.svg b/qortal-ui-core/emoji/svg/1f3a0.svg new file mode 100644 index 00000000..35c75b69 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3a0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3a1.svg b/qortal-ui-core/emoji/svg/1f3a1.svg new file mode 100644 index 00000000..c35744ab --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3a1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3a2.svg b/qortal-ui-core/emoji/svg/1f3a2.svg new file mode 100644 index 00000000..256d8afb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3a2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3a3.svg b/qortal-ui-core/emoji/svg/1f3a3.svg new file mode 100644 index 00000000..1a1df4f9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3a3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3a4.svg b/qortal-ui-core/emoji/svg/1f3a4.svg new file mode 100644 index 00000000..e2613347 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3a5.svg b/qortal-ui-core/emoji/svg/1f3a5.svg new file mode 100644 index 00000000..d6c68e0d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3a5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3a6.svg b/qortal-ui-core/emoji/svg/1f3a6.svg new file mode 100644 index 00000000..04ba5e33 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3a6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3a7.svg b/qortal-ui-core/emoji/svg/1f3a7.svg new file mode 100644 index 00000000..3a9df15a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3a7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3a8.svg b/qortal-ui-core/emoji/svg/1f3a8.svg new file mode 100644 index 00000000..3bfdea0c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3a9.svg b/qortal-ui-core/emoji/svg/1f3a9.svg new file mode 100644 index 00000000..1017cef3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3a9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3aa.svg b/qortal-ui-core/emoji/svg/1f3aa.svg new file mode 100644 index 00000000..fec7dd2e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3aa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ab.svg b/qortal-ui-core/emoji/svg/1f3ab.svg new file mode 100644 index 00000000..cd234010 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ab.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ac.svg b/qortal-ui-core/emoji/svg/1f3ac.svg new file mode 100644 index 00000000..3a326766 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ac.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ad.svg b/qortal-ui-core/emoji/svg/1f3ad.svg new file mode 100644 index 00000000..c8c99012 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ad.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ae.svg b/qortal-ui-core/emoji/svg/1f3ae.svg new file mode 100644 index 00000000..4ec08ae4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ae.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3af.svg b/qortal-ui-core/emoji/svg/1f3af.svg new file mode 100644 index 00000000..9562c6c3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3b0.svg b/qortal-ui-core/emoji/svg/1f3b0.svg new file mode 100644 index 00000000..789fd08d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3b1.svg b/qortal-ui-core/emoji/svg/1f3b1.svg new file mode 100644 index 00000000..28abf33e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3b2.svg b/qortal-ui-core/emoji/svg/1f3b2.svg new file mode 100644 index 00000000..408f2f92 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3b3.svg b/qortal-ui-core/emoji/svg/1f3b3.svg new file mode 100644 index 00000000..9227f288 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3b4.svg b/qortal-ui-core/emoji/svg/1f3b4.svg new file mode 100644 index 00000000..33d3e0f5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3b4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3b5.svg b/qortal-ui-core/emoji/svg/1f3b5.svg new file mode 100644 index 00000000..c9286d2b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3b5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3b6.svg b/qortal-ui-core/emoji/svg/1f3b6.svg new file mode 100644 index 00000000..f13b3b8b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3b6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3b7.svg b/qortal-ui-core/emoji/svg/1f3b7.svg new file mode 100644 index 00000000..ed0f849e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3b7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3b8.svg b/qortal-ui-core/emoji/svg/1f3b8.svg new file mode 100644 index 00000000..22074a11 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3b8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3b9.svg b/qortal-ui-core/emoji/svg/1f3b9.svg new file mode 100644 index 00000000..6ce8afd9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3b9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ba.svg b/qortal-ui-core/emoji/svg/1f3ba.svg new file mode 100644 index 00000000..454ab781 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ba.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3bb.svg b/qortal-ui-core/emoji/svg/1f3bb.svg new file mode 100644 index 00000000..efb7d5da --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3bc.svg b/qortal-ui-core/emoji/svg/1f3bc.svg new file mode 100644 index 00000000..5628fcac --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3bd.svg b/qortal-ui-core/emoji/svg/1f3bd.svg new file mode 100644 index 00000000..8410aee4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3be.svg b/qortal-ui-core/emoji/svg/1f3be.svg new file mode 100644 index 00000000..323e5c46 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3be.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3bf.svg b/qortal-ui-core/emoji/svg/1f3bf.svg new file mode 100644 index 00000000..a117c938 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3bf.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c0.svg b/qortal-ui-core/emoji/svg/1f3c0.svg new file mode 100644 index 00000000..24693956 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c1.svg b/qortal-ui-core/emoji/svg/1f3c1.svg new file mode 100644 index 00000000..695f0ef3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c2-1f3fb.svg b/qortal-ui-core/emoji/svg/1f3c2-1f3fb.svg new file mode 100644 index 00000000..627fa068 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c2-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c2-1f3fc.svg b/qortal-ui-core/emoji/svg/1f3c2-1f3fc.svg new file mode 100644 index 00000000..c0090e16 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c2-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c2-1f3fd.svg b/qortal-ui-core/emoji/svg/1f3c2-1f3fd.svg new file mode 100644 index 00000000..e71263c9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c2-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c2-1f3fe.svg b/qortal-ui-core/emoji/svg/1f3c2-1f3fe.svg new file mode 100644 index 00000000..aa7ab8fa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c2-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c2-1f3ff.svg b/qortal-ui-core/emoji/svg/1f3c2-1f3ff.svg new file mode 100644 index 00000000..9f66b45f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c2-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c2.svg b/qortal-ui-core/emoji/svg/1f3c2.svg new file mode 100644 index 00000000..bff2c084 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c3-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..9c559abd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c3-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..604a0024 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-1f3fb.svg b/qortal-ui-core/emoji/svg/1f3c3-1f3fb.svg new file mode 100644 index 00000000..c650508d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c3-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..2639daf5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c3-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..f93e9dbf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-1f3fc.svg b/qortal-ui-core/emoji/svg/1f3c3-1f3fc.svg new file mode 100644 index 00000000..d207d92a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c3-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..f2677ee9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c3-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..847b7f6e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-1f3fd.svg b/qortal-ui-core/emoji/svg/1f3c3-1f3fd.svg new file mode 100644 index 00000000..54b5cbc8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c3-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..175349d1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c3-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..51db6d67 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-1f3fe.svg b/qortal-ui-core/emoji/svg/1f3c3-1f3fe.svg new file mode 100644 index 00000000..7012bb13 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c3-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..b19ab881 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c3-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..81889777 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-1f3ff.svg b/qortal-ui-core/emoji/svg/1f3c3-1f3ff.svg new file mode 100644 index 00000000..b45b1e01 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c3-200d-2640-fe0f.svg new file mode 100644 index 00000000..9acdb7a7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c3-200d-2642-fe0f.svg new file mode 100644 index 00000000..42bc6010 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c3.svg b/qortal-ui-core/emoji/svg/1f3c3.svg new file mode 100644 index 00000000..a9658d69 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c4-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..c5f30819 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c4-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..e396618f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-1f3fb.svg b/qortal-ui-core/emoji/svg/1f3c4-1f3fb.svg new file mode 100644 index 00000000..600f4aeb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c4-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..2fcf3c60 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c4-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..228af26f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-1f3fc.svg b/qortal-ui-core/emoji/svg/1f3c4-1f3fc.svg new file mode 100644 index 00000000..42a5f1de --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c4-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..0d575554 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c4-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..521b554b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-1f3fd.svg b/qortal-ui-core/emoji/svg/1f3c4-1f3fd.svg new file mode 100644 index 00000000..0c13cab5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c4-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..6372f70a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c4-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..147c45ae --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-1f3fe.svg b/qortal-ui-core/emoji/svg/1f3c4-1f3fe.svg new file mode 100644 index 00000000..269f1737 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c4-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..8cb8ad8f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c4-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..0e0ef2e9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-1f3ff.svg b/qortal-ui-core/emoji/svg/1f3c4-1f3ff.svg new file mode 100644 index 00000000..75cc5148 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c4-200d-2640-fe0f.svg new file mode 100644 index 00000000..c33ecc72 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3c4-200d-2642-fe0f.svg new file mode 100644 index 00000000..6da42a5c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c4.svg b/qortal-ui-core/emoji/svg/1f3c4.svg new file mode 100644 index 00000000..53b4ec65 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c5.svg b/qortal-ui-core/emoji/svg/1f3c5.svg new file mode 100644 index 00000000..a576ba8b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c6.svg b/qortal-ui-core/emoji/svg/1f3c6.svg new file mode 100644 index 00000000..00457c31 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c7-1f3fb.svg b/qortal-ui-core/emoji/svg/1f3c7-1f3fb.svg new file mode 100644 index 00000000..a48a00b1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c7-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c7-1f3fc.svg b/qortal-ui-core/emoji/svg/1f3c7-1f3fc.svg new file mode 100644 index 00000000..f80fc323 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c7-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c7-1f3fd.svg b/qortal-ui-core/emoji/svg/1f3c7-1f3fd.svg new file mode 100644 index 00000000..0baedbc9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c7-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c7-1f3fe.svg b/qortal-ui-core/emoji/svg/1f3c7-1f3fe.svg new file mode 100644 index 00000000..ef50b0b1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c7-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c7-1f3ff.svg b/qortal-ui-core/emoji/svg/1f3c7-1f3ff.svg new file mode 100644 index 00000000..ba0de655 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c7-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c7.svg b/qortal-ui-core/emoji/svg/1f3c7.svg new file mode 100644 index 00000000..e4cf1523 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c8.svg b/qortal-ui-core/emoji/svg/1f3c8.svg new file mode 100644 index 00000000..4f5530d2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3c9.svg b/qortal-ui-core/emoji/svg/1f3c9.svg new file mode 100644 index 00000000..5e12c43c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3c9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3ca-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..6ce5dcdb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3ca-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..b3e34553 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-1f3fb.svg b/qortal-ui-core/emoji/svg/1f3ca-1f3fb.svg new file mode 100644 index 00000000..cb149c34 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3ca-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..a2457fc7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3ca-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..86eda185 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-1f3fc.svg b/qortal-ui-core/emoji/svg/1f3ca-1f3fc.svg new file mode 100644 index 00000000..fd8f6f19 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3ca-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..8704f5b5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3ca-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..bf944220 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-1f3fd.svg b/qortal-ui-core/emoji/svg/1f3ca-1f3fd.svg new file mode 100644 index 00000000..36b89523 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3ca-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..4ee3a44d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3ca-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..e320765a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-1f3fe.svg b/qortal-ui-core/emoji/svg/1f3ca-1f3fe.svg new file mode 100644 index 00000000..0c54d993 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3ca-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..11f4beab --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3ca-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..a25741c2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-1f3ff.svg b/qortal-ui-core/emoji/svg/1f3ca-1f3ff.svg new file mode 100644 index 00000000..65dd7f37 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3ca-200d-2640-fe0f.svg new file mode 100644 index 00000000..dfc2cb61 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3ca-200d-2642-fe0f.svg new file mode 100644 index 00000000..12bad064 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ca.svg b/qortal-ui-core/emoji/svg/1f3ca.svg new file mode 100644 index 00000000..49013769 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ca.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cb-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..de38be18 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cb-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..1caeeb8f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-1f3fb.svg b/qortal-ui-core/emoji/svg/1f3cb-1f3fb.svg new file mode 100644 index 00000000..8bcc454f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cb-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..03f29357 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cb-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..44953ab1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-1f3fc.svg b/qortal-ui-core/emoji/svg/1f3cb-1f3fc.svg new file mode 100644 index 00000000..2898d555 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cb-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..00f68eed --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cb-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..5401c2f6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-1f3fd.svg b/qortal-ui-core/emoji/svg/1f3cb-1f3fd.svg new file mode 100644 index 00000000..6a8ede71 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cb-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..34e859a1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cb-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..b5f19bf2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-1f3fe.svg b/qortal-ui-core/emoji/svg/1f3cb-1f3fe.svg new file mode 100644 index 00000000..465f6c5b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cb-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..117b92a7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cb-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..2cf83c47 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-1f3ff.svg b/qortal-ui-core/emoji/svg/1f3cb-1f3ff.svg new file mode 100644 index 00000000..a557ed47 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-fe0f-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cb-fe0f-200d-2640-fe0f.svg new file mode 100644 index 00000000..1e2ac7f8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-fe0f-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb-fe0f-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cb-fe0f-200d-2642-fe0f.svg new file mode 100644 index 00000000..f9bbcc92 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb-fe0f-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cb.svg b/qortal-ui-core/emoji/svg/1f3cb.svg new file mode 100644 index 00000000..78e9c7a2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cc-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..781baf63 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cc-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..f478ef13 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-1f3fb.svg b/qortal-ui-core/emoji/svg/1f3cc-1f3fb.svg new file mode 100644 index 00000000..105b62c6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cc-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..61462b99 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cc-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..59373fd1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-1f3fc.svg b/qortal-ui-core/emoji/svg/1f3cc-1f3fc.svg new file mode 100644 index 00000000..e69be139 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cc-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..353c5c2e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cc-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..6e67562b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-1f3fd.svg b/qortal-ui-core/emoji/svg/1f3cc-1f3fd.svg new file mode 100644 index 00000000..d938cd7e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cc-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..9a9a856e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cc-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..24031bbf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-1f3fe.svg b/qortal-ui-core/emoji/svg/1f3cc-1f3fe.svg new file mode 100644 index 00000000..28f9169c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cc-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..13af8399 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cc-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..6c8ed88f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-1f3ff.svg b/qortal-ui-core/emoji/svg/1f3cc-1f3ff.svg new file mode 100644 index 00000000..91609819 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-fe0f-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cc-fe0f-200d-2640-fe0f.svg new file mode 100644 index 00000000..859d12f5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-fe0f-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc-fe0f-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f3cc-fe0f-200d-2642-fe0f.svg new file mode 100644 index 00000000..1381d6d3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc-fe0f-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cc.svg b/qortal-ui-core/emoji/svg/1f3cc.svg new file mode 100644 index 00000000..6b973a28 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cd.svg b/qortal-ui-core/emoji/svg/1f3cd.svg new file mode 100644 index 00000000..c51ccc34 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ce.svg b/qortal-ui-core/emoji/svg/1f3ce.svg new file mode 100644 index 00000000..3f427166 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ce.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3cf.svg b/qortal-ui-core/emoji/svg/1f3cf.svg new file mode 100644 index 00000000..140db58e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3cf.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3d0.svg b/qortal-ui-core/emoji/svg/1f3d0.svg new file mode 100644 index 00000000..b23cfc3a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3d0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3d1.svg b/qortal-ui-core/emoji/svg/1f3d1.svg new file mode 100644 index 00000000..c367cef2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3d1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3d2.svg b/qortal-ui-core/emoji/svg/1f3d2.svg new file mode 100644 index 00000000..382c6291 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3d2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3d3.svg b/qortal-ui-core/emoji/svg/1f3d3.svg new file mode 100644 index 00000000..6201ef5a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3d3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3d4.svg b/qortal-ui-core/emoji/svg/1f3d4.svg new file mode 100644 index 00000000..8b78f31e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3d4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3d5.svg b/qortal-ui-core/emoji/svg/1f3d5.svg new file mode 100644 index 00000000..7a2fb80e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3d5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3d6.svg b/qortal-ui-core/emoji/svg/1f3d6.svg new file mode 100644 index 00000000..9428f90f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3d6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3d7.svg b/qortal-ui-core/emoji/svg/1f3d7.svg new file mode 100644 index 00000000..e77a170b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3d7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3d8.svg b/qortal-ui-core/emoji/svg/1f3d8.svg new file mode 100644 index 00000000..483f1ade --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3d8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3d9.svg b/qortal-ui-core/emoji/svg/1f3d9.svg new file mode 100644 index 00000000..b379d80e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3d9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3da.svg b/qortal-ui-core/emoji/svg/1f3da.svg new file mode 100644 index 00000000..5c5ade6b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3da.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3db.svg b/qortal-ui-core/emoji/svg/1f3db.svg new file mode 100644 index 00000000..bdd0d45f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3db.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3dc.svg b/qortal-ui-core/emoji/svg/1f3dc.svg new file mode 100644 index 00000000..99baa8d0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3dc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3dd.svg b/qortal-ui-core/emoji/svg/1f3dd.svg new file mode 100644 index 00000000..d66d8d47 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3dd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3de.svg b/qortal-ui-core/emoji/svg/1f3de.svg new file mode 100644 index 00000000..940483bd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3de.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3df.svg b/qortal-ui-core/emoji/svg/1f3df.svg new file mode 100644 index 00000000..248c6d9e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3df.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3e0.svg b/qortal-ui-core/emoji/svg/1f3e0.svg new file mode 100644 index 00000000..0692739d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3e0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3e1.svg b/qortal-ui-core/emoji/svg/1f3e1.svg new file mode 100644 index 00000000..b44b7288 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3e1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3e2.svg b/qortal-ui-core/emoji/svg/1f3e2.svg new file mode 100644 index 00000000..8d06ecd2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3e2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3e3.svg b/qortal-ui-core/emoji/svg/1f3e3.svg new file mode 100644 index 00000000..132ba410 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3e4.svg b/qortal-ui-core/emoji/svg/1f3e4.svg new file mode 100644 index 00000000..7ac74e40 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3e4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3e5.svg b/qortal-ui-core/emoji/svg/1f3e5.svg new file mode 100644 index 00000000..0b2748a5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3e5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3e6.svg b/qortal-ui-core/emoji/svg/1f3e6.svg new file mode 100644 index 00000000..2fd3fb07 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3e7.svg b/qortal-ui-core/emoji/svg/1f3e7.svg new file mode 100644 index 00000000..e4c0000b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3e7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3e8.svg b/qortal-ui-core/emoji/svg/1f3e8.svg new file mode 100644 index 00000000..2d67b9a9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3e9.svg b/qortal-ui-core/emoji/svg/1f3e9.svg new file mode 100644 index 00000000..9da5e448 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ea.svg b/qortal-ui-core/emoji/svg/1f3ea.svg new file mode 100644 index 00000000..87f3f963 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3eb.svg b/qortal-ui-core/emoji/svg/1f3eb.svg new file mode 100644 index 00000000..8be9e962 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ec.svg b/qortal-ui-core/emoji/svg/1f3ec.svg new file mode 100644 index 00000000..c30d022e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ed.svg b/qortal-ui-core/emoji/svg/1f3ed.svg new file mode 100644 index 00000000..04ee1626 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ee.svg b/qortal-ui-core/emoji/svg/1f3ee.svg new file mode 100644 index 00000000..a825f2b7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ee.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ef.svg b/qortal-ui-core/emoji/svg/1f3ef.svg new file mode 100644 index 00000000..21683997 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ef.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3f0.svg b/qortal-ui-core/emoji/svg/1f3f0.svg new file mode 100644 index 00000000..b4e3d19f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3f3-fe0f-200d-1f308.svg b/qortal-ui-core/emoji/svg/1f3f3-fe0f-200d-1f308.svg new file mode 100644 index 00000000..1969e497 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3f3-fe0f-200d-1f308.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3f3-fe0f-200d-26a7-fe0f.svg b/qortal-ui-core/emoji/svg/1f3f3-fe0f-200d-26a7-fe0f.svg new file mode 100644 index 00000000..f9fc064c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3f3-fe0f-200d-26a7-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3f3.svg b/qortal-ui-core/emoji/svg/1f3f3.svg new file mode 100644 index 00000000..2f21575d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3f4-200d-2620-fe0f.svg b/qortal-ui-core/emoji/svg/1f3f4-200d-2620-fe0f.svg new file mode 100644 index 00000000..ae0d531a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3f4-200d-2620-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3f4-e0067-e0062-e0065-e006e-e0067-e007f.svg b/qortal-ui-core/emoji/svg/1f3f4-e0067-e0062-e0065-e006e-e0067-e007f.svg new file mode 100644 index 00000000..fa209567 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3f4-e0067-e0062-e0065-e006e-e0067-e007f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3f4-e0067-e0062-e0073-e0063-e0074-e007f.svg b/qortal-ui-core/emoji/svg/1f3f4-e0067-e0062-e0073-e0063-e0074-e007f.svg new file mode 100644 index 00000000..bfb8b485 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3f4-e0067-e0062-e0073-e0063-e0074-e007f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3f4-e0067-e0062-e0077-e006c-e0073-e007f.svg b/qortal-ui-core/emoji/svg/1f3f4-e0067-e0062-e0077-e006c-e0073-e007f.svg new file mode 100644 index 00000000..a8326768 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3f4-e0067-e0062-e0077-e006c-e0073-e007f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3f4.svg b/qortal-ui-core/emoji/svg/1f3f4.svg new file mode 100644 index 00000000..819ff64a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3f5.svg b/qortal-ui-core/emoji/svg/1f3f5.svg new file mode 100644 index 00000000..dfaa7186 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3f5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3f7.svg b/qortal-ui-core/emoji/svg/1f3f7.svg new file mode 100644 index 00000000..60462664 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3f8.svg b/qortal-ui-core/emoji/svg/1f3f8.svg new file mode 100644 index 00000000..143f8eae --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3f9.svg b/qortal-ui-core/emoji/svg/1f3f9.svg new file mode 100644 index 00000000..37922127 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3fa.svg b/qortal-ui-core/emoji/svg/1f3fa.svg new file mode 100644 index 00000000..4c6b4d8f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3fb.svg b/qortal-ui-core/emoji/svg/1f3fb.svg new file mode 100644 index 00000000..e1ac3e94 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3fc.svg b/qortal-ui-core/emoji/svg/1f3fc.svg new file mode 100644 index 00000000..33c58c9c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3fd.svg b/qortal-ui-core/emoji/svg/1f3fd.svg new file mode 100644 index 00000000..cb3c24e7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3fe.svg b/qortal-ui-core/emoji/svg/1f3fe.svg new file mode 100644 index 00000000..7f34e609 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f3ff.svg b/qortal-ui-core/emoji/svg/1f3ff.svg new file mode 100644 index 00000000..64142d3e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f400.svg b/qortal-ui-core/emoji/svg/1f400.svg new file mode 100644 index 00000000..d0a03a2c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f400.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f401.svg b/qortal-ui-core/emoji/svg/1f401.svg new file mode 100644 index 00000000..365ab788 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f401.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f402.svg b/qortal-ui-core/emoji/svg/1f402.svg new file mode 100644 index 00000000..378164c3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f402.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f403.svg b/qortal-ui-core/emoji/svg/1f403.svg new file mode 100644 index 00000000..33d0009f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f403.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f404.svg b/qortal-ui-core/emoji/svg/1f404.svg new file mode 100644 index 00000000..4c791dcc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f404.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f405.svg b/qortal-ui-core/emoji/svg/1f405.svg new file mode 100644 index 00000000..c74ecf6f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f405.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f406.svg b/qortal-ui-core/emoji/svg/1f406.svg new file mode 100644 index 00000000..4eaef099 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f406.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f407.svg b/qortal-ui-core/emoji/svg/1f407.svg new file mode 100644 index 00000000..71be1224 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f407.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f408-200d-2b1b.svg b/qortal-ui-core/emoji/svg/1f408-200d-2b1b.svg new file mode 100644 index 00000000..cf7b1d90 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f408-200d-2b1b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f408.svg b/qortal-ui-core/emoji/svg/1f408.svg new file mode 100644 index 00000000..edb55b1f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f408.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f409.svg b/qortal-ui-core/emoji/svg/1f409.svg new file mode 100644 index 00000000..14e17655 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f409.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f40a.svg b/qortal-ui-core/emoji/svg/1f40a.svg new file mode 100644 index 00000000..a9a6debc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f40a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f40b.svg b/qortal-ui-core/emoji/svg/1f40b.svg new file mode 100644 index 00000000..8bf0a538 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f40b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f40c.svg b/qortal-ui-core/emoji/svg/1f40c.svg new file mode 100644 index 00000000..2c636582 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f40c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f40d.svg b/qortal-ui-core/emoji/svg/1f40d.svg new file mode 100644 index 00000000..17531783 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f40d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f40e.svg b/qortal-ui-core/emoji/svg/1f40e.svg new file mode 100644 index 00000000..1cd00b59 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f40e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f40f.svg b/qortal-ui-core/emoji/svg/1f40f.svg new file mode 100644 index 00000000..f0ba99ef --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f40f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f410.svg b/qortal-ui-core/emoji/svg/1f410.svg new file mode 100644 index 00000000..83d3e56a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f410.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f411.svg b/qortal-ui-core/emoji/svg/1f411.svg new file mode 100644 index 00000000..891e6702 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f411.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f412.svg b/qortal-ui-core/emoji/svg/1f412.svg new file mode 100644 index 00000000..6ffccee4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f412.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f413.svg b/qortal-ui-core/emoji/svg/1f413.svg new file mode 100644 index 00000000..29a4abe8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f413.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f414.svg b/qortal-ui-core/emoji/svg/1f414.svg new file mode 100644 index 00000000..b08f7a2b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f414.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f415-200d-1f9ba.svg b/qortal-ui-core/emoji/svg/1f415-200d-1f9ba.svg new file mode 100644 index 00000000..0ba7fb30 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f415-200d-1f9ba.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f415.svg b/qortal-ui-core/emoji/svg/1f415.svg new file mode 100644 index 00000000..c959deb9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f415.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f416.svg b/qortal-ui-core/emoji/svg/1f416.svg new file mode 100644 index 00000000..9a71ef84 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f416.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f417.svg b/qortal-ui-core/emoji/svg/1f417.svg new file mode 100644 index 00000000..ad7a77db --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f417.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f418.svg b/qortal-ui-core/emoji/svg/1f418.svg new file mode 100644 index 00000000..fb9656cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f418.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f419.svg b/qortal-ui-core/emoji/svg/1f419.svg new file mode 100644 index 00000000..d915a8fd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f419.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f41a.svg b/qortal-ui-core/emoji/svg/1f41a.svg new file mode 100644 index 00000000..804ece88 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f41a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f41b.svg b/qortal-ui-core/emoji/svg/1f41b.svg new file mode 100644 index 00000000..f8986dd7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f41b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f41c.svg b/qortal-ui-core/emoji/svg/1f41c.svg new file mode 100644 index 00000000..385b616e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f41c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f41d.svg b/qortal-ui-core/emoji/svg/1f41d.svg new file mode 100644 index 00000000..31e78828 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f41d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f41e.svg b/qortal-ui-core/emoji/svg/1f41e.svg new file mode 100644 index 00000000..f314ca9a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f41e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f41f.svg b/qortal-ui-core/emoji/svg/1f41f.svg new file mode 100644 index 00000000..7d9ef410 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f41f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f420.svg b/qortal-ui-core/emoji/svg/1f420.svg new file mode 100644 index 00000000..ccc11c48 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f420.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f421.svg b/qortal-ui-core/emoji/svg/1f421.svg new file mode 100644 index 00000000..13a7ddc6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f421.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f422.svg b/qortal-ui-core/emoji/svg/1f422.svg new file mode 100644 index 00000000..fe4b659e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f422.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f423.svg b/qortal-ui-core/emoji/svg/1f423.svg new file mode 100644 index 00000000..98f9c822 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f423.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f424.svg b/qortal-ui-core/emoji/svg/1f424.svg new file mode 100644 index 00000000..1286ed38 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f424.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f425.svg b/qortal-ui-core/emoji/svg/1f425.svg new file mode 100644 index 00000000..bcbd2181 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f425.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f426.svg b/qortal-ui-core/emoji/svg/1f426.svg new file mode 100644 index 00000000..06d93a91 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f426.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f427.svg b/qortal-ui-core/emoji/svg/1f427.svg new file mode 100644 index 00000000..fe34d91a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f427.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f428.svg b/qortal-ui-core/emoji/svg/1f428.svg new file mode 100644 index 00000000..1da7190a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f428.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f429.svg b/qortal-ui-core/emoji/svg/1f429.svg new file mode 100644 index 00000000..0ffd0828 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f429.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f42a.svg b/qortal-ui-core/emoji/svg/1f42a.svg new file mode 100644 index 00000000..278e144f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f42a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f42b.svg b/qortal-ui-core/emoji/svg/1f42b.svg new file mode 100644 index 00000000..8d60286e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f42b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f42c.svg b/qortal-ui-core/emoji/svg/1f42c.svg new file mode 100644 index 00000000..ee782f2f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f42c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f42d.svg b/qortal-ui-core/emoji/svg/1f42d.svg new file mode 100644 index 00000000..91e12624 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f42d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f42e.svg b/qortal-ui-core/emoji/svg/1f42e.svg new file mode 100644 index 00000000..40fede03 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f42e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f42f.svg b/qortal-ui-core/emoji/svg/1f42f.svg new file mode 100644 index 00000000..5ecd980c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f42f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f430.svg b/qortal-ui-core/emoji/svg/1f430.svg new file mode 100644 index 00000000..2f70f966 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f430.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f431.svg b/qortal-ui-core/emoji/svg/1f431.svg new file mode 100644 index 00000000..cc75dcc6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f431.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f432.svg b/qortal-ui-core/emoji/svg/1f432.svg new file mode 100644 index 00000000..1c1b4347 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f432.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f433.svg b/qortal-ui-core/emoji/svg/1f433.svg new file mode 100644 index 00000000..f00ea103 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f433.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f434.svg b/qortal-ui-core/emoji/svg/1f434.svg new file mode 100644 index 00000000..9aa7d693 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f434.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f435.svg b/qortal-ui-core/emoji/svg/1f435.svg new file mode 100644 index 00000000..ee6c57cf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f435.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f436.svg b/qortal-ui-core/emoji/svg/1f436.svg new file mode 100644 index 00000000..8b2e6858 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f436.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f437.svg b/qortal-ui-core/emoji/svg/1f437.svg new file mode 100644 index 00000000..49175ea4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f437.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f438.svg b/qortal-ui-core/emoji/svg/1f438.svg new file mode 100644 index 00000000..74ddb592 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f438.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f439.svg b/qortal-ui-core/emoji/svg/1f439.svg new file mode 100644 index 00000000..9bb7bae3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f439.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f43a.svg b/qortal-ui-core/emoji/svg/1f43a.svg new file mode 100644 index 00000000..af402057 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f43a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f43b-200d-2744-fe0f.svg b/qortal-ui-core/emoji/svg/1f43b-200d-2744-fe0f.svg new file mode 100644 index 00000000..dc70f185 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f43b-200d-2744-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f43b.svg b/qortal-ui-core/emoji/svg/1f43b.svg new file mode 100644 index 00000000..50224417 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f43b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f43c.svg b/qortal-ui-core/emoji/svg/1f43c.svg new file mode 100644 index 00000000..8607893a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f43c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f43d.svg b/qortal-ui-core/emoji/svg/1f43d.svg new file mode 100644 index 00000000..071722db --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f43d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f43e.svg b/qortal-ui-core/emoji/svg/1f43e.svg new file mode 100644 index 00000000..40013679 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f43e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f43f.svg b/qortal-ui-core/emoji/svg/1f43f.svg new file mode 100644 index 00000000..36768749 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f43f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f440.svg b/qortal-ui-core/emoji/svg/1f440.svg new file mode 100644 index 00000000..46a268f4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f440.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f441-200d-1f5e8.svg b/qortal-ui-core/emoji/svg/1f441-200d-1f5e8.svg new file mode 100644 index 00000000..ebe9061d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f441-200d-1f5e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f441.svg b/qortal-ui-core/emoji/svg/1f441.svg new file mode 100644 index 00000000..bd1a45e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f441.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f442-1f3fb.svg b/qortal-ui-core/emoji/svg/1f442-1f3fb.svg new file mode 100644 index 00000000..75194c52 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f442-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f442-1f3fc.svg b/qortal-ui-core/emoji/svg/1f442-1f3fc.svg new file mode 100644 index 00000000..f4ae52f7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f442-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f442-1f3fd.svg b/qortal-ui-core/emoji/svg/1f442-1f3fd.svg new file mode 100644 index 00000000..da1d80a1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f442-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f442-1f3fe.svg b/qortal-ui-core/emoji/svg/1f442-1f3fe.svg new file mode 100644 index 00000000..f54144b3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f442-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f442-1f3ff.svg b/qortal-ui-core/emoji/svg/1f442-1f3ff.svg new file mode 100644 index 00000000..84545121 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f442-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f442.svg b/qortal-ui-core/emoji/svg/1f442.svg new file mode 100644 index 00000000..1b386c7c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f442.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f443-1f3fb.svg b/qortal-ui-core/emoji/svg/1f443-1f3fb.svg new file mode 100644 index 00000000..ba2e3dc7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f443-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f443-1f3fc.svg b/qortal-ui-core/emoji/svg/1f443-1f3fc.svg new file mode 100644 index 00000000..e953ffde --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f443-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f443-1f3fd.svg b/qortal-ui-core/emoji/svg/1f443-1f3fd.svg new file mode 100644 index 00000000..fff0434a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f443-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f443-1f3fe.svg b/qortal-ui-core/emoji/svg/1f443-1f3fe.svg new file mode 100644 index 00000000..bfb49618 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f443-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f443-1f3ff.svg b/qortal-ui-core/emoji/svg/1f443-1f3ff.svg new file mode 100644 index 00000000..e9c466d8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f443-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f443.svg b/qortal-ui-core/emoji/svg/1f443.svg new file mode 100644 index 00000000..654a6f2a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f443.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f444.svg b/qortal-ui-core/emoji/svg/1f444.svg new file mode 100644 index 00000000..e8a29c47 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f444.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f445.svg b/qortal-ui-core/emoji/svg/1f445.svg new file mode 100644 index 00000000..64386b95 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f445.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f446-1f3fb.svg b/qortal-ui-core/emoji/svg/1f446-1f3fb.svg new file mode 100644 index 00000000..4b66516d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f446-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f446-1f3fc.svg b/qortal-ui-core/emoji/svg/1f446-1f3fc.svg new file mode 100644 index 00000000..f2f80230 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f446-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f446-1f3fd.svg b/qortal-ui-core/emoji/svg/1f446-1f3fd.svg new file mode 100644 index 00000000..8a35f113 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f446-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f446-1f3fe.svg b/qortal-ui-core/emoji/svg/1f446-1f3fe.svg new file mode 100644 index 00000000..dce82c50 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f446-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f446-1f3ff.svg b/qortal-ui-core/emoji/svg/1f446-1f3ff.svg new file mode 100644 index 00000000..56492307 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f446-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f446.svg b/qortal-ui-core/emoji/svg/1f446.svg new file mode 100644 index 00000000..46bc3596 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f446.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f447-1f3fb.svg b/qortal-ui-core/emoji/svg/1f447-1f3fb.svg new file mode 100644 index 00000000..5d5c6790 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f447-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f447-1f3fc.svg b/qortal-ui-core/emoji/svg/1f447-1f3fc.svg new file mode 100644 index 00000000..6191d80e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f447-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f447-1f3fd.svg b/qortal-ui-core/emoji/svg/1f447-1f3fd.svg new file mode 100644 index 00000000..553f3b90 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f447-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f447-1f3fe.svg b/qortal-ui-core/emoji/svg/1f447-1f3fe.svg new file mode 100644 index 00000000..2d7fc57d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f447-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f447-1f3ff.svg b/qortal-ui-core/emoji/svg/1f447-1f3ff.svg new file mode 100644 index 00000000..e64a83e5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f447-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f447.svg b/qortal-ui-core/emoji/svg/1f447.svg new file mode 100644 index 00000000..b3df6170 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f447.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f448-1f3fb.svg b/qortal-ui-core/emoji/svg/1f448-1f3fb.svg new file mode 100644 index 00000000..452e1731 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f448-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f448-1f3fc.svg b/qortal-ui-core/emoji/svg/1f448-1f3fc.svg new file mode 100644 index 00000000..698207e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f448-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f448-1f3fd.svg b/qortal-ui-core/emoji/svg/1f448-1f3fd.svg new file mode 100644 index 00000000..dec8dbed --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f448-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f448-1f3fe.svg b/qortal-ui-core/emoji/svg/1f448-1f3fe.svg new file mode 100644 index 00000000..60e329d9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f448-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f448-1f3ff.svg b/qortal-ui-core/emoji/svg/1f448-1f3ff.svg new file mode 100644 index 00000000..58e85097 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f448-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f448.svg b/qortal-ui-core/emoji/svg/1f448.svg new file mode 100644 index 00000000..10cf55fa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f448.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f449-1f3fb.svg b/qortal-ui-core/emoji/svg/1f449-1f3fb.svg new file mode 100644 index 00000000..76635f26 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f449-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f449-1f3fc.svg b/qortal-ui-core/emoji/svg/1f449-1f3fc.svg new file mode 100644 index 00000000..4f03a7e8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f449-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f449-1f3fd.svg b/qortal-ui-core/emoji/svg/1f449-1f3fd.svg new file mode 100644 index 00000000..5b90a8a3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f449-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f449-1f3fe.svg b/qortal-ui-core/emoji/svg/1f449-1f3fe.svg new file mode 100644 index 00000000..75257c12 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f449-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f449-1f3ff.svg b/qortal-ui-core/emoji/svg/1f449-1f3ff.svg new file mode 100644 index 00000000..d7b5893c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f449-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f449.svg b/qortal-ui-core/emoji/svg/1f449.svg new file mode 100644 index 00000000..f8c6a4b1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f449.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44a-1f3fb.svg b/qortal-ui-core/emoji/svg/1f44a-1f3fb.svg new file mode 100644 index 00000000..c113b4ae --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44a-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44a-1f3fc.svg b/qortal-ui-core/emoji/svg/1f44a-1f3fc.svg new file mode 100644 index 00000000..54cdf858 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44a-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44a-1f3fd.svg b/qortal-ui-core/emoji/svg/1f44a-1f3fd.svg new file mode 100644 index 00000000..b798e5ba --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44a-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44a-1f3fe.svg b/qortal-ui-core/emoji/svg/1f44a-1f3fe.svg new file mode 100644 index 00000000..c9b1cf60 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44a-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44a-1f3ff.svg b/qortal-ui-core/emoji/svg/1f44a-1f3ff.svg new file mode 100644 index 00000000..faa58cbc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44a-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44a.svg b/qortal-ui-core/emoji/svg/1f44a.svg new file mode 100644 index 00000000..813373e6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44b-1f3fb.svg b/qortal-ui-core/emoji/svg/1f44b-1f3fb.svg new file mode 100644 index 00000000..de8871dc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44b-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44b-1f3fc.svg b/qortal-ui-core/emoji/svg/1f44b-1f3fc.svg new file mode 100644 index 00000000..beec31c9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44b-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44b-1f3fd.svg b/qortal-ui-core/emoji/svg/1f44b-1f3fd.svg new file mode 100644 index 00000000..975f489f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44b-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44b-1f3fe.svg b/qortal-ui-core/emoji/svg/1f44b-1f3fe.svg new file mode 100644 index 00000000..13c59cf1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44b-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44b-1f3ff.svg b/qortal-ui-core/emoji/svg/1f44b-1f3ff.svg new file mode 100644 index 00000000..1ce9ef37 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44b-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44b.svg b/qortal-ui-core/emoji/svg/1f44b.svg new file mode 100644 index 00000000..8942c68b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44c-1f3fb.svg b/qortal-ui-core/emoji/svg/1f44c-1f3fb.svg new file mode 100644 index 00000000..e54788da --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44c-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44c-1f3fc.svg b/qortal-ui-core/emoji/svg/1f44c-1f3fc.svg new file mode 100644 index 00000000..e96a2580 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44c-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44c-1f3fd.svg b/qortal-ui-core/emoji/svg/1f44c-1f3fd.svg new file mode 100644 index 00000000..6e52b17f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44c-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44c-1f3fe.svg b/qortal-ui-core/emoji/svg/1f44c-1f3fe.svg new file mode 100644 index 00000000..91cb40e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44c-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44c-1f3ff.svg b/qortal-ui-core/emoji/svg/1f44c-1f3ff.svg new file mode 100644 index 00000000..ffa03f7a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44c-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44c.svg b/qortal-ui-core/emoji/svg/1f44c.svg new file mode 100644 index 00000000..c36d7748 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44d-1f3fb.svg b/qortal-ui-core/emoji/svg/1f44d-1f3fb.svg new file mode 100644 index 00000000..ac1ab027 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44d-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44d-1f3fc.svg b/qortal-ui-core/emoji/svg/1f44d-1f3fc.svg new file mode 100644 index 00000000..e5d4b0dc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44d-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44d-1f3fd.svg b/qortal-ui-core/emoji/svg/1f44d-1f3fd.svg new file mode 100644 index 00000000..7dde2291 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44d-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44d-1f3fe.svg b/qortal-ui-core/emoji/svg/1f44d-1f3fe.svg new file mode 100644 index 00000000..a0b15657 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44d-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44d-1f3ff.svg b/qortal-ui-core/emoji/svg/1f44d-1f3ff.svg new file mode 100644 index 00000000..dc21efcb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44d-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44d.svg b/qortal-ui-core/emoji/svg/1f44d.svg new file mode 100644 index 00000000..595672dc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44e-1f3fb.svg b/qortal-ui-core/emoji/svg/1f44e-1f3fb.svg new file mode 100644 index 00000000..cf3616ea --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44e-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44e-1f3fc.svg b/qortal-ui-core/emoji/svg/1f44e-1f3fc.svg new file mode 100644 index 00000000..e929cabb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44e-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44e-1f3fd.svg b/qortal-ui-core/emoji/svg/1f44e-1f3fd.svg new file mode 100644 index 00000000..0584fd01 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44e-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44e-1f3fe.svg b/qortal-ui-core/emoji/svg/1f44e-1f3fe.svg new file mode 100644 index 00000000..88af00e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44e-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44e-1f3ff.svg b/qortal-ui-core/emoji/svg/1f44e-1f3ff.svg new file mode 100644 index 00000000..0e8c62e3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44e-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44e.svg b/qortal-ui-core/emoji/svg/1f44e.svg new file mode 100644 index 00000000..1569ad09 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44f-1f3fb.svg b/qortal-ui-core/emoji/svg/1f44f-1f3fb.svg new file mode 100644 index 00000000..27feea25 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44f-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44f-1f3fc.svg b/qortal-ui-core/emoji/svg/1f44f-1f3fc.svg new file mode 100644 index 00000000..7edc9477 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44f-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44f-1f3fd.svg b/qortal-ui-core/emoji/svg/1f44f-1f3fd.svg new file mode 100644 index 00000000..93201cf6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44f-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44f-1f3fe.svg b/qortal-ui-core/emoji/svg/1f44f-1f3fe.svg new file mode 100644 index 00000000..0301e0cf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44f-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44f-1f3ff.svg b/qortal-ui-core/emoji/svg/1f44f-1f3ff.svg new file mode 100644 index 00000000..eec087b6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44f-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f44f.svg b/qortal-ui-core/emoji/svg/1f44f.svg new file mode 100644 index 00000000..2ed7b62f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f44f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f450-1f3fb.svg b/qortal-ui-core/emoji/svg/1f450-1f3fb.svg new file mode 100644 index 00000000..621c9f6c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f450-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f450-1f3fc.svg b/qortal-ui-core/emoji/svg/1f450-1f3fc.svg new file mode 100644 index 00000000..70b490f4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f450-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f450-1f3fd.svg b/qortal-ui-core/emoji/svg/1f450-1f3fd.svg new file mode 100644 index 00000000..a8944369 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f450-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f450-1f3fe.svg b/qortal-ui-core/emoji/svg/1f450-1f3fe.svg new file mode 100644 index 00000000..e31b85ca --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f450-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f450-1f3ff.svg b/qortal-ui-core/emoji/svg/1f450-1f3ff.svg new file mode 100644 index 00000000..c0d8fc43 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f450-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f450.svg b/qortal-ui-core/emoji/svg/1f450.svg new file mode 100644 index 00000000..eebee254 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f450.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f451.svg b/qortal-ui-core/emoji/svg/1f451.svg new file mode 100644 index 00000000..4db8d2bc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f451.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f452.svg b/qortal-ui-core/emoji/svg/1f452.svg new file mode 100644 index 00000000..4b647446 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f452.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f453.svg b/qortal-ui-core/emoji/svg/1f453.svg new file mode 100644 index 00000000..18d99981 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f453.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f454.svg b/qortal-ui-core/emoji/svg/1f454.svg new file mode 100644 index 00000000..8e860d6d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f454.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f455.svg b/qortal-ui-core/emoji/svg/1f455.svg new file mode 100644 index 00000000..1db48202 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f455.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f456.svg b/qortal-ui-core/emoji/svg/1f456.svg new file mode 100644 index 00000000..44191ae4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f456.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f457.svg b/qortal-ui-core/emoji/svg/1f457.svg new file mode 100644 index 00000000..29cc45c7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f457.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f458.svg b/qortal-ui-core/emoji/svg/1f458.svg new file mode 100644 index 00000000..7c955e99 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f458.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f459.svg b/qortal-ui-core/emoji/svg/1f459.svg new file mode 100644 index 00000000..ed327f10 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f459.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f45a.svg b/qortal-ui-core/emoji/svg/1f45a.svg new file mode 100644 index 00000000..9d6306ce --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f45a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f45b.svg b/qortal-ui-core/emoji/svg/1f45b.svg new file mode 100644 index 00000000..bb404a2b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f45b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f45c.svg b/qortal-ui-core/emoji/svg/1f45c.svg new file mode 100644 index 00000000..3093d6bb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f45c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f45d.svg b/qortal-ui-core/emoji/svg/1f45d.svg new file mode 100644 index 00000000..6d6b1364 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f45d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f45e.svg b/qortal-ui-core/emoji/svg/1f45e.svg new file mode 100644 index 00000000..fe94bf59 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f45e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f45f.svg b/qortal-ui-core/emoji/svg/1f45f.svg new file mode 100644 index 00000000..f0c998c6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f45f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f460.svg b/qortal-ui-core/emoji/svg/1f460.svg new file mode 100644 index 00000000..f3aaf449 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f460.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f461.svg b/qortal-ui-core/emoji/svg/1f461.svg new file mode 100644 index 00000000..c2f62e4f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f461.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f462.svg b/qortal-ui-core/emoji/svg/1f462.svg new file mode 100644 index 00000000..641dd8b2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f462.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f463.svg b/qortal-ui-core/emoji/svg/1f463.svg new file mode 100644 index 00000000..bc37ac05 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f463.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f464.svg b/qortal-ui-core/emoji/svg/1f464.svg new file mode 100644 index 00000000..51d02dd2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f464.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f465.svg b/qortal-ui-core/emoji/svg/1f465.svg new file mode 100644 index 00000000..076c6e7d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f465.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f466-1f3fb.svg b/qortal-ui-core/emoji/svg/1f466-1f3fb.svg new file mode 100644 index 00000000..449e0892 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f466-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f466-1f3fc.svg b/qortal-ui-core/emoji/svg/1f466-1f3fc.svg new file mode 100644 index 00000000..20f7bf0d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f466-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f466-1f3fd.svg b/qortal-ui-core/emoji/svg/1f466-1f3fd.svg new file mode 100644 index 00000000..3b4f0dba --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f466-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f466-1f3fe.svg b/qortal-ui-core/emoji/svg/1f466-1f3fe.svg new file mode 100644 index 00000000..197d8309 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f466-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f466-1f3ff.svg b/qortal-ui-core/emoji/svg/1f466-1f3ff.svg new file mode 100644 index 00000000..c4d1e1a2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f466-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f466.svg b/qortal-ui-core/emoji/svg/1f466.svg new file mode 100644 index 00000000..de1318cc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f467-1f3fb.svg b/qortal-ui-core/emoji/svg/1f467-1f3fb.svg new file mode 100644 index 00000000..887df9fc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f467-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f467-1f3fc.svg b/qortal-ui-core/emoji/svg/1f467-1f3fc.svg new file mode 100644 index 00000000..98c09561 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f467-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f467-1f3fd.svg b/qortal-ui-core/emoji/svg/1f467-1f3fd.svg new file mode 100644 index 00000000..058874c7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f467-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f467-1f3fe.svg b/qortal-ui-core/emoji/svg/1f467-1f3fe.svg new file mode 100644 index 00000000..dd656d86 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f467-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f467-1f3ff.svg b/qortal-ui-core/emoji/svg/1f467-1f3ff.svg new file mode 100644 index 00000000..2f9980a8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f467-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f467.svg b/qortal-ui-core/emoji/svg/1f467.svg new file mode 100644 index 00000000..e40a8589 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f467.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f33e.svg new file mode 100644 index 00000000..e9ce8292 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f373.svg new file mode 100644 index 00000000..a972e6a4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f37c.svg new file mode 100644 index 00000000..19c8fff2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f384.svg new file mode 100644 index 00000000..ef5c6153 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f393.svg new file mode 100644 index 00000000..e4f480ff --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f3a4.svg new file mode 100644 index 00000000..03b4f988 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f3a8.svg new file mode 100644 index 00000000..c5249097 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f3eb.svg new file mode 100644 index 00000000..b8b0f125 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f3ed.svg new file mode 100644 index 00000000..96b45869 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f4bb.svg new file mode 100644 index 00000000..70ea65ec --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f4bc.svg new file mode 100644 index 00000000..06f78911 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f527.svg new file mode 100644 index 00000000..fc9059e0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f52c.svg new file mode 100644 index 00000000..08440f06 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f680.svg new file mode 100644 index 00000000..8492ec94 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f692.svg new file mode 100644 index 00000000..4d32c4df --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f91d-200d-1f468-1f3fc.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f91d-200d-1f468-1f3fc.svg new file mode 100644 index 00000000..7ad1503a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f91d-200d-1f468-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f91d-200d-1f468-1f3fd.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f91d-200d-1f468-1f3fd.svg new file mode 100644 index 00000000..a431a10c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f91d-200d-1f468-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f91d-200d-1f468-1f3fe.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f91d-200d-1f468-1f3fe.svg new file mode 100644 index 00000000..26df5261 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f91d-200d-1f468-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f91d-200d-1f468-1f3ff.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f91d-200d-1f468-1f3ff.svg new file mode 100644 index 00000000..aba57a36 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f91d-200d-1f468-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9af.svg new file mode 100644 index 00000000..06f7b2cf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9b0.svg new file mode 100644 index 00000000..e627fbc2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9b1.svg new file mode 100644 index 00000000..d21a1f77 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9b2.svg new file mode 100644 index 00000000..9c89431f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9b3.svg new file mode 100644 index 00000000..66c62c1e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9bc.svg new file mode 100644 index 00000000..01278456 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9bd.svg new file mode 100644 index 00000000..7d0c06d0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-2695-fe0f.svg new file mode 100644 index 00000000..7e239f00 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-2696-fe0f.svg new file mode 100644 index 00000000..78a2a14c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-2708-fe0f.svg new file mode 100644 index 00000000..fb5ef4b8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fb.svg b/qortal-ui-core/emoji/svg/1f468-1f3fb.svg new file mode 100644 index 00000000..1ab8ea02 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f33e.svg new file mode 100644 index 00000000..a75bacf4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f373.svg new file mode 100644 index 00000000..1ec6e028 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f37c.svg new file mode 100644 index 00000000..5d702994 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f384.svg new file mode 100644 index 00000000..5adcdf4e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f393.svg new file mode 100644 index 00000000..960ff27c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f3a4.svg new file mode 100644 index 00000000..e1137949 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f3a8.svg new file mode 100644 index 00000000..cce25b79 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f3eb.svg new file mode 100644 index 00000000..fb6f4f4a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f3ed.svg new file mode 100644 index 00000000..22ad9bfe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f4bb.svg new file mode 100644 index 00000000..038a4fc4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f4bc.svg new file mode 100644 index 00000000..c07947ba --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f527.svg new file mode 100644 index 00000000..d0bf573e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f52c.svg new file mode 100644 index 00000000..0cbcdf1f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f680.svg new file mode 100644 index 00000000..b1567a68 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f692.svg new file mode 100644 index 00000000..ae762719 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f91d-200d-1f468-1f3fb.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f91d-200d-1f468-1f3fb.svg new file mode 100644 index 00000000..2c042889 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f91d-200d-1f468-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f91d-200d-1f468-1f3fd.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f91d-200d-1f468-1f3fd.svg new file mode 100644 index 00000000..461f95d0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f91d-200d-1f468-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f91d-200d-1f468-1f3fe.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f91d-200d-1f468-1f3fe.svg new file mode 100644 index 00000000..50adc8b7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f91d-200d-1f468-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f91d-200d-1f468-1f3ff.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f91d-200d-1f468-1f3ff.svg new file mode 100644 index 00000000..fb82cc52 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f91d-200d-1f468-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9af.svg new file mode 100644 index 00000000..77eb1728 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9b0.svg new file mode 100644 index 00000000..9582c89a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9b1.svg new file mode 100644 index 00000000..bb09af97 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9b2.svg new file mode 100644 index 00000000..59308642 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9b3.svg new file mode 100644 index 00000000..f4e0f36a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9bc.svg new file mode 100644 index 00000000..08bc53e6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9bd.svg new file mode 100644 index 00000000..6fbe0659 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-2695-fe0f.svg new file mode 100644 index 00000000..e2f3fc6d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-2696-fe0f.svg new file mode 100644 index 00000000..214293e8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-2708-fe0f.svg new file mode 100644 index 00000000..0010ed13 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fc.svg b/qortal-ui-core/emoji/svg/1f468-1f3fc.svg new file mode 100644 index 00000000..658aeabe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f33e.svg new file mode 100644 index 00000000..20b878f5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f373.svg new file mode 100644 index 00000000..137e7603 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f37c.svg new file mode 100644 index 00000000..46f2ea1a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f384.svg new file mode 100644 index 00000000..0a56a8b1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f393.svg new file mode 100644 index 00000000..2383bc67 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f3a4.svg new file mode 100644 index 00000000..69b4dbc2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f3a8.svg new file mode 100644 index 00000000..115850f9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f3eb.svg new file mode 100644 index 00000000..5ee09e05 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f3ed.svg new file mode 100644 index 00000000..c78c5b79 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f4bb.svg new file mode 100644 index 00000000..e87322a8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f4bc.svg new file mode 100644 index 00000000..0aa43d9d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f527.svg new file mode 100644 index 00000000..a21d33da --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f52c.svg new file mode 100644 index 00000000..bb745edb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f680.svg new file mode 100644 index 00000000..d6daa5d0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f692.svg new file mode 100644 index 00000000..42308ee3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f91d-200d-1f468-1f3fb.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f91d-200d-1f468-1f3fb.svg new file mode 100644 index 00000000..c74eea4c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f91d-200d-1f468-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f91d-200d-1f468-1f3fc.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f91d-200d-1f468-1f3fc.svg new file mode 100644 index 00000000..020e414a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f91d-200d-1f468-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f91d-200d-1f468-1f3fe.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f91d-200d-1f468-1f3fe.svg new file mode 100644 index 00000000..f9acaa59 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f91d-200d-1f468-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f91d-200d-1f468-1f3ff.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f91d-200d-1f468-1f3ff.svg new file mode 100644 index 00000000..6ebf806e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f91d-200d-1f468-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9af.svg new file mode 100644 index 00000000..f28f13f2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9b0.svg new file mode 100644 index 00000000..a1d16367 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9b1.svg new file mode 100644 index 00000000..a26b39bf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9b2.svg new file mode 100644 index 00000000..116085d2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9b3.svg new file mode 100644 index 00000000..06cedb47 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9bc.svg new file mode 100644 index 00000000..be45b679 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9bd.svg new file mode 100644 index 00000000..64bf6233 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-2695-fe0f.svg new file mode 100644 index 00000000..a1f496cc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-2696-fe0f.svg new file mode 100644 index 00000000..8ebc442a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-2708-fe0f.svg new file mode 100644 index 00000000..dc52d245 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fd.svg b/qortal-ui-core/emoji/svg/1f468-1f3fd.svg new file mode 100644 index 00000000..8c2abb3d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f33e.svg new file mode 100644 index 00000000..48a941a6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f373.svg new file mode 100644 index 00000000..1f059617 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f37c.svg new file mode 100644 index 00000000..ea5681fe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f384.svg new file mode 100644 index 00000000..16b3b33e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f393.svg new file mode 100644 index 00000000..0f2e9268 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f3a4.svg new file mode 100644 index 00000000..3dcccacc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f3a8.svg new file mode 100644 index 00000000..b6f69c8a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f3eb.svg new file mode 100644 index 00000000..2487cb6d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f3ed.svg new file mode 100644 index 00000000..8c20bdf2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f4bb.svg new file mode 100644 index 00000000..705591d2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f4bc.svg new file mode 100644 index 00000000..65b919ad --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f527.svg new file mode 100644 index 00000000..6c40125b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f52c.svg new file mode 100644 index 00000000..7a84c52f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f680.svg new file mode 100644 index 00000000..c0eefc66 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f692.svg new file mode 100644 index 00000000..6fc176c8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f91d-200d-1f468-1f3fb.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f91d-200d-1f468-1f3fb.svg new file mode 100644 index 00000000..6f6162c3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f91d-200d-1f468-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f91d-200d-1f468-1f3fc.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f91d-200d-1f468-1f3fc.svg new file mode 100644 index 00000000..92f56c75 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f91d-200d-1f468-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f91d-200d-1f468-1f3fd.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f91d-200d-1f468-1f3fd.svg new file mode 100644 index 00000000..064e44b4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f91d-200d-1f468-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f91d-200d-1f468-1f3ff.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f91d-200d-1f468-1f3ff.svg new file mode 100644 index 00000000..58212d4f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f91d-200d-1f468-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9af.svg new file mode 100644 index 00000000..56845736 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9b0.svg new file mode 100644 index 00000000..7d77bfd4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9b1.svg new file mode 100644 index 00000000..bc9c28d1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9b2.svg new file mode 100644 index 00000000..4d4a8625 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9b3.svg new file mode 100644 index 00000000..28b93791 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9bc.svg new file mode 100644 index 00000000..0e2b8bed --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9bd.svg new file mode 100644 index 00000000..65503708 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-2695-fe0f.svg new file mode 100644 index 00000000..9d7e1137 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-2696-fe0f.svg new file mode 100644 index 00000000..28127409 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-2708-fe0f.svg new file mode 100644 index 00000000..66c892e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3fe.svg b/qortal-ui-core/emoji/svg/1f468-1f3fe.svg new file mode 100644 index 00000000..c09f4392 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f33e.svg new file mode 100644 index 00000000..11210bf5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f373.svg new file mode 100644 index 00000000..2ebe6f84 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f37c.svg new file mode 100644 index 00000000..330c92ef --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f384.svg new file mode 100644 index 00000000..4923cbf4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f393.svg new file mode 100644 index 00000000..e746f4c5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f3a4.svg new file mode 100644 index 00000000..505ac44f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f3a8.svg new file mode 100644 index 00000000..e0c3b4dc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f3eb.svg new file mode 100644 index 00000000..658ef824 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f3ed.svg new file mode 100644 index 00000000..8635665e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f4bb.svg new file mode 100644 index 00000000..bd637ca0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f4bc.svg new file mode 100644 index 00000000..b3596ae1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f527.svg new file mode 100644 index 00000000..fac206ff --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f52c.svg new file mode 100644 index 00000000..b7367ad1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f680.svg new file mode 100644 index 00000000..54a4f62f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f692.svg new file mode 100644 index 00000000..1e0472d5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f91d-200d-1f468-1f3fb.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f91d-200d-1f468-1f3fb.svg new file mode 100644 index 00000000..e83c662e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f91d-200d-1f468-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f91d-200d-1f468-1f3fc.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f91d-200d-1f468-1f3fc.svg new file mode 100644 index 00000000..bee8dd51 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f91d-200d-1f468-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f91d-200d-1f468-1f3fd.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f91d-200d-1f468-1f3fd.svg new file mode 100644 index 00000000..66591e14 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f91d-200d-1f468-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f91d-200d-1f468-1f3fe.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f91d-200d-1f468-1f3fe.svg new file mode 100644 index 00000000..33856b49 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f91d-200d-1f468-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9af.svg new file mode 100644 index 00000000..513caf1b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9b0.svg new file mode 100644 index 00000000..0a5b536b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9b1.svg new file mode 100644 index 00000000..66c33aea --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9b2.svg new file mode 100644 index 00000000..7ab86cd7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9b3.svg new file mode 100644 index 00000000..370b6733 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9bc.svg new file mode 100644 index 00000000..99ad94b9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9bd.svg new file mode 100644 index 00000000..4f6eba07 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-2695-fe0f.svg new file mode 100644 index 00000000..aa3fd0ad --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-2696-fe0f.svg new file mode 100644 index 00000000..1aaa0a1e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-2708-fe0f.svg new file mode 100644 index 00000000..dce186ed --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-1f3ff.svg b/qortal-ui-core/emoji/svg/1f468-1f3ff.svg new file mode 100644 index 00000000..96c5b170 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f33e.svg new file mode 100644 index 00000000..0fcee4fa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f373.svg new file mode 100644 index 00000000..9344e17d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f37c.svg new file mode 100644 index 00000000..971908e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f384.svg new file mode 100644 index 00000000..9c61da6c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f393.svg new file mode 100644 index 00000000..ab35970f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f3a4.svg new file mode 100644 index 00000000..0462a6b2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f3a8.svg new file mode 100644 index 00000000..eb21722a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f3eb.svg new file mode 100644 index 00000000..95963cfa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f3ed.svg new file mode 100644 index 00000000..6fc1eae4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f466-200d-1f466.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f466-200d-1f466.svg new file mode 100644 index 00000000..89b3ad3d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f466-200d-1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f466.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f466.svg new file mode 100644 index 00000000..26c8de97 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f467-200d-1f466.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f467-200d-1f466.svg new file mode 100644 index 00000000..a2008f1c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f467-200d-1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f467-200d-1f467.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f467-200d-1f467.svg new file mode 100644 index 00000000..acb7b7df --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f467-200d-1f467.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f467.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f467.svg new file mode 100644 index 00000000..4cda7514 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f467.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f468-200d-1f466-200d-1f466.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f468-200d-1f466-200d-1f466.svg new file mode 100644 index 00000000..efa5db97 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f468-200d-1f466-200d-1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f468-200d-1f466.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f468-200d-1f466.svg new file mode 100644 index 00000000..d3a5877d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f468-200d-1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f468-200d-1f467-200d-1f466.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f468-200d-1f467-200d-1f466.svg new file mode 100644 index 00000000..4d12c1a3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f468-200d-1f467-200d-1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f468-200d-1f467-200d-1f467.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f468-200d-1f467-200d-1f467.svg new file mode 100644 index 00000000..a694e429 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f468-200d-1f467-200d-1f467.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f468-200d-1f467.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f468-200d-1f467.svg new file mode 100644 index 00000000..48c4e731 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f468-200d-1f467.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f469-200d-1f466-200d-1f466.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f469-200d-1f466-200d-1f466.svg new file mode 100644 index 00000000..9c3f3da3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f469-200d-1f466-200d-1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f469-200d-1f466.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f469-200d-1f466.svg new file mode 100644 index 00000000..8f5fad9f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f469-200d-1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f469-200d-1f467-200d-1f466.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f469-200d-1f467-200d-1f466.svg new file mode 100644 index 00000000..88568076 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f469-200d-1f467-200d-1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f469-200d-1f467-200d-1f467.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f469-200d-1f467-200d-1f467.svg new file mode 100644 index 00000000..58111c6b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f469-200d-1f467-200d-1f467.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f469-200d-1f467.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f469-200d-1f467.svg new file mode 100644 index 00000000..22a662f0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f469-200d-1f467.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f4bb.svg new file mode 100644 index 00000000..e37b0499 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f4bc.svg new file mode 100644 index 00000000..a3f56fea --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f527.svg new file mode 100644 index 00000000..6bc505eb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f52c.svg new file mode 100644 index 00000000..02a9e121 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f680.svg new file mode 100644 index 00000000..dd97a209 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f692.svg new file mode 100644 index 00000000..cfdef73d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f9af.svg new file mode 100644 index 00000000..321bc0d9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f9b0.svg new file mode 100644 index 00000000..1b633b3c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f9b1.svg new file mode 100644 index 00000000..6ac57434 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f9b2.svg new file mode 100644 index 00000000..ea49779a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f9b3.svg new file mode 100644 index 00000000..a14e3fd4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f9bc.svg new file mode 100644 index 00000000..7d37c87f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f468-200d-1f9bd.svg new file mode 100644 index 00000000..b8d2858f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-200d-2695-fe0f.svg new file mode 100644 index 00000000..627461f9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-200d-2696-fe0f.svg new file mode 100644 index 00000000..759d3078 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f468-200d-2708-fe0f.svg new file mode 100644 index 00000000..b5ed35af --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-2764-fe0f-200d-1f468.svg b/qortal-ui-core/emoji/svg/1f468-200d-2764-fe0f-200d-1f468.svg new file mode 100644 index 00000000..cace24fc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-2764-fe0f-200d-1f468.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468-200d-2764-fe0f-200d-1f48b-200d-1f468.svg b/qortal-ui-core/emoji/svg/1f468-200d-2764-fe0f-200d-1f48b-200d-1f468.svg new file mode 100644 index 00000000..41dbd968 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468-200d-2764-fe0f-200d-1f48b-200d-1f468.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f468.svg b/qortal-ui-core/emoji/svg/1f468.svg new file mode 100644 index 00000000..98b73b58 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f468.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f33e.svg new file mode 100644 index 00000000..5f246340 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f373.svg new file mode 100644 index 00000000..6ed4b51f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f37c.svg new file mode 100644 index 00000000..311bda9f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f384.svg new file mode 100644 index 00000000..0227456d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f393.svg new file mode 100644 index 00000000..ed106adc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f3a4.svg new file mode 100644 index 00000000..e0403c5d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f3a8.svg new file mode 100644 index 00000000..0caf0716 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f3eb.svg new file mode 100644 index 00000000..819bf36f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f3ed.svg new file mode 100644 index 00000000..0914b045 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f4bb.svg new file mode 100644 index 00000000..3ab61d8f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f4bc.svg new file mode 100644 index 00000000..ebd3e39d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f527.svg new file mode 100644 index 00000000..dd5eeb48 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f52c.svg new file mode 100644 index 00000000..a2a080b0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f680.svg new file mode 100644 index 00000000..b4e5a081 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f692.svg new file mode 100644 index 00000000..98bf8354 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f468-1f3fc.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f468-1f3fc.svg new file mode 100644 index 00000000..688ddedc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f468-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f468-1f3fd.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f468-1f3fd.svg new file mode 100644 index 00000000..a33c2de5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f468-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f468-1f3fe.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f468-1f3fe.svg new file mode 100644 index 00000000..3686c186 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f468-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f468-1f3ff.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f468-1f3ff.svg new file mode 100644 index 00000000..1180b222 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f468-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f469-1f3fc.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f469-1f3fc.svg new file mode 100644 index 00000000..6bab40c3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f469-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f469-1f3fd.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f469-1f3fd.svg new file mode 100644 index 00000000..a6584189 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f469-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f469-1f3fe.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f469-1f3fe.svg new file mode 100644 index 00000000..85afc927 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f469-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f469-1f3ff.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f469-1f3ff.svg new file mode 100644 index 00000000..43ce3ec2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f91d-200d-1f469-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9af.svg new file mode 100644 index 00000000..3c581218 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9b0.svg new file mode 100644 index 00000000..94c85fd1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9b1.svg new file mode 100644 index 00000000..a1a2ba77 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9b2.svg new file mode 100644 index 00000000..258c5149 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9b3.svg new file mode 100644 index 00000000..98fbde9f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9bc.svg new file mode 100644 index 00000000..2f240ea5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9bd.svg new file mode 100644 index 00000000..68f49e07 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-2695-fe0f.svg new file mode 100644 index 00000000..e22a0bdf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-2696-fe0f.svg new file mode 100644 index 00000000..574cad0f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-2708-fe0f.svg new file mode 100644 index 00000000..5cd08b32 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fb.svg b/qortal-ui-core/emoji/svg/1f469-1f3fb.svg new file mode 100644 index 00000000..b44725bb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f33e.svg new file mode 100644 index 00000000..7a30a982 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f373.svg new file mode 100644 index 00000000..4ef7a7ff --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f37c.svg new file mode 100644 index 00000000..cfae280e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f384.svg new file mode 100644 index 00000000..5887d75e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f393.svg new file mode 100644 index 00000000..d045ed82 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f3a4.svg new file mode 100644 index 00000000..210cd6c4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f3a8.svg new file mode 100644 index 00000000..7d83bc06 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f3eb.svg new file mode 100644 index 00000000..2ddfeb1e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f3ed.svg new file mode 100644 index 00000000..ab815ee2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f4bb.svg new file mode 100644 index 00000000..ab3600e6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f4bc.svg new file mode 100644 index 00000000..b117aa66 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f527.svg new file mode 100644 index 00000000..5f2b878a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f52c.svg new file mode 100644 index 00000000..dfb93eec --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f680.svg new file mode 100644 index 00000000..39635e27 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f692.svg new file mode 100644 index 00000000..676cf60a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f468-1f3fb.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f468-1f3fb.svg new file mode 100644 index 00000000..9c9e08c1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f468-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f468-1f3fd.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f468-1f3fd.svg new file mode 100644 index 00000000..a4220c37 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f468-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f468-1f3fe.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f468-1f3fe.svg new file mode 100644 index 00000000..bc5805af --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f468-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f468-1f3ff.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f468-1f3ff.svg new file mode 100644 index 00000000..d96d1d93 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f468-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f469-1f3fb.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f469-1f3fb.svg new file mode 100644 index 00000000..cc7111d1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f469-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f469-1f3fd.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f469-1f3fd.svg new file mode 100644 index 00000000..6c9f81a9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f469-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f469-1f3fe.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f469-1f3fe.svg new file mode 100644 index 00000000..e00c758e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f469-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f469-1f3ff.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f469-1f3ff.svg new file mode 100644 index 00000000..61833c8e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f91d-200d-1f469-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9af.svg new file mode 100644 index 00000000..ad8806b3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9b0.svg new file mode 100644 index 00000000..179dedb8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9b1.svg new file mode 100644 index 00000000..4594647a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9b2.svg new file mode 100644 index 00000000..8da4ee52 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9b3.svg new file mode 100644 index 00000000..99ffa0d0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9bc.svg new file mode 100644 index 00000000..ffea3a28 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9bd.svg new file mode 100644 index 00000000..39843afd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-2695-fe0f.svg new file mode 100644 index 00000000..0bb189f4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-2696-fe0f.svg new file mode 100644 index 00000000..44cbc897 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-2708-fe0f.svg new file mode 100644 index 00000000..3fc9536f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fc.svg b/qortal-ui-core/emoji/svg/1f469-1f3fc.svg new file mode 100644 index 00000000..7c3ba633 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f33e.svg new file mode 100644 index 00000000..841df90a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f373.svg new file mode 100644 index 00000000..c76e15f1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f37c.svg new file mode 100644 index 00000000..8e1e408c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f384.svg new file mode 100644 index 00000000..3e1853d2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f393.svg new file mode 100644 index 00000000..eead9a2f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f3a4.svg new file mode 100644 index 00000000..5e589ad9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f3a8.svg new file mode 100644 index 00000000..e97e8d9f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f3eb.svg new file mode 100644 index 00000000..2d447221 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f3ed.svg new file mode 100644 index 00000000..dd6e627f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f4bb.svg new file mode 100644 index 00000000..c036ad1e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f4bc.svg new file mode 100644 index 00000000..e89a5b11 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f527.svg new file mode 100644 index 00000000..ba2b753f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f52c.svg new file mode 100644 index 00000000..bb686deb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f680.svg new file mode 100644 index 00000000..21ff7a7a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f692.svg new file mode 100644 index 00000000..76f000c7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f468-1f3fb.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f468-1f3fb.svg new file mode 100644 index 00000000..973ae2ee --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f468-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f468-1f3fc.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f468-1f3fc.svg new file mode 100644 index 00000000..6c651ec2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f468-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f468-1f3fe.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f468-1f3fe.svg new file mode 100644 index 00000000..743c1642 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f468-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f468-1f3ff.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f468-1f3ff.svg new file mode 100644 index 00000000..d6444e8c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f468-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f469-1f3fb.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f469-1f3fb.svg new file mode 100644 index 00000000..ce6b91c6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f469-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f469-1f3fc.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f469-1f3fc.svg new file mode 100644 index 00000000..8fd0c0be --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f469-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f469-1f3fe.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f469-1f3fe.svg new file mode 100644 index 00000000..c26f6697 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f469-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f469-1f3ff.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f469-1f3ff.svg new file mode 100644 index 00000000..e2176e4d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f91d-200d-1f469-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9af.svg new file mode 100644 index 00000000..c17b0ed2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9b0.svg new file mode 100644 index 00000000..7a1df80e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9b1.svg new file mode 100644 index 00000000..5434a54a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9b2.svg new file mode 100644 index 00000000..7881eb73 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9b3.svg new file mode 100644 index 00000000..25ff5151 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9bc.svg new file mode 100644 index 00000000..79834531 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9bd.svg new file mode 100644 index 00000000..c128386d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-2695-fe0f.svg new file mode 100644 index 00000000..d0b51ac6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-2696-fe0f.svg new file mode 100644 index 00000000..8a1993e3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-2708-fe0f.svg new file mode 100644 index 00000000..e1fc6c3e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fd.svg b/qortal-ui-core/emoji/svg/1f469-1f3fd.svg new file mode 100644 index 00000000..5dba957a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f33e.svg new file mode 100644 index 00000000..7570c376 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f373.svg new file mode 100644 index 00000000..9e7522ea --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f37c.svg new file mode 100644 index 00000000..b910a877 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f384.svg new file mode 100644 index 00000000..6d94d270 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f393.svg new file mode 100644 index 00000000..4d4967b0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f3a4.svg new file mode 100644 index 00000000..de1f4f08 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f3a8.svg new file mode 100644 index 00000000..5a08cb63 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f3eb.svg new file mode 100644 index 00000000..5908aeba --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f3ed.svg new file mode 100644 index 00000000..626a1f04 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f4bb.svg new file mode 100644 index 00000000..86d044ec --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f4bc.svg new file mode 100644 index 00000000..f67b33b2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f527.svg new file mode 100644 index 00000000..a3a47a08 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f52c.svg new file mode 100644 index 00000000..984578cb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f680.svg new file mode 100644 index 00000000..882cf485 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f692.svg new file mode 100644 index 00000000..5b666b0d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f468-1f3fb.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f468-1f3fb.svg new file mode 100644 index 00000000..6a6824ec --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f468-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f468-1f3fc.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f468-1f3fc.svg new file mode 100644 index 00000000..59e3f287 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f468-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f468-1f3fd.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f468-1f3fd.svg new file mode 100644 index 00000000..2550de8b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f468-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f468-1f3ff.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f468-1f3ff.svg new file mode 100644 index 00000000..c43d096a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f468-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f469-1f3fb.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f469-1f3fb.svg new file mode 100644 index 00000000..ddce0b44 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f469-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f469-1f3fc.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f469-1f3fc.svg new file mode 100644 index 00000000..7a12304c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f469-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f469-1f3fd.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f469-1f3fd.svg new file mode 100644 index 00000000..09b01755 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f469-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f469-1f3ff.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f469-1f3ff.svg new file mode 100644 index 00000000..dd4f20eb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f91d-200d-1f469-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9af.svg new file mode 100644 index 00000000..3b4b5395 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9b0.svg new file mode 100644 index 00000000..a10b4cb4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9b1.svg new file mode 100644 index 00000000..8b866fff --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9b2.svg new file mode 100644 index 00000000..3e7738c7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9b3.svg new file mode 100644 index 00000000..50ad4ea2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9bc.svg new file mode 100644 index 00000000..ba5ca054 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9bd.svg new file mode 100644 index 00000000..f481961b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-2695-fe0f.svg new file mode 100644 index 00000000..a6b5ffc4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-2696-fe0f.svg new file mode 100644 index 00000000..06110b76 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-2708-fe0f.svg new file mode 100644 index 00000000..74c44cd7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3fe.svg b/qortal-ui-core/emoji/svg/1f469-1f3fe.svg new file mode 100644 index 00000000..4539d0ee --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f33e.svg new file mode 100644 index 00000000..2d1476ec --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f373.svg new file mode 100644 index 00000000..c9cafcfc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f37c.svg new file mode 100644 index 00000000..69855666 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f384.svg new file mode 100644 index 00000000..2178a33c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f393.svg new file mode 100644 index 00000000..93456597 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f3a4.svg new file mode 100644 index 00000000..c182d216 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f3a8.svg new file mode 100644 index 00000000..fc1e99ea --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f3eb.svg new file mode 100644 index 00000000..c92782c7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f3ed.svg new file mode 100644 index 00000000..599992fe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f4bb.svg new file mode 100644 index 00000000..e73241a2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f4bc.svg new file mode 100644 index 00000000..e283c008 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f527.svg new file mode 100644 index 00000000..65196942 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f52c.svg new file mode 100644 index 00000000..cdf068ba --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f680.svg new file mode 100644 index 00000000..636a9fe2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f692.svg new file mode 100644 index 00000000..68589337 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f468-1f3fb.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f468-1f3fb.svg new file mode 100644 index 00000000..8932b8cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f468-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f468-1f3fc.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f468-1f3fc.svg new file mode 100644 index 00000000..cf102b7c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f468-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f468-1f3fd.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f468-1f3fd.svg new file mode 100644 index 00000000..7e8c4130 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f468-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f468-1f3fe.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f468-1f3fe.svg new file mode 100644 index 00000000..bcd04bf7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f468-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f469-1f3fb.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f469-1f3fb.svg new file mode 100644 index 00000000..1128ecfa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f469-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f469-1f3fc.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f469-1f3fc.svg new file mode 100644 index 00000000..3200168e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f469-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f469-1f3fd.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f469-1f3fd.svg new file mode 100644 index 00000000..9212f3c4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f469-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f469-1f3fe.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f469-1f3fe.svg new file mode 100644 index 00000000..ff7c9011 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f91d-200d-1f469-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9af.svg new file mode 100644 index 00000000..aafa3bce --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9b0.svg new file mode 100644 index 00000000..1ae85c6e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9b1.svg new file mode 100644 index 00000000..c2844211 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9b2.svg new file mode 100644 index 00000000..f490be8b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9b3.svg new file mode 100644 index 00000000..cf3e39d6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9bc.svg new file mode 100644 index 00000000..39f0c6a7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9bd.svg new file mode 100644 index 00000000..4eea4dc7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-2695-fe0f.svg new file mode 100644 index 00000000..7db92127 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-2696-fe0f.svg new file mode 100644 index 00000000..4fe0541f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-2708-fe0f.svg new file mode 100644 index 00000000..1f4a7b6d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-1f3ff.svg b/qortal-ui-core/emoji/svg/1f469-1f3ff.svg new file mode 100644 index 00000000..ac43b9ef --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f33e.svg new file mode 100644 index 00000000..c8974b5e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f373.svg new file mode 100644 index 00000000..962deccd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f37c.svg new file mode 100644 index 00000000..c13cc537 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f384.svg new file mode 100644 index 00000000..6cabe582 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f393.svg new file mode 100644 index 00000000..47ad3e7c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f3a4.svg new file mode 100644 index 00000000..8aa5e4ce --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f3a8.svg new file mode 100644 index 00000000..6d4807ee --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f3eb.svg new file mode 100644 index 00000000..9a3e5445 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f3ed.svg new file mode 100644 index 00000000..064bfd4d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f466-200d-1f466.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f466-200d-1f466.svg new file mode 100644 index 00000000..a10b0190 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f466-200d-1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f466.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f466.svg new file mode 100644 index 00000000..6ae66b64 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f467-200d-1f466.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f467-200d-1f466.svg new file mode 100644 index 00000000..710fb8e5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f467-200d-1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f467-200d-1f467.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f467-200d-1f467.svg new file mode 100644 index 00000000..88da46ee --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f467-200d-1f467.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f467.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f467.svg new file mode 100644 index 00000000..43e4333f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f467.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f469-200d-1f466-200d-1f466.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f469-200d-1f466-200d-1f466.svg new file mode 100644 index 00000000..8915200c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f469-200d-1f466-200d-1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f469-200d-1f466.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f469-200d-1f466.svg new file mode 100644 index 00000000..8cd8bad8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f469-200d-1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f469-200d-1f467-200d-1f466.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f469-200d-1f467-200d-1f466.svg new file mode 100644 index 00000000..976e8481 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f469-200d-1f467-200d-1f466.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f469-200d-1f467-200d-1f467.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f469-200d-1f467-200d-1f467.svg new file mode 100644 index 00000000..96e0434e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f469-200d-1f467-200d-1f467.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f469-200d-1f467.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f469-200d-1f467.svg new file mode 100644 index 00000000..9201b66c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f469-200d-1f467.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f4bb.svg new file mode 100644 index 00000000..c69729f3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f4bc.svg new file mode 100644 index 00000000..9f41d662 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f527.svg new file mode 100644 index 00000000..24b16096 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f52c.svg new file mode 100644 index 00000000..9597ebca --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f680.svg new file mode 100644 index 00000000..c4fdde46 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f692.svg new file mode 100644 index 00000000..cbde12ec --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f9af.svg new file mode 100644 index 00000000..fe555873 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f9b0.svg new file mode 100644 index 00000000..68367e8f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f9b1.svg new file mode 100644 index 00000000..62cc26b1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f9b2.svg new file mode 100644 index 00000000..3fd10040 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f9b3.svg new file mode 100644 index 00000000..1ce720e8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f9bc.svg new file mode 100644 index 00000000..6706ec81 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f469-200d-1f9bd.svg new file mode 100644 index 00000000..1d6b02cf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-200d-2695-fe0f.svg new file mode 100644 index 00000000..efe29092 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-200d-2696-fe0f.svg new file mode 100644 index 00000000..e8b489a7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f469-200d-2708-fe0f.svg new file mode 100644 index 00000000..953b06fd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-2764-fe0f-200d-1f468.svg b/qortal-ui-core/emoji/svg/1f469-200d-2764-fe0f-200d-1f468.svg new file mode 100644 index 00000000..ece280dc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-2764-fe0f-200d-1f468.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-2764-fe0f-200d-1f469.svg b/qortal-ui-core/emoji/svg/1f469-200d-2764-fe0f-200d-1f469.svg new file mode 100644 index 00000000..62abb03e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-2764-fe0f-200d-1f469.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-2764-fe0f-200d-1f48b-200d-1f468.svg b/qortal-ui-core/emoji/svg/1f469-200d-2764-fe0f-200d-1f48b-200d-1f468.svg new file mode 100644 index 00000000..8248ed60 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-2764-fe0f-200d-1f48b-200d-1f468.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469-200d-2764-fe0f-200d-1f48b-200d-1f469.svg b/qortal-ui-core/emoji/svg/1f469-200d-2764-fe0f-200d-1f48b-200d-1f469.svg new file mode 100644 index 00000000..e46dfcae --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469-200d-2764-fe0f-200d-1f48b-200d-1f469.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f469.svg b/qortal-ui-core/emoji/svg/1f469.svg new file mode 100644 index 00000000..41785677 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f469.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46a.svg b/qortal-ui-core/emoji/svg/1f46a.svg new file mode 100644 index 00000000..945b1a84 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46b-1f3fb.svg b/qortal-ui-core/emoji/svg/1f46b-1f3fb.svg new file mode 100644 index 00000000..2cc10f95 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46b-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46b-1f3fc.svg b/qortal-ui-core/emoji/svg/1f46b-1f3fc.svg new file mode 100644 index 00000000..894d7220 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46b-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46b-1f3fd.svg b/qortal-ui-core/emoji/svg/1f46b-1f3fd.svg new file mode 100644 index 00000000..4496ef51 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46b-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46b-1f3fe.svg b/qortal-ui-core/emoji/svg/1f46b-1f3fe.svg new file mode 100644 index 00000000..25cbd995 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46b-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46b-1f3ff.svg b/qortal-ui-core/emoji/svg/1f46b-1f3ff.svg new file mode 100644 index 00000000..f4be2772 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46b-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46b.svg b/qortal-ui-core/emoji/svg/1f46b.svg new file mode 100644 index 00000000..59ca8c08 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46c-1f3fb.svg b/qortal-ui-core/emoji/svg/1f46c-1f3fb.svg new file mode 100644 index 00000000..2050ca35 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46c-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46c-1f3fc.svg b/qortal-ui-core/emoji/svg/1f46c-1f3fc.svg new file mode 100644 index 00000000..05701083 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46c-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46c-1f3fd.svg b/qortal-ui-core/emoji/svg/1f46c-1f3fd.svg new file mode 100644 index 00000000..b00c6be0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46c-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46c-1f3fe.svg b/qortal-ui-core/emoji/svg/1f46c-1f3fe.svg new file mode 100644 index 00000000..58302a87 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46c-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46c-1f3ff.svg b/qortal-ui-core/emoji/svg/1f46c-1f3ff.svg new file mode 100644 index 00000000..c7dddadf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46c-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46c.svg b/qortal-ui-core/emoji/svg/1f46c.svg new file mode 100644 index 00000000..87280c14 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46d-1f3fb.svg b/qortal-ui-core/emoji/svg/1f46d-1f3fb.svg new file mode 100644 index 00000000..e3e1a4a5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46d-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46d-1f3fc.svg b/qortal-ui-core/emoji/svg/1f46d-1f3fc.svg new file mode 100644 index 00000000..782875a0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46d-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46d-1f3fd.svg b/qortal-ui-core/emoji/svg/1f46d-1f3fd.svg new file mode 100644 index 00000000..f69bbc06 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46d-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46d-1f3fe.svg b/qortal-ui-core/emoji/svg/1f46d-1f3fe.svg new file mode 100644 index 00000000..f14ac947 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46d-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46d-1f3ff.svg b/qortal-ui-core/emoji/svg/1f46d-1f3ff.svg new file mode 100644 index 00000000..d8e8432d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46d-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46d.svg b/qortal-ui-core/emoji/svg/1f46d.svg new file mode 100644 index 00000000..91a55c38 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f46e-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..3b9cc978 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f46e-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..25c4c81c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-1f3fb.svg b/qortal-ui-core/emoji/svg/1f46e-1f3fb.svg new file mode 100644 index 00000000..a7041d07 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f46e-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..e3f37cb4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f46e-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..b2c47839 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-1f3fc.svg b/qortal-ui-core/emoji/svg/1f46e-1f3fc.svg new file mode 100644 index 00000000..18883fa7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f46e-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..77b19743 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f46e-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..7e5e4b5d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-1f3fd.svg b/qortal-ui-core/emoji/svg/1f46e-1f3fd.svg new file mode 100644 index 00000000..333abdab --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f46e-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..d40f400c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f46e-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..e817083a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-1f3fe.svg b/qortal-ui-core/emoji/svg/1f46e-1f3fe.svg new file mode 100644 index 00000000..cfd4fcda --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f46e-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..43b98a0e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f46e-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..440cb510 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-1f3ff.svg b/qortal-ui-core/emoji/svg/1f46e-1f3ff.svg new file mode 100644 index 00000000..339c56b9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f46e-200d-2640-fe0f.svg new file mode 100644 index 00000000..6b0fac22 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f46e-200d-2642-fe0f.svg new file mode 100644 index 00000000..2974c984 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46e.svg b/qortal-ui-core/emoji/svg/1f46e.svg new file mode 100644 index 00000000..feaeb0b9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46f-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f46f-200d-2640-fe0f.svg new file mode 100644 index 00000000..7c7fe7df --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46f-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46f-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f46f-200d-2642-fe0f.svg new file mode 100644 index 00000000..13717aac --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46f-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f46f.svg b/qortal-ui-core/emoji/svg/1f46f.svg new file mode 100644 index 00000000..062ff266 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f46f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f470-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..6e0b0fe3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f470-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..84c773ab --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-1f3fb.svg b/qortal-ui-core/emoji/svg/1f470-1f3fb.svg new file mode 100644 index 00000000..e8c6cd06 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f470-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..ee4102b6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f470-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..f894e261 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-1f3fc.svg b/qortal-ui-core/emoji/svg/1f470-1f3fc.svg new file mode 100644 index 00000000..511c7aa8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f470-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..3d7605dc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f470-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..f1b941d1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-1f3fd.svg b/qortal-ui-core/emoji/svg/1f470-1f3fd.svg new file mode 100644 index 00000000..4fc12eb5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f470-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..1e33374c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f470-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..1c8135c9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-1f3fe.svg b/qortal-ui-core/emoji/svg/1f470-1f3fe.svg new file mode 100644 index 00000000..c30f3c09 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f470-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..656a9b71 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f470-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..2c090f1a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-1f3ff.svg b/qortal-ui-core/emoji/svg/1f470-1f3ff.svg new file mode 100644 index 00000000..9e0f2a25 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f470-200d-2640-fe0f.svg new file mode 100644 index 00000000..2fd75bfe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f470-200d-2642-fe0f.svg new file mode 100644 index 00000000..d12c670e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f470.svg b/qortal-ui-core/emoji/svg/1f470.svg new file mode 100644 index 00000000..a41b9b99 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f470.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f471-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..e9427e1d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f471-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..8a5a3299 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-1f3fb.svg b/qortal-ui-core/emoji/svg/1f471-1f3fb.svg new file mode 100644 index 00000000..2bbee729 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f471-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..7c3ba633 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f471-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..8455a9ed --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-1f3fc.svg b/qortal-ui-core/emoji/svg/1f471-1f3fc.svg new file mode 100644 index 00000000..9030253e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f471-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..ae6c4f82 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f471-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..4332b5b1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-1f3fd.svg b/qortal-ui-core/emoji/svg/1f471-1f3fd.svg new file mode 100644 index 00000000..52d178ff --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f471-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..33a7c3a0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f471-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..c8461a98 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-1f3fe.svg b/qortal-ui-core/emoji/svg/1f471-1f3fe.svg new file mode 100644 index 00000000..5fbbad14 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f471-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..7d3745fe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f471-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..f91a87fe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-1f3ff.svg b/qortal-ui-core/emoji/svg/1f471-1f3ff.svg new file mode 100644 index 00000000..323178b9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f471-200d-2640-fe0f.svg new file mode 100644 index 00000000..2fec72cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f471-200d-2642-fe0f.svg new file mode 100644 index 00000000..f73f9f5b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f471.svg b/qortal-ui-core/emoji/svg/1f471.svg new file mode 100644 index 00000000..b524f21e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f471.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f472-1f3fb.svg b/qortal-ui-core/emoji/svg/1f472-1f3fb.svg new file mode 100644 index 00000000..598b23cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f472-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f472-1f3fc.svg b/qortal-ui-core/emoji/svg/1f472-1f3fc.svg new file mode 100644 index 00000000..f57b59f1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f472-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f472-1f3fd.svg b/qortal-ui-core/emoji/svg/1f472-1f3fd.svg new file mode 100644 index 00000000..a4f37c4f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f472-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f472-1f3fe.svg b/qortal-ui-core/emoji/svg/1f472-1f3fe.svg new file mode 100644 index 00000000..83322d69 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f472-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f472-1f3ff.svg b/qortal-ui-core/emoji/svg/1f472-1f3ff.svg new file mode 100644 index 00000000..e1ae612f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f472-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f472.svg b/qortal-ui-core/emoji/svg/1f472.svg new file mode 100644 index 00000000..7ed6bd53 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f472.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f473-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..f93ddcc6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f473-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..bb59f119 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-1f3fb.svg b/qortal-ui-core/emoji/svg/1f473-1f3fb.svg new file mode 100644 index 00000000..060fcd51 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f473-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..be21bc7d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f473-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..3e748c39 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-1f3fc.svg b/qortal-ui-core/emoji/svg/1f473-1f3fc.svg new file mode 100644 index 00000000..3ad2dd13 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f473-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..61590f02 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f473-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..2373c1dc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-1f3fd.svg b/qortal-ui-core/emoji/svg/1f473-1f3fd.svg new file mode 100644 index 00000000..6f11f533 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f473-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..cf5b0692 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f473-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..bc680e6d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-1f3fe.svg b/qortal-ui-core/emoji/svg/1f473-1f3fe.svg new file mode 100644 index 00000000..165a9750 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f473-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..20c6ba1c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f473-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..6f0f3c59 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-1f3ff.svg b/qortal-ui-core/emoji/svg/1f473-1f3ff.svg new file mode 100644 index 00000000..74fc855e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f473-200d-2640-fe0f.svg new file mode 100644 index 00000000..9fe3052c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f473-200d-2642-fe0f.svg new file mode 100644 index 00000000..5ef43d40 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f473.svg b/qortal-ui-core/emoji/svg/1f473.svg new file mode 100644 index 00000000..216ebcc3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f473.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f474-1f3fb.svg b/qortal-ui-core/emoji/svg/1f474-1f3fb.svg new file mode 100644 index 00000000..307f6c9a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f474-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f474-1f3fc.svg b/qortal-ui-core/emoji/svg/1f474-1f3fc.svg new file mode 100644 index 00000000..6b3b908b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f474-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f474-1f3fd.svg b/qortal-ui-core/emoji/svg/1f474-1f3fd.svg new file mode 100644 index 00000000..1ab3c23c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f474-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f474-1f3fe.svg b/qortal-ui-core/emoji/svg/1f474-1f3fe.svg new file mode 100644 index 00000000..2fb9707f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f474-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f474-1f3ff.svg b/qortal-ui-core/emoji/svg/1f474-1f3ff.svg new file mode 100644 index 00000000..e421b117 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f474-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f474.svg b/qortal-ui-core/emoji/svg/1f474.svg new file mode 100644 index 00000000..eecf20c7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f474.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f475-1f3fb.svg b/qortal-ui-core/emoji/svg/1f475-1f3fb.svg new file mode 100644 index 00000000..d55f164c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f475-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f475-1f3fc.svg b/qortal-ui-core/emoji/svg/1f475-1f3fc.svg new file mode 100644 index 00000000..41b7da72 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f475-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f475-1f3fd.svg b/qortal-ui-core/emoji/svg/1f475-1f3fd.svg new file mode 100644 index 00000000..955ae93f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f475-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f475-1f3fe.svg b/qortal-ui-core/emoji/svg/1f475-1f3fe.svg new file mode 100644 index 00000000..adb2c20b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f475-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f475-1f3ff.svg b/qortal-ui-core/emoji/svg/1f475-1f3ff.svg new file mode 100644 index 00000000..98b4bf83 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f475-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f475.svg b/qortal-ui-core/emoji/svg/1f475.svg new file mode 100644 index 00000000..51867613 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f475.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f476-1f3fb.svg b/qortal-ui-core/emoji/svg/1f476-1f3fb.svg new file mode 100644 index 00000000..44510c6a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f476-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f476-1f3fc.svg b/qortal-ui-core/emoji/svg/1f476-1f3fc.svg new file mode 100644 index 00000000..fe37aa3a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f476-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f476-1f3fd.svg b/qortal-ui-core/emoji/svg/1f476-1f3fd.svg new file mode 100644 index 00000000..fe23a4af --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f476-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f476-1f3fe.svg b/qortal-ui-core/emoji/svg/1f476-1f3fe.svg new file mode 100644 index 00000000..492d7408 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f476-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f476-1f3ff.svg b/qortal-ui-core/emoji/svg/1f476-1f3ff.svg new file mode 100644 index 00000000..66853c96 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f476-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f476.svg b/qortal-ui-core/emoji/svg/1f476.svg new file mode 100644 index 00000000..e065d3b4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f476.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f477-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..52408815 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f477-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..bbe5b3aa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-1f3fb.svg b/qortal-ui-core/emoji/svg/1f477-1f3fb.svg new file mode 100644 index 00000000..cfc25654 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f477-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..1f1a29cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f477-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..de967317 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-1f3fc.svg b/qortal-ui-core/emoji/svg/1f477-1f3fc.svg new file mode 100644 index 00000000..e19ba61b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f477-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..59412f2f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f477-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..a7c900da --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-1f3fd.svg b/qortal-ui-core/emoji/svg/1f477-1f3fd.svg new file mode 100644 index 00000000..59ca2e2b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f477-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..8fb9e378 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f477-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..4fa4d68c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-1f3fe.svg b/qortal-ui-core/emoji/svg/1f477-1f3fe.svg new file mode 100644 index 00000000..a090efe5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f477-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..23c567e2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f477-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..a4943218 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-1f3ff.svg b/qortal-ui-core/emoji/svg/1f477-1f3ff.svg new file mode 100644 index 00000000..2838ca15 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f477-200d-2640-fe0f.svg new file mode 100644 index 00000000..ecfd1b82 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f477-200d-2642-fe0f.svg new file mode 100644 index 00000000..d1e6b36d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f477.svg b/qortal-ui-core/emoji/svg/1f477.svg new file mode 100644 index 00000000..5843060c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f477.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f478-1f3fb.svg b/qortal-ui-core/emoji/svg/1f478-1f3fb.svg new file mode 100644 index 00000000..55dac0b1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f478-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f478-1f3fc.svg b/qortal-ui-core/emoji/svg/1f478-1f3fc.svg new file mode 100644 index 00000000..2a4b944e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f478-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f478-1f3fd.svg b/qortal-ui-core/emoji/svg/1f478-1f3fd.svg new file mode 100644 index 00000000..ee321355 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f478-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f478-1f3fe.svg b/qortal-ui-core/emoji/svg/1f478-1f3fe.svg new file mode 100644 index 00000000..33437aab --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f478-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f478-1f3ff.svg b/qortal-ui-core/emoji/svg/1f478-1f3ff.svg new file mode 100644 index 00000000..2bd03cc1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f478-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f478.svg b/qortal-ui-core/emoji/svg/1f478.svg new file mode 100644 index 00000000..9704853c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f478.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f479.svg b/qortal-ui-core/emoji/svg/1f479.svg new file mode 100644 index 00000000..59babb15 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f479.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f47a.svg b/qortal-ui-core/emoji/svg/1f47a.svg new file mode 100644 index 00000000..bb0db744 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f47a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f47b.svg b/qortal-ui-core/emoji/svg/1f47b.svg new file mode 100644 index 00000000..02e70fab --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f47b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f47c-1f3fb.svg b/qortal-ui-core/emoji/svg/1f47c-1f3fb.svg new file mode 100644 index 00000000..7a20bd07 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f47c-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f47c-1f3fc.svg b/qortal-ui-core/emoji/svg/1f47c-1f3fc.svg new file mode 100644 index 00000000..5e63fc02 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f47c-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f47c-1f3fd.svg b/qortal-ui-core/emoji/svg/1f47c-1f3fd.svg new file mode 100644 index 00000000..17ed0f60 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f47c-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f47c-1f3fe.svg b/qortal-ui-core/emoji/svg/1f47c-1f3fe.svg new file mode 100644 index 00000000..208876d8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f47c-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f47c-1f3ff.svg b/qortal-ui-core/emoji/svg/1f47c-1f3ff.svg new file mode 100644 index 00000000..add44627 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f47c-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f47c.svg b/qortal-ui-core/emoji/svg/1f47c.svg new file mode 100644 index 00000000..1233b93a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f47c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f47d.svg b/qortal-ui-core/emoji/svg/1f47d.svg new file mode 100644 index 00000000..f6e98d1c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f47d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f47e.svg b/qortal-ui-core/emoji/svg/1f47e.svg new file mode 100644 index 00000000..cda34441 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f47e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f47f.svg b/qortal-ui-core/emoji/svg/1f47f.svg new file mode 100644 index 00000000..61097f02 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f47f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f480.svg b/qortal-ui-core/emoji/svg/1f480.svg new file mode 100644 index 00000000..a8000b15 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f480.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f481-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..c3f18727 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f481-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..1b649a27 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-1f3fb.svg b/qortal-ui-core/emoji/svg/1f481-1f3fb.svg new file mode 100644 index 00000000..b8c32493 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f481-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..c3e88dcd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f481-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..49c9b730 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-1f3fc.svg b/qortal-ui-core/emoji/svg/1f481-1f3fc.svg new file mode 100644 index 00000000..ec37e7d5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f481-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..8b53b300 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f481-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..bee2e017 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-1f3fd.svg b/qortal-ui-core/emoji/svg/1f481-1f3fd.svg new file mode 100644 index 00000000..793093f4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f481-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..11e4e832 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f481-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..70d2da2c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-1f3fe.svg b/qortal-ui-core/emoji/svg/1f481-1f3fe.svg new file mode 100644 index 00000000..65df7b42 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f481-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..e55c1edd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f481-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..7fcad0d8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-1f3ff.svg b/qortal-ui-core/emoji/svg/1f481-1f3ff.svg new file mode 100644 index 00000000..9d3ea6cf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f481-200d-2640-fe0f.svg new file mode 100644 index 00000000..7a4864fd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f481-200d-2642-fe0f.svg new file mode 100644 index 00000000..1bb54337 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f481.svg b/qortal-ui-core/emoji/svg/1f481.svg new file mode 100644 index 00000000..eeffd85d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f481.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f482-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..99f1919a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f482-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..c15d824f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-1f3fb.svg b/qortal-ui-core/emoji/svg/1f482-1f3fb.svg new file mode 100644 index 00000000..3f7f82f6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f482-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..04f10dd1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f482-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..1e6689e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-1f3fc.svg b/qortal-ui-core/emoji/svg/1f482-1f3fc.svg new file mode 100644 index 00000000..2dc74688 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f482-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..ebddd61b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f482-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..268da548 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-1f3fd.svg b/qortal-ui-core/emoji/svg/1f482-1f3fd.svg new file mode 100644 index 00000000..96779eeb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f482-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..667d9ef9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f482-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..88b6c0f8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-1f3fe.svg b/qortal-ui-core/emoji/svg/1f482-1f3fe.svg new file mode 100644 index 00000000..2493a139 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f482-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..208fa74e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f482-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..831d1986 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-1f3ff.svg b/qortal-ui-core/emoji/svg/1f482-1f3ff.svg new file mode 100644 index 00000000..40b130b5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f482-200d-2640-fe0f.svg new file mode 100644 index 00000000..e8a33883 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f482-200d-2642-fe0f.svg new file mode 100644 index 00000000..e8998c59 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f482.svg b/qortal-ui-core/emoji/svg/1f482.svg new file mode 100644 index 00000000..d809a9f7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f482.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f483-1f3fb.svg b/qortal-ui-core/emoji/svg/1f483-1f3fb.svg new file mode 100644 index 00000000..72c8f2ce --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f483-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f483-1f3fc.svg b/qortal-ui-core/emoji/svg/1f483-1f3fc.svg new file mode 100644 index 00000000..972ac6a5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f483-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f483-1f3fd.svg b/qortal-ui-core/emoji/svg/1f483-1f3fd.svg new file mode 100644 index 00000000..50377b68 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f483-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f483-1f3fe.svg b/qortal-ui-core/emoji/svg/1f483-1f3fe.svg new file mode 100644 index 00000000..e4dde292 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f483-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f483-1f3ff.svg b/qortal-ui-core/emoji/svg/1f483-1f3ff.svg new file mode 100644 index 00000000..ac535068 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f483-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f483.svg b/qortal-ui-core/emoji/svg/1f483.svg new file mode 100644 index 00000000..abc19e5f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f483.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f484.svg b/qortal-ui-core/emoji/svg/1f484.svg new file mode 100644 index 00000000..af7e8616 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f484.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f485-1f3fb.svg b/qortal-ui-core/emoji/svg/1f485-1f3fb.svg new file mode 100644 index 00000000..5cfe6e9d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f485-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f485-1f3fc.svg b/qortal-ui-core/emoji/svg/1f485-1f3fc.svg new file mode 100644 index 00000000..af54b518 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f485-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f485-1f3fd.svg b/qortal-ui-core/emoji/svg/1f485-1f3fd.svg new file mode 100644 index 00000000..e1d99274 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f485-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f485-1f3fe.svg b/qortal-ui-core/emoji/svg/1f485-1f3fe.svg new file mode 100644 index 00000000..18fea631 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f485-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f485-1f3ff.svg b/qortal-ui-core/emoji/svg/1f485-1f3ff.svg new file mode 100644 index 00000000..49176735 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f485-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f485.svg b/qortal-ui-core/emoji/svg/1f485.svg new file mode 100644 index 00000000..2ddba936 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f485.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f486-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..28d27e29 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f486-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..92d7d0b5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-1f3fb.svg b/qortal-ui-core/emoji/svg/1f486-1f3fb.svg new file mode 100644 index 00000000..3e6ec649 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f486-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..dad79ad1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f486-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..4627172b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-1f3fc.svg b/qortal-ui-core/emoji/svg/1f486-1f3fc.svg new file mode 100644 index 00000000..6c9d96ce --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f486-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..407d11b3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f486-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..e30946fe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-1f3fd.svg b/qortal-ui-core/emoji/svg/1f486-1f3fd.svg new file mode 100644 index 00000000..82205d5a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f486-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..defbf61f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f486-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..e7d5b9d8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-1f3fe.svg b/qortal-ui-core/emoji/svg/1f486-1f3fe.svg new file mode 100644 index 00000000..923f580d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f486-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..793967fd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f486-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..36fa5f90 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-1f3ff.svg b/qortal-ui-core/emoji/svg/1f486-1f3ff.svg new file mode 100644 index 00000000..c03123b2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f486-200d-2640-fe0f.svg new file mode 100644 index 00000000..de2053b8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f486-200d-2642-fe0f.svg new file mode 100644 index 00000000..39bb75b2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f486.svg b/qortal-ui-core/emoji/svg/1f486.svg new file mode 100644 index 00000000..57e35884 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f486.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f487-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..3d2a27c6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f487-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..d50a4298 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-1f3fb.svg b/qortal-ui-core/emoji/svg/1f487-1f3fb.svg new file mode 100644 index 00000000..acafd9bb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f487-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..fc156536 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f487-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..bc4c86b6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-1f3fc.svg b/qortal-ui-core/emoji/svg/1f487-1f3fc.svg new file mode 100644 index 00000000..e3665ec1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f487-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..c2d9ec71 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f487-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..89651cdb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-1f3fd.svg b/qortal-ui-core/emoji/svg/1f487-1f3fd.svg new file mode 100644 index 00000000..45bb2f1a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f487-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..ed2374cf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f487-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..8deb60db --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-1f3fe.svg b/qortal-ui-core/emoji/svg/1f487-1f3fe.svg new file mode 100644 index 00000000..39623cc0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f487-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..b8b4754c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f487-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..ba85114d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-1f3ff.svg b/qortal-ui-core/emoji/svg/1f487-1f3ff.svg new file mode 100644 index 00000000..1840045c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f487-200d-2640-fe0f.svg new file mode 100644 index 00000000..8bfab801 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f487-200d-2642-fe0f.svg new file mode 100644 index 00000000..e3bc6d90 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f487.svg b/qortal-ui-core/emoji/svg/1f487.svg new file mode 100644 index 00000000..1957fa0f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f487.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f488.svg b/qortal-ui-core/emoji/svg/1f488.svg new file mode 100644 index 00000000..33ed3328 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f488.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f489.svg b/qortal-ui-core/emoji/svg/1f489.svg new file mode 100644 index 00000000..ef9c72c7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f489.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f48a.svg b/qortal-ui-core/emoji/svg/1f48a.svg new file mode 100644 index 00000000..931839bf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f48a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f48b.svg b/qortal-ui-core/emoji/svg/1f48b.svg new file mode 100644 index 00000000..f71fc97f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f48b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f48c.svg b/qortal-ui-core/emoji/svg/1f48c.svg new file mode 100644 index 00000000..0734ecf2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f48c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f48d.svg b/qortal-ui-core/emoji/svg/1f48d.svg new file mode 100644 index 00000000..08341659 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f48d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f48e.svg b/qortal-ui-core/emoji/svg/1f48e.svg new file mode 100644 index 00000000..a379f719 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f48e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f48f.svg b/qortal-ui-core/emoji/svg/1f48f.svg new file mode 100644 index 00000000..69cec3c6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f48f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f490.svg b/qortal-ui-core/emoji/svg/1f490.svg new file mode 100644 index 00000000..f080ef7f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f490.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f491.svg b/qortal-ui-core/emoji/svg/1f491.svg new file mode 100644 index 00000000..73a30e93 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f491.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f492.svg b/qortal-ui-core/emoji/svg/1f492.svg new file mode 100644 index 00000000..974ddac8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f492.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f493.svg b/qortal-ui-core/emoji/svg/1f493.svg new file mode 100644 index 00000000..404a6e76 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f493.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f494.svg b/qortal-ui-core/emoji/svg/1f494.svg new file mode 100644 index 00000000..d50c7704 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f494.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f495.svg b/qortal-ui-core/emoji/svg/1f495.svg new file mode 100644 index 00000000..b4b3216f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f495.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f496.svg b/qortal-ui-core/emoji/svg/1f496.svg new file mode 100644 index 00000000..aa3abbca --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f496.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f497.svg b/qortal-ui-core/emoji/svg/1f497.svg new file mode 100644 index 00000000..295f9d48 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f497.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f498.svg b/qortal-ui-core/emoji/svg/1f498.svg new file mode 100644 index 00000000..32d819fe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f498.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f499.svg b/qortal-ui-core/emoji/svg/1f499.svg new file mode 100644 index 00000000..9eade121 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f499.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f49a.svg b/qortal-ui-core/emoji/svg/1f49a.svg new file mode 100644 index 00000000..b81f7029 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f49a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f49b.svg b/qortal-ui-core/emoji/svg/1f49b.svg new file mode 100644 index 00000000..e57e2444 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f49b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f49c.svg b/qortal-ui-core/emoji/svg/1f49c.svg new file mode 100644 index 00000000..f1dc073c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f49c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f49d.svg b/qortal-ui-core/emoji/svg/1f49d.svg new file mode 100644 index 00000000..5db2632f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f49d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f49e.svg b/qortal-ui-core/emoji/svg/1f49e.svg new file mode 100644 index 00000000..b9459b7d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f49e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f49f.svg b/qortal-ui-core/emoji/svg/1f49f.svg new file mode 100644 index 00000000..71adb414 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f49f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4a0.svg b/qortal-ui-core/emoji/svg/1f4a0.svg new file mode 100644 index 00000000..9c805656 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4a0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4a1.svg b/qortal-ui-core/emoji/svg/1f4a1.svg new file mode 100644 index 00000000..88b62e38 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4a1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4a2.svg b/qortal-ui-core/emoji/svg/1f4a2.svg new file mode 100644 index 00000000..78f797b3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4a2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4a3.svg b/qortal-ui-core/emoji/svg/1f4a3.svg new file mode 100644 index 00000000..feb2c9d2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4a3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4a4.svg b/qortal-ui-core/emoji/svg/1f4a4.svg new file mode 100644 index 00000000..b713e97a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4a5.svg b/qortal-ui-core/emoji/svg/1f4a5.svg new file mode 100644 index 00000000..36c50d63 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4a5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4a6.svg b/qortal-ui-core/emoji/svg/1f4a6.svg new file mode 100644 index 00000000..fd53cd84 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4a6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4a7.svg b/qortal-ui-core/emoji/svg/1f4a7.svg new file mode 100644 index 00000000..3116ec31 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4a7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4a8.svg b/qortal-ui-core/emoji/svg/1f4a8.svg new file mode 100644 index 00000000..006e04ad --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4a9.svg b/qortal-ui-core/emoji/svg/1f4a9.svg new file mode 100644 index 00000000..19221f6a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4a9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4aa-1f3fb.svg b/qortal-ui-core/emoji/svg/1f4aa-1f3fb.svg new file mode 100644 index 00000000..2627eea6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4aa-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4aa-1f3fc.svg b/qortal-ui-core/emoji/svg/1f4aa-1f3fc.svg new file mode 100644 index 00000000..2cac971b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4aa-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4aa-1f3fd.svg b/qortal-ui-core/emoji/svg/1f4aa-1f3fd.svg new file mode 100644 index 00000000..68f6b750 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4aa-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4aa-1f3fe.svg b/qortal-ui-core/emoji/svg/1f4aa-1f3fe.svg new file mode 100644 index 00000000..c773c672 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4aa-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4aa-1f3ff.svg b/qortal-ui-core/emoji/svg/1f4aa-1f3ff.svg new file mode 100644 index 00000000..16efbe0f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4aa-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4aa.svg b/qortal-ui-core/emoji/svg/1f4aa.svg new file mode 100644 index 00000000..7b4c1206 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4aa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4ab.svg b/qortal-ui-core/emoji/svg/1f4ab.svg new file mode 100644 index 00000000..af3261c2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4ab.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4ac.svg b/qortal-ui-core/emoji/svg/1f4ac.svg new file mode 100644 index 00000000..11533c5b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4ac.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4ad.svg b/qortal-ui-core/emoji/svg/1f4ad.svg new file mode 100644 index 00000000..f3d835c8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4ad.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4ae.svg b/qortal-ui-core/emoji/svg/1f4ae.svg new file mode 100644 index 00000000..7f8b5287 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4ae.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4af.svg b/qortal-ui-core/emoji/svg/1f4af.svg new file mode 100644 index 00000000..3d565cc6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4b0.svg b/qortal-ui-core/emoji/svg/1f4b0.svg new file mode 100644 index 00000000..5b41c52d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4b1.svg b/qortal-ui-core/emoji/svg/1f4b1.svg new file mode 100644 index 00000000..b67b0cd4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4b2.svg b/qortal-ui-core/emoji/svg/1f4b2.svg new file mode 100644 index 00000000..1bc1ead4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4b3.svg b/qortal-ui-core/emoji/svg/1f4b3.svg new file mode 100644 index 00000000..97641af4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4b4.svg b/qortal-ui-core/emoji/svg/1f4b4.svg new file mode 100644 index 00000000..747870e0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4b4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4b5.svg b/qortal-ui-core/emoji/svg/1f4b5.svg new file mode 100644 index 00000000..1c68944a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4b5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4b6.svg b/qortal-ui-core/emoji/svg/1f4b6.svg new file mode 100644 index 00000000..afd8b715 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4b6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4b7.svg b/qortal-ui-core/emoji/svg/1f4b7.svg new file mode 100644 index 00000000..ff5c5a44 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4b7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4b8.svg b/qortal-ui-core/emoji/svg/1f4b8.svg new file mode 100644 index 00000000..8b6fa109 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4b8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4b9.svg b/qortal-ui-core/emoji/svg/1f4b9.svg new file mode 100644 index 00000000..f6143a06 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4b9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4ba.svg b/qortal-ui-core/emoji/svg/1f4ba.svg new file mode 100644 index 00000000..ab311bc7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4ba.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4bb.svg b/qortal-ui-core/emoji/svg/1f4bb.svg new file mode 100644 index 00000000..93357fa2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4bc.svg b/qortal-ui-core/emoji/svg/1f4bc.svg new file mode 100644 index 00000000..c5336c75 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4bd.svg b/qortal-ui-core/emoji/svg/1f4bd.svg new file mode 100644 index 00000000..a557b9bf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4be.svg b/qortal-ui-core/emoji/svg/1f4be.svg new file mode 100644 index 00000000..7c976269 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4be.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4bf.svg b/qortal-ui-core/emoji/svg/1f4bf.svg new file mode 100644 index 00000000..6824a064 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4bf.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4c0.svg b/qortal-ui-core/emoji/svg/1f4c0.svg new file mode 100644 index 00000000..1b3b38b8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4c0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4c1.svg b/qortal-ui-core/emoji/svg/1f4c1.svg new file mode 100644 index 00000000..099d58ba --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4c1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4c2.svg b/qortal-ui-core/emoji/svg/1f4c2.svg new file mode 100644 index 00000000..60ec3794 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4c2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4c3.svg b/qortal-ui-core/emoji/svg/1f4c3.svg new file mode 100644 index 00000000..bf19ad29 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4c3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4c4.svg b/qortal-ui-core/emoji/svg/1f4c4.svg new file mode 100644 index 00000000..4631bc53 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4c4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4c5.svg b/qortal-ui-core/emoji/svg/1f4c5.svg new file mode 100644 index 00000000..476a9506 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4c5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4c6.svg b/qortal-ui-core/emoji/svg/1f4c6.svg new file mode 100644 index 00000000..b2de8c5c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4c6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4c7.svg b/qortal-ui-core/emoji/svg/1f4c7.svg new file mode 100644 index 00000000..097a7151 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4c7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4c8.svg b/qortal-ui-core/emoji/svg/1f4c8.svg new file mode 100644 index 00000000..cbf108fc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4c8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4c9.svg b/qortal-ui-core/emoji/svg/1f4c9.svg new file mode 100644 index 00000000..ac8c258c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4c9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4ca.svg b/qortal-ui-core/emoji/svg/1f4ca.svg new file mode 100644 index 00000000..3c572cb8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4ca.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4cb.svg b/qortal-ui-core/emoji/svg/1f4cb.svg new file mode 100644 index 00000000..a51b34a9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4cb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4cc.svg b/qortal-ui-core/emoji/svg/1f4cc.svg new file mode 100644 index 00000000..2ab6da3e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4cc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4cd.svg b/qortal-ui-core/emoji/svg/1f4cd.svg new file mode 100644 index 00000000..8ab3159c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4cd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4ce.svg b/qortal-ui-core/emoji/svg/1f4ce.svg new file mode 100644 index 00000000..284cf667 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4ce.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4cf.svg b/qortal-ui-core/emoji/svg/1f4cf.svg new file mode 100644 index 00000000..37b035b2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4cf.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4d0.svg b/qortal-ui-core/emoji/svg/1f4d0.svg new file mode 100644 index 00000000..b3651501 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4d0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4d1.svg b/qortal-ui-core/emoji/svg/1f4d1.svg new file mode 100644 index 00000000..b3bdc36c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4d1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4d2.svg b/qortal-ui-core/emoji/svg/1f4d2.svg new file mode 100644 index 00000000..ee15b168 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4d2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4d3.svg b/qortal-ui-core/emoji/svg/1f4d3.svg new file mode 100644 index 00000000..b6f49c05 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4d3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4d4.svg b/qortal-ui-core/emoji/svg/1f4d4.svg new file mode 100644 index 00000000..2bfc4cad --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4d4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4d5.svg b/qortal-ui-core/emoji/svg/1f4d5.svg new file mode 100644 index 00000000..701ff017 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4d5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4d6.svg b/qortal-ui-core/emoji/svg/1f4d6.svg new file mode 100644 index 00000000..0dfd0832 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4d6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4d7.svg b/qortal-ui-core/emoji/svg/1f4d7.svg new file mode 100644 index 00000000..ff747447 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4d7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4d8.svg b/qortal-ui-core/emoji/svg/1f4d8.svg new file mode 100644 index 00000000..ce459283 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4d8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4d9.svg b/qortal-ui-core/emoji/svg/1f4d9.svg new file mode 100644 index 00000000..b055f66b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4d9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4da.svg b/qortal-ui-core/emoji/svg/1f4da.svg new file mode 100644 index 00000000..422d3884 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4da.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4db.svg b/qortal-ui-core/emoji/svg/1f4db.svg new file mode 100644 index 00000000..00f1a106 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4db.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4dc.svg b/qortal-ui-core/emoji/svg/1f4dc.svg new file mode 100644 index 00000000..2a7fd37d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4dc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4dd.svg b/qortal-ui-core/emoji/svg/1f4dd.svg new file mode 100644 index 00000000..1697ffbe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4dd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4de.svg b/qortal-ui-core/emoji/svg/1f4de.svg new file mode 100644 index 00000000..cfaf7ca8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4de.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4df.svg b/qortal-ui-core/emoji/svg/1f4df.svg new file mode 100644 index 00000000..d7d4b5fa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4df.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4e0.svg b/qortal-ui-core/emoji/svg/1f4e0.svg new file mode 100644 index 00000000..5f88b133 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4e0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4e1.svg b/qortal-ui-core/emoji/svg/1f4e1.svg new file mode 100644 index 00000000..dcb02946 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4e1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4e2.svg b/qortal-ui-core/emoji/svg/1f4e2.svg new file mode 100644 index 00000000..8bd0c94f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4e2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4e3.svg b/qortal-ui-core/emoji/svg/1f4e3.svg new file mode 100644 index 00000000..20cbc7d4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4e4.svg b/qortal-ui-core/emoji/svg/1f4e4.svg new file mode 100644 index 00000000..62d9033e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4e4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4e5.svg b/qortal-ui-core/emoji/svg/1f4e5.svg new file mode 100644 index 00000000..921ca18a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4e5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4e6.svg b/qortal-ui-core/emoji/svg/1f4e6.svg new file mode 100644 index 00000000..1ce09611 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4e7.svg b/qortal-ui-core/emoji/svg/1f4e7.svg new file mode 100644 index 00000000..d8ce780c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4e7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4e8.svg b/qortal-ui-core/emoji/svg/1f4e8.svg new file mode 100644 index 00000000..7c59e93a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4e9.svg b/qortal-ui-core/emoji/svg/1f4e9.svg new file mode 100644 index 00000000..1847cd13 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4ea.svg b/qortal-ui-core/emoji/svg/1f4ea.svg new file mode 100644 index 00000000..54f609e9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4eb.svg b/qortal-ui-core/emoji/svg/1f4eb.svg new file mode 100644 index 00000000..79ea795a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4ec.svg b/qortal-ui-core/emoji/svg/1f4ec.svg new file mode 100644 index 00000000..27d6ebe6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4ed.svg b/qortal-ui-core/emoji/svg/1f4ed.svg new file mode 100644 index 00000000..4e969c95 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4ee.svg b/qortal-ui-core/emoji/svg/1f4ee.svg new file mode 100644 index 00000000..61c0332d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4ee.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4ef.svg b/qortal-ui-core/emoji/svg/1f4ef.svg new file mode 100644 index 00000000..2fa1e2d4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4ef.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4f0.svg b/qortal-ui-core/emoji/svg/1f4f0.svg new file mode 100644 index 00000000..a97d4771 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4f1.svg b/qortal-ui-core/emoji/svg/1f4f1.svg new file mode 100644 index 00000000..81c4e99c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4f1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4f2.svg b/qortal-ui-core/emoji/svg/1f4f2.svg new file mode 100644 index 00000000..82f5293e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4f3.svg b/qortal-ui-core/emoji/svg/1f4f3.svg new file mode 100644 index 00000000..287d5a9d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4f4.svg b/qortal-ui-core/emoji/svg/1f4f4.svg new file mode 100644 index 00000000..fc2d2cd4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4f5.svg b/qortal-ui-core/emoji/svg/1f4f5.svg new file mode 100644 index 00000000..fdbab38c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4f5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4f6.svg b/qortal-ui-core/emoji/svg/1f4f6.svg new file mode 100644 index 00000000..df646fd3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4f6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4f7.svg b/qortal-ui-core/emoji/svg/1f4f7.svg new file mode 100644 index 00000000..aa2d9c50 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4f8.svg b/qortal-ui-core/emoji/svg/1f4f8.svg new file mode 100644 index 00000000..9bf3cf70 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4f9.svg b/qortal-ui-core/emoji/svg/1f4f9.svg new file mode 100644 index 00000000..f1abb590 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4fa.svg b/qortal-ui-core/emoji/svg/1f4fa.svg new file mode 100644 index 00000000..5f864dee --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4fb.svg b/qortal-ui-core/emoji/svg/1f4fb.svg new file mode 100644 index 00000000..33808ad7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4fc.svg b/qortal-ui-core/emoji/svg/1f4fc.svg new file mode 100644 index 00000000..31024baf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4fd.svg b/qortal-ui-core/emoji/svg/1f4fd.svg new file mode 100644 index 00000000..b12b42ce --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f4ff.svg b/qortal-ui-core/emoji/svg/1f4ff.svg new file mode 100644 index 00000000..a38a8e27 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f4ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f500.svg b/qortal-ui-core/emoji/svg/1f500.svg new file mode 100644 index 00000000..43f78bc4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f500.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f501.svg b/qortal-ui-core/emoji/svg/1f501.svg new file mode 100644 index 00000000..27efdab8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f501.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f502.svg b/qortal-ui-core/emoji/svg/1f502.svg new file mode 100644 index 00000000..926d8965 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f502.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f503.svg b/qortal-ui-core/emoji/svg/1f503.svg new file mode 100644 index 00000000..e35eb881 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f503.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f504.svg b/qortal-ui-core/emoji/svg/1f504.svg new file mode 100644 index 00000000..c88a827c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f504.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f505.svg b/qortal-ui-core/emoji/svg/1f505.svg new file mode 100644 index 00000000..998b8f43 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f505.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f506.svg b/qortal-ui-core/emoji/svg/1f506.svg new file mode 100644 index 00000000..2a2d58ca --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f506.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f507.svg b/qortal-ui-core/emoji/svg/1f507.svg new file mode 100644 index 00000000..39dddb52 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f507.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f508.svg b/qortal-ui-core/emoji/svg/1f508.svg new file mode 100644 index 00000000..11a7b0ed --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f508.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f509.svg b/qortal-ui-core/emoji/svg/1f509.svg new file mode 100644 index 00000000..9fb6c1cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f509.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f50a.svg b/qortal-ui-core/emoji/svg/1f50a.svg new file mode 100644 index 00000000..de54654e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f50a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f50b.svg b/qortal-ui-core/emoji/svg/1f50b.svg new file mode 100644 index 00000000..66d420fc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f50b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f50c.svg b/qortal-ui-core/emoji/svg/1f50c.svg new file mode 100644 index 00000000..8f432f0d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f50c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f50d.svg b/qortal-ui-core/emoji/svg/1f50d.svg new file mode 100644 index 00000000..038bbc24 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f50d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f50e.svg b/qortal-ui-core/emoji/svg/1f50e.svg new file mode 100644 index 00000000..778ae77e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f50e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f50f.svg b/qortal-ui-core/emoji/svg/1f50f.svg new file mode 100644 index 00000000..d2ae4863 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f50f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f510.svg b/qortal-ui-core/emoji/svg/1f510.svg new file mode 100644 index 00000000..014079e8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f510.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f511.svg b/qortal-ui-core/emoji/svg/1f511.svg new file mode 100644 index 00000000..7b4dc2a7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f511.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f512.svg b/qortal-ui-core/emoji/svg/1f512.svg new file mode 100644 index 00000000..378fabf4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f512.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f513.svg b/qortal-ui-core/emoji/svg/1f513.svg new file mode 100644 index 00000000..cd82ec8e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f513.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f514.svg b/qortal-ui-core/emoji/svg/1f514.svg new file mode 100644 index 00000000..9e89a7ca --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f514.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f515.svg b/qortal-ui-core/emoji/svg/1f515.svg new file mode 100644 index 00000000..921d352c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f515.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f516.svg b/qortal-ui-core/emoji/svg/1f516.svg new file mode 100644 index 00000000..38dc790a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f516.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f517.svg b/qortal-ui-core/emoji/svg/1f517.svg new file mode 100644 index 00000000..22ddbe08 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f517.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f518.svg b/qortal-ui-core/emoji/svg/1f518.svg new file mode 100644 index 00000000..e4d03480 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f518.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f519.svg b/qortal-ui-core/emoji/svg/1f519.svg new file mode 100644 index 00000000..ddf8fbd3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f519.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f51a.svg b/qortal-ui-core/emoji/svg/1f51a.svg new file mode 100644 index 00000000..d964c524 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f51a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f51b.svg b/qortal-ui-core/emoji/svg/1f51b.svg new file mode 100644 index 00000000..a885bab4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f51b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f51c.svg b/qortal-ui-core/emoji/svg/1f51c.svg new file mode 100644 index 00000000..69042810 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f51c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f51d.svg b/qortal-ui-core/emoji/svg/1f51d.svg new file mode 100644 index 00000000..54ab898e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f51d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f51e.svg b/qortal-ui-core/emoji/svg/1f51e.svg new file mode 100644 index 00000000..8f877f8b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f51e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f51f.svg b/qortal-ui-core/emoji/svg/1f51f.svg new file mode 100644 index 00000000..05dc8b91 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f51f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f520.svg b/qortal-ui-core/emoji/svg/1f520.svg new file mode 100644 index 00000000..429f1136 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f520.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f521.svg b/qortal-ui-core/emoji/svg/1f521.svg new file mode 100644 index 00000000..3c2076ea --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f521.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f522.svg b/qortal-ui-core/emoji/svg/1f522.svg new file mode 100644 index 00000000..316f8ee8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f522.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f523.svg b/qortal-ui-core/emoji/svg/1f523.svg new file mode 100644 index 00000000..71ac1578 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f523.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f524.svg b/qortal-ui-core/emoji/svg/1f524.svg new file mode 100644 index 00000000..e3e9464c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f524.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f525.svg b/qortal-ui-core/emoji/svg/1f525.svg new file mode 100644 index 00000000..e7dee6dd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f525.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f526.svg b/qortal-ui-core/emoji/svg/1f526.svg new file mode 100644 index 00000000..1aff8ae2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f526.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f527.svg b/qortal-ui-core/emoji/svg/1f527.svg new file mode 100644 index 00000000..73a06d0d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f528.svg b/qortal-ui-core/emoji/svg/1f528.svg new file mode 100644 index 00000000..1a0485e5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f528.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f529.svg b/qortal-ui-core/emoji/svg/1f529.svg new file mode 100644 index 00000000..e02eaa6f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f529.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f52a.svg b/qortal-ui-core/emoji/svg/1f52a.svg new file mode 100644 index 00000000..d2ba9e7f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f52a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f52b.svg b/qortal-ui-core/emoji/svg/1f52b.svg new file mode 100644 index 00000000..3c8b6e43 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f52b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f52c.svg b/qortal-ui-core/emoji/svg/1f52c.svg new file mode 100644 index 00000000..e910ee89 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f52d.svg b/qortal-ui-core/emoji/svg/1f52d.svg new file mode 100644 index 00000000..113c0330 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f52d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f52e.svg b/qortal-ui-core/emoji/svg/1f52e.svg new file mode 100644 index 00000000..d7e09232 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f52e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f52f.svg b/qortal-ui-core/emoji/svg/1f52f.svg new file mode 100644 index 00000000..7efa3724 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f52f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f530.svg b/qortal-ui-core/emoji/svg/1f530.svg new file mode 100644 index 00000000..a6b9fbe1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f530.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f531.svg b/qortal-ui-core/emoji/svg/1f531.svg new file mode 100644 index 00000000..20cc78d8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f531.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f532.svg b/qortal-ui-core/emoji/svg/1f532.svg new file mode 100644 index 00000000..a2e37de7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f532.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f533.svg b/qortal-ui-core/emoji/svg/1f533.svg new file mode 100644 index 00000000..13f35b71 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f533.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f534.svg b/qortal-ui-core/emoji/svg/1f534.svg new file mode 100644 index 00000000..d98cc6d6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f534.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f535.svg b/qortal-ui-core/emoji/svg/1f535.svg new file mode 100644 index 00000000..9d4ab8f5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f535.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f536.svg b/qortal-ui-core/emoji/svg/1f536.svg new file mode 100644 index 00000000..9695be3e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f536.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f537.svg b/qortal-ui-core/emoji/svg/1f537.svg new file mode 100644 index 00000000..44acab23 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f537.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f538.svg b/qortal-ui-core/emoji/svg/1f538.svg new file mode 100644 index 00000000..842ffcc5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f538.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f539.svg b/qortal-ui-core/emoji/svg/1f539.svg new file mode 100644 index 00000000..bb4865d1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f539.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f53a.svg b/qortal-ui-core/emoji/svg/1f53a.svg new file mode 100644 index 00000000..96d0ebb2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f53a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f53b.svg b/qortal-ui-core/emoji/svg/1f53b.svg new file mode 100644 index 00000000..f846cbfb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f53b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f53c.svg b/qortal-ui-core/emoji/svg/1f53c.svg new file mode 100644 index 00000000..b057a592 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f53c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f53d.svg b/qortal-ui-core/emoji/svg/1f53d.svg new file mode 100644 index 00000000..09ec8746 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f53d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f549.svg b/qortal-ui-core/emoji/svg/1f549.svg new file mode 100644 index 00000000..9e6a1efb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f549.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f54a.svg b/qortal-ui-core/emoji/svg/1f54a.svg new file mode 100644 index 00000000..613e4956 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f54a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f54b.svg b/qortal-ui-core/emoji/svg/1f54b.svg new file mode 100644 index 00000000..3cd63ee3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f54b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f54c.svg b/qortal-ui-core/emoji/svg/1f54c.svg new file mode 100644 index 00000000..6ef55165 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f54c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f54d.svg b/qortal-ui-core/emoji/svg/1f54d.svg new file mode 100644 index 00000000..c82ae007 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f54d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f54e.svg b/qortal-ui-core/emoji/svg/1f54e.svg new file mode 100644 index 00000000..1ebcec52 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f54e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f550.svg b/qortal-ui-core/emoji/svg/1f550.svg new file mode 100644 index 00000000..da82d976 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f550.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f551.svg b/qortal-ui-core/emoji/svg/1f551.svg new file mode 100644 index 00000000..96ab682e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f551.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f552.svg b/qortal-ui-core/emoji/svg/1f552.svg new file mode 100644 index 00000000..ce4c487a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f552.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f553.svg b/qortal-ui-core/emoji/svg/1f553.svg new file mode 100644 index 00000000..2ac4eade --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f553.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f554.svg b/qortal-ui-core/emoji/svg/1f554.svg new file mode 100644 index 00000000..1a2ef1c3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f554.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f555.svg b/qortal-ui-core/emoji/svg/1f555.svg new file mode 100644 index 00000000..5021b165 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f555.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f556.svg b/qortal-ui-core/emoji/svg/1f556.svg new file mode 100644 index 00000000..a2eb7ef2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f556.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f557.svg b/qortal-ui-core/emoji/svg/1f557.svg new file mode 100644 index 00000000..3a7ff9b0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f557.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f558.svg b/qortal-ui-core/emoji/svg/1f558.svg new file mode 100644 index 00000000..e9d3cb58 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f558.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f559.svg b/qortal-ui-core/emoji/svg/1f559.svg new file mode 100644 index 00000000..331f702d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f559.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f55a.svg b/qortal-ui-core/emoji/svg/1f55a.svg new file mode 100644 index 00000000..58834498 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f55a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f55b.svg b/qortal-ui-core/emoji/svg/1f55b.svg new file mode 100644 index 00000000..85010aee --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f55b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f55c.svg b/qortal-ui-core/emoji/svg/1f55c.svg new file mode 100644 index 00000000..f471871f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f55c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f55d.svg b/qortal-ui-core/emoji/svg/1f55d.svg new file mode 100644 index 00000000..feb77f81 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f55d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f55e.svg b/qortal-ui-core/emoji/svg/1f55e.svg new file mode 100644 index 00000000..8ab841fa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f55e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f55f.svg b/qortal-ui-core/emoji/svg/1f55f.svg new file mode 100644 index 00000000..81ccc7ed --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f55f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f560.svg b/qortal-ui-core/emoji/svg/1f560.svg new file mode 100644 index 00000000..098c47f3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f560.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f561.svg b/qortal-ui-core/emoji/svg/1f561.svg new file mode 100644 index 00000000..3a50a9ae --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f561.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f562.svg b/qortal-ui-core/emoji/svg/1f562.svg new file mode 100644 index 00000000..f2c6ace6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f562.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f563.svg b/qortal-ui-core/emoji/svg/1f563.svg new file mode 100644 index 00000000..a14e0dc6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f563.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f564.svg b/qortal-ui-core/emoji/svg/1f564.svg new file mode 100644 index 00000000..4d6f8735 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f564.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f565.svg b/qortal-ui-core/emoji/svg/1f565.svg new file mode 100644 index 00000000..f658fa32 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f565.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f566.svg b/qortal-ui-core/emoji/svg/1f566.svg new file mode 100644 index 00000000..41e105ff --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f566.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f567.svg b/qortal-ui-core/emoji/svg/1f567.svg new file mode 100644 index 00000000..7178a881 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f567.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f56f.svg b/qortal-ui-core/emoji/svg/1f56f.svg new file mode 100644 index 00000000..c0e45ac5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f56f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f570.svg b/qortal-ui-core/emoji/svg/1f570.svg new file mode 100644 index 00000000..da6fd268 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f570.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f573.svg b/qortal-ui-core/emoji/svg/1f573.svg new file mode 100644 index 00000000..213a6ab6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f573.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f574-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..19175729 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f574-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..97bc7b5a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-1f3fb.svg b/qortal-ui-core/emoji/svg/1f574-1f3fb.svg new file mode 100644 index 00000000..dda8bd69 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f574-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..3de7ee30 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f574-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..27c10f15 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-1f3fc.svg b/qortal-ui-core/emoji/svg/1f574-1f3fc.svg new file mode 100644 index 00000000..ba0b1252 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f574-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..076acec6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f574-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..4e980b00 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-1f3fd.svg b/qortal-ui-core/emoji/svg/1f574-1f3fd.svg new file mode 100644 index 00000000..a06a09df --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f574-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..f98eb126 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f574-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..88a30616 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-1f3fe.svg b/qortal-ui-core/emoji/svg/1f574-1f3fe.svg new file mode 100644 index 00000000..2dde9ec8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f574-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..e8033f53 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f574-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..57aec606 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-1f3ff.svg b/qortal-ui-core/emoji/svg/1f574-1f3ff.svg new file mode 100644 index 00000000..31c17327 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-fe0f-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f574-fe0f-200d-2640-fe0f.svg new file mode 100644 index 00000000..4f80c791 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-fe0f-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574-fe0f-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f574-fe0f-200d-2642-fe0f.svg new file mode 100644 index 00000000..a834fd4b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574-fe0f-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f574.svg b/qortal-ui-core/emoji/svg/1f574.svg new file mode 100644 index 00000000..d363425a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f574.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f575-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..b85b5dba --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f575-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..fd521e25 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-1f3fb.svg b/qortal-ui-core/emoji/svg/1f575-1f3fb.svg new file mode 100644 index 00000000..a2782993 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f575-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..dfc8aabc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f575-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..fdb8cd5b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-1f3fc.svg b/qortal-ui-core/emoji/svg/1f575-1f3fc.svg new file mode 100644 index 00000000..0c94590f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f575-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..b6d0b87b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f575-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..474f2535 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-1f3fd.svg b/qortal-ui-core/emoji/svg/1f575-1f3fd.svg new file mode 100644 index 00000000..9350bd1c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f575-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..67b6d0b9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f575-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..3367897a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-1f3fe.svg b/qortal-ui-core/emoji/svg/1f575-1f3fe.svg new file mode 100644 index 00000000..5455c07a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f575-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..fcea54da --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f575-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..eb25e644 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-1f3ff.svg b/qortal-ui-core/emoji/svg/1f575-1f3ff.svg new file mode 100644 index 00000000..0302169f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-fe0f-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f575-fe0f-200d-2640-fe0f.svg new file mode 100644 index 00000000..1f92d39d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-fe0f-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575-fe0f-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f575-fe0f-200d-2642-fe0f.svg new file mode 100644 index 00000000..bba4b943 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575-fe0f-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f575.svg b/qortal-ui-core/emoji/svg/1f575.svg new file mode 100644 index 00000000..e82b8d9e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f575.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f576.svg b/qortal-ui-core/emoji/svg/1f576.svg new file mode 100644 index 00000000..5d5c04fb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f576.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f577.svg b/qortal-ui-core/emoji/svg/1f577.svg new file mode 100644 index 00000000..a1568651 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f577.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f578.svg b/qortal-ui-core/emoji/svg/1f578.svg new file mode 100644 index 00000000..92142fd3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f578.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f579.svg b/qortal-ui-core/emoji/svg/1f579.svg new file mode 100644 index 00000000..33479b50 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f579.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f57a-1f3fb.svg b/qortal-ui-core/emoji/svg/1f57a-1f3fb.svg new file mode 100644 index 00000000..1eb5928c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f57a-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f57a-1f3fc.svg b/qortal-ui-core/emoji/svg/1f57a-1f3fc.svg new file mode 100644 index 00000000..37bfbee9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f57a-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f57a-1f3fd.svg b/qortal-ui-core/emoji/svg/1f57a-1f3fd.svg new file mode 100644 index 00000000..586b6c5e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f57a-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f57a-1f3fe.svg b/qortal-ui-core/emoji/svg/1f57a-1f3fe.svg new file mode 100644 index 00000000..02824e9c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f57a-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f57a-1f3ff.svg b/qortal-ui-core/emoji/svg/1f57a-1f3ff.svg new file mode 100644 index 00000000..f43787a0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f57a-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f57a.svg b/qortal-ui-core/emoji/svg/1f57a.svg new file mode 100644 index 00000000..e63c1ec8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f57a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f587.svg b/qortal-ui-core/emoji/svg/1f587.svg new file mode 100644 index 00000000..a6ef1815 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f587.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f58a.svg b/qortal-ui-core/emoji/svg/1f58a.svg new file mode 100644 index 00000000..4e791e6a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f58a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f58b.svg b/qortal-ui-core/emoji/svg/1f58b.svg new file mode 100644 index 00000000..8a7f7735 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f58b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f58c.svg b/qortal-ui-core/emoji/svg/1f58c.svg new file mode 100644 index 00000000..b39bcbc9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f58c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f58d.svg b/qortal-ui-core/emoji/svg/1f58d.svg new file mode 100644 index 00000000..5a4cbe8e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f58d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f590-1f3fb.svg b/qortal-ui-core/emoji/svg/1f590-1f3fb.svg new file mode 100644 index 00000000..f106ae7d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f590-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f590-1f3fc.svg b/qortal-ui-core/emoji/svg/1f590-1f3fc.svg new file mode 100644 index 00000000..9944090e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f590-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f590-1f3fd.svg b/qortal-ui-core/emoji/svg/1f590-1f3fd.svg new file mode 100644 index 00000000..296a8f79 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f590-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f590-1f3fe.svg b/qortal-ui-core/emoji/svg/1f590-1f3fe.svg new file mode 100644 index 00000000..9ec61de5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f590-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f590-1f3ff.svg b/qortal-ui-core/emoji/svg/1f590-1f3ff.svg new file mode 100644 index 00000000..0a4d174b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f590-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f590.svg b/qortal-ui-core/emoji/svg/1f590.svg new file mode 100644 index 00000000..1c8dd684 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f590.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f595-1f3fb.svg b/qortal-ui-core/emoji/svg/1f595-1f3fb.svg new file mode 100644 index 00000000..3865d662 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f595-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f595-1f3fc.svg b/qortal-ui-core/emoji/svg/1f595-1f3fc.svg new file mode 100644 index 00000000..b52ea58d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f595-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f595-1f3fd.svg b/qortal-ui-core/emoji/svg/1f595-1f3fd.svg new file mode 100644 index 00000000..7224b212 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f595-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f595-1f3fe.svg b/qortal-ui-core/emoji/svg/1f595-1f3fe.svg new file mode 100644 index 00000000..571c54c3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f595-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f595-1f3ff.svg b/qortal-ui-core/emoji/svg/1f595-1f3ff.svg new file mode 100644 index 00000000..0fdb0ea6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f595-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f595.svg b/qortal-ui-core/emoji/svg/1f595.svg new file mode 100644 index 00000000..e644c376 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f595.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f596-1f3fb.svg b/qortal-ui-core/emoji/svg/1f596-1f3fb.svg new file mode 100644 index 00000000..0676c0fc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f596-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f596-1f3fc.svg b/qortal-ui-core/emoji/svg/1f596-1f3fc.svg new file mode 100644 index 00000000..9f1d4f10 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f596-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f596-1f3fd.svg b/qortal-ui-core/emoji/svg/1f596-1f3fd.svg new file mode 100644 index 00000000..b2c324d5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f596-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f596-1f3fe.svg b/qortal-ui-core/emoji/svg/1f596-1f3fe.svg new file mode 100644 index 00000000..eb3586ee --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f596-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f596-1f3ff.svg b/qortal-ui-core/emoji/svg/1f596-1f3ff.svg new file mode 100644 index 00000000..c8f2b5b0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f596-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f596.svg b/qortal-ui-core/emoji/svg/1f596.svg new file mode 100644 index 00000000..4b834f87 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f596.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5a4.svg b/qortal-ui-core/emoji/svg/1f5a4.svg new file mode 100644 index 00000000..51ec883f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5a5.svg b/qortal-ui-core/emoji/svg/1f5a5.svg new file mode 100644 index 00000000..e1a06333 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5a5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5a8.svg b/qortal-ui-core/emoji/svg/1f5a8.svg new file mode 100644 index 00000000..fae59fef --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5b1.svg b/qortal-ui-core/emoji/svg/1f5b1.svg new file mode 100644 index 00000000..961f67ee --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5b2.svg b/qortal-ui-core/emoji/svg/1f5b2.svg new file mode 100644 index 00000000..caea2fdc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5bc.svg b/qortal-ui-core/emoji/svg/1f5bc.svg new file mode 100644 index 00000000..1a2ad727 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5c2.svg b/qortal-ui-core/emoji/svg/1f5c2.svg new file mode 100644 index 00000000..822a9276 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5c2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5c3.svg b/qortal-ui-core/emoji/svg/1f5c3.svg new file mode 100644 index 00000000..48dd45b8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5c3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5c4.svg b/qortal-ui-core/emoji/svg/1f5c4.svg new file mode 100644 index 00000000..4c065fb4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5c4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5d1.svg b/qortal-ui-core/emoji/svg/1f5d1.svg new file mode 100644 index 00000000..26695074 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5d1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5d2.svg b/qortal-ui-core/emoji/svg/1f5d2.svg new file mode 100644 index 00000000..cbb6965b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5d2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5d3.svg b/qortal-ui-core/emoji/svg/1f5d3.svg new file mode 100644 index 00000000..526191c0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5d3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5dc.svg b/qortal-ui-core/emoji/svg/1f5dc.svg new file mode 100644 index 00000000..6f35d170 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5dc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5dd.svg b/qortal-ui-core/emoji/svg/1f5dd.svg new file mode 100644 index 00000000..9e97cea6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5dd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5de.svg b/qortal-ui-core/emoji/svg/1f5de.svg new file mode 100644 index 00000000..95678176 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5de.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5e1.svg b/qortal-ui-core/emoji/svg/1f5e1.svg new file mode 100644 index 00000000..d1d7712c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5e1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5e3.svg b/qortal-ui-core/emoji/svg/1f5e3.svg new file mode 100644 index 00000000..4e613c04 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5e8.svg b/qortal-ui-core/emoji/svg/1f5e8.svg new file mode 100644 index 00000000..d0918971 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5ef.svg b/qortal-ui-core/emoji/svg/1f5ef.svg new file mode 100644 index 00000000..3aba53cc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5ef.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5f3.svg b/qortal-ui-core/emoji/svg/1f5f3.svg new file mode 100644 index 00000000..9c643d36 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5fa.svg b/qortal-ui-core/emoji/svg/1f5fa.svg new file mode 100644 index 00000000..337b3dc9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5fb.svg b/qortal-ui-core/emoji/svg/1f5fb.svg new file mode 100644 index 00000000..a8ad074c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5fc.svg b/qortal-ui-core/emoji/svg/1f5fc.svg new file mode 100644 index 00000000..92fd6ae0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5fd.svg b/qortal-ui-core/emoji/svg/1f5fd.svg new file mode 100644 index 00000000..3191523a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5fe.svg b/qortal-ui-core/emoji/svg/1f5fe.svg new file mode 100644 index 00000000..a67c561e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f5ff.svg b/qortal-ui-core/emoji/svg/1f5ff.svg new file mode 100644 index 00000000..5ba18be1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f5ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f600.svg b/qortal-ui-core/emoji/svg/1f600.svg new file mode 100644 index 00000000..21afce43 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f600.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f601.svg b/qortal-ui-core/emoji/svg/1f601.svg new file mode 100644 index 00000000..9b792cbe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f601.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f602.svg b/qortal-ui-core/emoji/svg/1f602.svg new file mode 100644 index 00000000..1ec79377 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f602.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f603.svg b/qortal-ui-core/emoji/svg/1f603.svg new file mode 100644 index 00000000..25d4b962 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f603.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f604.svg b/qortal-ui-core/emoji/svg/1f604.svg new file mode 100644 index 00000000..99ac39c7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f604.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f605.svg b/qortal-ui-core/emoji/svg/1f605.svg new file mode 100644 index 00000000..de6eb5de --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f605.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f606.svg b/qortal-ui-core/emoji/svg/1f606.svg new file mode 100644 index 00000000..e82c405a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f606.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f607.svg b/qortal-ui-core/emoji/svg/1f607.svg new file mode 100644 index 00000000..f6260fdb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f607.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f608.svg b/qortal-ui-core/emoji/svg/1f608.svg new file mode 100644 index 00000000..79c24804 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f608.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f609.svg b/qortal-ui-core/emoji/svg/1f609.svg new file mode 100644 index 00000000..1b7bba0a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f609.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f60a.svg b/qortal-ui-core/emoji/svg/1f60a.svg new file mode 100644 index 00000000..a6d9c1b5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f60a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f60b.svg b/qortal-ui-core/emoji/svg/1f60b.svg new file mode 100644 index 00000000..27e0d3a4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f60b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f60c.svg b/qortal-ui-core/emoji/svg/1f60c.svg new file mode 100644 index 00000000..f8d56233 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f60c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f60d.svg b/qortal-ui-core/emoji/svg/1f60d.svg new file mode 100644 index 00000000..18b1867c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f60d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f60e.svg b/qortal-ui-core/emoji/svg/1f60e.svg new file mode 100644 index 00000000..fff644a8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f60e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f60f.svg b/qortal-ui-core/emoji/svg/1f60f.svg new file mode 100644 index 00000000..ef4f386e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f60f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f610.svg b/qortal-ui-core/emoji/svg/1f610.svg new file mode 100644 index 00000000..953f9217 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f610.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f611.svg b/qortal-ui-core/emoji/svg/1f611.svg new file mode 100644 index 00000000..55be4fd3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f611.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f612.svg b/qortal-ui-core/emoji/svg/1f612.svg new file mode 100644 index 00000000..197089f5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f612.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f613.svg b/qortal-ui-core/emoji/svg/1f613.svg new file mode 100644 index 00000000..83c65803 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f613.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f614.svg b/qortal-ui-core/emoji/svg/1f614.svg new file mode 100644 index 00000000..be035300 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f614.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f615.svg b/qortal-ui-core/emoji/svg/1f615.svg new file mode 100644 index 00000000..339a6a27 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f615.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f616.svg b/qortal-ui-core/emoji/svg/1f616.svg new file mode 100644 index 00000000..2b8871ce --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f616.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f617.svg b/qortal-ui-core/emoji/svg/1f617.svg new file mode 100644 index 00000000..6b817eec --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f617.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f618.svg b/qortal-ui-core/emoji/svg/1f618.svg new file mode 100644 index 00000000..5e00b8e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f618.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f619.svg b/qortal-ui-core/emoji/svg/1f619.svg new file mode 100644 index 00000000..d9dfaa9d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f619.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f61a.svg b/qortal-ui-core/emoji/svg/1f61a.svg new file mode 100644 index 00000000..cefa3516 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f61a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f61b.svg b/qortal-ui-core/emoji/svg/1f61b.svg new file mode 100644 index 00000000..e249672d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f61b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f61c.svg b/qortal-ui-core/emoji/svg/1f61c.svg new file mode 100644 index 00000000..76b205dc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f61c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f61d.svg b/qortal-ui-core/emoji/svg/1f61d.svg new file mode 100644 index 00000000..f6b04039 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f61d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f61e.svg b/qortal-ui-core/emoji/svg/1f61e.svg new file mode 100644 index 00000000..7ae60a58 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f61e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f61f.svg b/qortal-ui-core/emoji/svg/1f61f.svg new file mode 100644 index 00000000..c5cec95d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f61f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f620.svg b/qortal-ui-core/emoji/svg/1f620.svg new file mode 100644 index 00000000..97e829a9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f620.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f621.svg b/qortal-ui-core/emoji/svg/1f621.svg new file mode 100644 index 00000000..f370594b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f621.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f622.svg b/qortal-ui-core/emoji/svg/1f622.svg new file mode 100644 index 00000000..1122bf5f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f622.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f623.svg b/qortal-ui-core/emoji/svg/1f623.svg new file mode 100644 index 00000000..e548a2ef --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f623.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f624.svg b/qortal-ui-core/emoji/svg/1f624.svg new file mode 100644 index 00000000..c211eec5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f624.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f625.svg b/qortal-ui-core/emoji/svg/1f625.svg new file mode 100644 index 00000000..0b4293f9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f625.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f626.svg b/qortal-ui-core/emoji/svg/1f626.svg new file mode 100644 index 00000000..683c0d34 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f626.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f627.svg b/qortal-ui-core/emoji/svg/1f627.svg new file mode 100644 index 00000000..5c338529 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f627.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f628.svg b/qortal-ui-core/emoji/svg/1f628.svg new file mode 100644 index 00000000..716302e2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f628.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f629.svg b/qortal-ui-core/emoji/svg/1f629.svg new file mode 100644 index 00000000..d367d484 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f629.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f62a.svg b/qortal-ui-core/emoji/svg/1f62a.svg new file mode 100644 index 00000000..ede0d7a2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f62a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f62b.svg b/qortal-ui-core/emoji/svg/1f62b.svg new file mode 100644 index 00000000..4253adad --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f62b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f62c.svg b/qortal-ui-core/emoji/svg/1f62c.svg new file mode 100644 index 00000000..3fdb9bf2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f62c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f62d.svg b/qortal-ui-core/emoji/svg/1f62d.svg new file mode 100644 index 00000000..11d1159e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f62d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f62e.svg b/qortal-ui-core/emoji/svg/1f62e.svg new file mode 100644 index 00000000..21fde1f0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f62e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f62f.svg b/qortal-ui-core/emoji/svg/1f62f.svg new file mode 100644 index 00000000..579bf480 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f62f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f630.svg b/qortal-ui-core/emoji/svg/1f630.svg new file mode 100644 index 00000000..de3d95cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f630.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f631.svg b/qortal-ui-core/emoji/svg/1f631.svg new file mode 100644 index 00000000..c70a81a7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f631.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f632.svg b/qortal-ui-core/emoji/svg/1f632.svg new file mode 100644 index 00000000..e2793217 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f632.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f633.svg b/qortal-ui-core/emoji/svg/1f633.svg new file mode 100644 index 00000000..80ee1fef --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f633.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f634.svg b/qortal-ui-core/emoji/svg/1f634.svg new file mode 100644 index 00000000..643ae221 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f634.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f635.svg b/qortal-ui-core/emoji/svg/1f635.svg new file mode 100644 index 00000000..7a45cf57 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f635.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f636.svg b/qortal-ui-core/emoji/svg/1f636.svg new file mode 100644 index 00000000..c208383c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f636.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f637.svg b/qortal-ui-core/emoji/svg/1f637.svg new file mode 100644 index 00000000..098e6b0b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f637.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f638.svg b/qortal-ui-core/emoji/svg/1f638.svg new file mode 100644 index 00000000..4e125ab9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f638.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f639.svg b/qortal-ui-core/emoji/svg/1f639.svg new file mode 100644 index 00000000..92f9022d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f639.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f63a.svg b/qortal-ui-core/emoji/svg/1f63a.svg new file mode 100644 index 00000000..88057ceb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f63a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f63b.svg b/qortal-ui-core/emoji/svg/1f63b.svg new file mode 100644 index 00000000..a4dd7e46 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f63b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f63c.svg b/qortal-ui-core/emoji/svg/1f63c.svg new file mode 100644 index 00000000..198ad47a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f63c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f63d.svg b/qortal-ui-core/emoji/svg/1f63d.svg new file mode 100644 index 00000000..e982de7a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f63d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f63e.svg b/qortal-ui-core/emoji/svg/1f63e.svg new file mode 100644 index 00000000..19a41d75 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f63e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f63f.svg b/qortal-ui-core/emoji/svg/1f63f.svg new file mode 100644 index 00000000..cdd84393 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f63f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f640.svg b/qortal-ui-core/emoji/svg/1f640.svg new file mode 100644 index 00000000..65ea8a5a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f640.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f641.svg b/qortal-ui-core/emoji/svg/1f641.svg new file mode 100644 index 00000000..cf3557b1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f641.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f642.svg b/qortal-ui-core/emoji/svg/1f642.svg new file mode 100644 index 00000000..ff9f989a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f642.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f643.svg b/qortal-ui-core/emoji/svg/1f643.svg new file mode 100644 index 00000000..ce062371 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f643.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f644.svg b/qortal-ui-core/emoji/svg/1f644.svg new file mode 100644 index 00000000..91c0b62f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f644.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f645-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..d3d6161f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f645-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..47b17497 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-1f3fb.svg b/qortal-ui-core/emoji/svg/1f645-1f3fb.svg new file mode 100644 index 00000000..9c977a2a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f645-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..061e83da --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f645-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..47109a9c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-1f3fc.svg b/qortal-ui-core/emoji/svg/1f645-1f3fc.svg new file mode 100644 index 00000000..1b50a9c7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f645-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..3ba6194b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f645-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..5e7487e7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-1f3fd.svg b/qortal-ui-core/emoji/svg/1f645-1f3fd.svg new file mode 100644 index 00000000..03a70859 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f645-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..5eacdc63 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f645-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..da7e7893 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-1f3fe.svg b/qortal-ui-core/emoji/svg/1f645-1f3fe.svg new file mode 100644 index 00000000..1424c968 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f645-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..e38dfd1c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f645-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..1fb2443b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-1f3ff.svg b/qortal-ui-core/emoji/svg/1f645-1f3ff.svg new file mode 100644 index 00000000..5b3bf34f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f645-200d-2640-fe0f.svg new file mode 100644 index 00000000..2e47b671 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f645-200d-2642-fe0f.svg new file mode 100644 index 00000000..ba0fc8e8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f645.svg b/qortal-ui-core/emoji/svg/1f645.svg new file mode 100644 index 00000000..d3d98541 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f645.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f646-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..1c051497 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f646-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..b8e5f156 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-1f3fb.svg b/qortal-ui-core/emoji/svg/1f646-1f3fb.svg new file mode 100644 index 00000000..acc932df --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f646-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..439f4d81 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f646-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..564a775e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-1f3fc.svg b/qortal-ui-core/emoji/svg/1f646-1f3fc.svg new file mode 100644 index 00000000..ec60afeb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f646-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..e5b1aea5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f646-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..b5103e3f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-1f3fd.svg b/qortal-ui-core/emoji/svg/1f646-1f3fd.svg new file mode 100644 index 00000000..0eb04e91 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f646-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..b041dc16 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f646-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..4b2b3b49 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-1f3fe.svg b/qortal-ui-core/emoji/svg/1f646-1f3fe.svg new file mode 100644 index 00000000..05a8ebf3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f646-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..66d5bd09 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f646-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..0411b8d4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-1f3ff.svg b/qortal-ui-core/emoji/svg/1f646-1f3ff.svg new file mode 100644 index 00000000..70e7bb82 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f646-200d-2640-fe0f.svg new file mode 100644 index 00000000..ccdb92a4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f646-200d-2642-fe0f.svg new file mode 100644 index 00000000..1c4205d5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f646.svg b/qortal-ui-core/emoji/svg/1f646.svg new file mode 100644 index 00000000..351e8d88 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f646.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f647-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..139284fe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f647-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..33901095 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-1f3fb.svg b/qortal-ui-core/emoji/svg/1f647-1f3fb.svg new file mode 100644 index 00000000..f16e19bb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f647-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..ba6b6eb3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f647-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..93d418cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-1f3fc.svg b/qortal-ui-core/emoji/svg/1f647-1f3fc.svg new file mode 100644 index 00000000..d0f9cf9d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f647-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..e9056586 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f647-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..abd06691 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-1f3fd.svg b/qortal-ui-core/emoji/svg/1f647-1f3fd.svg new file mode 100644 index 00000000..83ba2f6c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f647-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..8511aade --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f647-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..3f55ae82 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-1f3fe.svg b/qortal-ui-core/emoji/svg/1f647-1f3fe.svg new file mode 100644 index 00000000..2eeb5c5c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f647-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..00ab5588 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f647-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..1ea343bb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-1f3ff.svg b/qortal-ui-core/emoji/svg/1f647-1f3ff.svg new file mode 100644 index 00000000..768d9ea9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f647-200d-2640-fe0f.svg new file mode 100644 index 00000000..0545aa2e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f647-200d-2642-fe0f.svg new file mode 100644 index 00000000..7462b006 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f647.svg b/qortal-ui-core/emoji/svg/1f647.svg new file mode 100644 index 00000000..7ad69e9b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f647.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f648.svg b/qortal-ui-core/emoji/svg/1f648.svg new file mode 100644 index 00000000..31e38a33 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f648.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f649.svg b/qortal-ui-core/emoji/svg/1f649.svg new file mode 100644 index 00000000..377e0e6d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f649.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64a.svg b/qortal-ui-core/emoji/svg/1f64a.svg new file mode 100644 index 00000000..1e4e313e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64b-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..f10a7ef7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64b-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..46819a3c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-1f3fb.svg b/qortal-ui-core/emoji/svg/1f64b-1f3fb.svg new file mode 100644 index 00000000..4da55e82 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64b-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..34b2d325 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64b-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..177f70a6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-1f3fc.svg b/qortal-ui-core/emoji/svg/1f64b-1f3fc.svg new file mode 100644 index 00000000..4ead5819 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64b-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..62156c38 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64b-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..b449f1c6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-1f3fd.svg b/qortal-ui-core/emoji/svg/1f64b-1f3fd.svg new file mode 100644 index 00000000..13d04314 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64b-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..4dcde370 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64b-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..e1053e78 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-1f3fe.svg b/qortal-ui-core/emoji/svg/1f64b-1f3fe.svg new file mode 100644 index 00000000..f16cf36d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64b-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..f939a836 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64b-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..34c358fb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-1f3ff.svg b/qortal-ui-core/emoji/svg/1f64b-1f3ff.svg new file mode 100644 index 00000000..9131dc36 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64b-200d-2640-fe0f.svg new file mode 100644 index 00000000..a5ccaa1a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64b-200d-2642-fe0f.svg new file mode 100644 index 00000000..faf2f760 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64b.svg b/qortal-ui-core/emoji/svg/1f64b.svg new file mode 100644 index 00000000..197e8318 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64c-1f3fb.svg b/qortal-ui-core/emoji/svg/1f64c-1f3fb.svg new file mode 100644 index 00000000..b51e08e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64c-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64c-1f3fc.svg b/qortal-ui-core/emoji/svg/1f64c-1f3fc.svg new file mode 100644 index 00000000..6c4f43ea --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64c-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64c-1f3fd.svg b/qortal-ui-core/emoji/svg/1f64c-1f3fd.svg new file mode 100644 index 00000000..5624f607 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64c-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64c-1f3fe.svg b/qortal-ui-core/emoji/svg/1f64c-1f3fe.svg new file mode 100644 index 00000000..527cc23e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64c-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64c-1f3ff.svg b/qortal-ui-core/emoji/svg/1f64c-1f3ff.svg new file mode 100644 index 00000000..fc0a3332 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64c-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64c.svg b/qortal-ui-core/emoji/svg/1f64c.svg new file mode 100644 index 00000000..be95511f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64d-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..3aaba503 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64d-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..24818037 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-1f3fb.svg b/qortal-ui-core/emoji/svg/1f64d-1f3fb.svg new file mode 100644 index 00000000..b694b36b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64d-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..7198a13c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64d-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..80545343 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-1f3fc.svg b/qortal-ui-core/emoji/svg/1f64d-1f3fc.svg new file mode 100644 index 00000000..9d0e546d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64d-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..ed14e028 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64d-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..17dee5c2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-1f3fd.svg b/qortal-ui-core/emoji/svg/1f64d-1f3fd.svg new file mode 100644 index 00000000..ba415fbf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64d-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..47e3da25 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64d-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..a8146a4c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-1f3fe.svg b/qortal-ui-core/emoji/svg/1f64d-1f3fe.svg new file mode 100644 index 00000000..cb7cb69d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64d-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..7e241144 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64d-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..a5f81fe0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-1f3ff.svg b/qortal-ui-core/emoji/svg/1f64d-1f3ff.svg new file mode 100644 index 00000000..b8de1547 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64d-200d-2640-fe0f.svg new file mode 100644 index 00000000..e14fb570 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64d-200d-2642-fe0f.svg new file mode 100644 index 00000000..6a5ce086 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64d.svg b/qortal-ui-core/emoji/svg/1f64d.svg new file mode 100644 index 00000000..0506155c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64e-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..e283e46e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64e-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..8afcbb54 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-1f3fb.svg b/qortal-ui-core/emoji/svg/1f64e-1f3fb.svg new file mode 100644 index 00000000..de107265 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64e-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..6f7d0fe0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64e-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..6c70ec3c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-1f3fc.svg b/qortal-ui-core/emoji/svg/1f64e-1f3fc.svg new file mode 100644 index 00000000..cb76ab3f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64e-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..96584b4a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64e-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..4854c110 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-1f3fd.svg b/qortal-ui-core/emoji/svg/1f64e-1f3fd.svg new file mode 100644 index 00000000..a8acc8cb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64e-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..ab993b07 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64e-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..f1cea099 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-1f3fe.svg b/qortal-ui-core/emoji/svg/1f64e-1f3fe.svg new file mode 100644 index 00000000..8f0366d4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64e-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..5bdbed28 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64e-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..c15298ee --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-1f3ff.svg b/qortal-ui-core/emoji/svg/1f64e-1f3ff.svg new file mode 100644 index 00000000..b13aab77 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f64e-200d-2640-fe0f.svg new file mode 100644 index 00000000..0bd74db6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f64e-200d-2642-fe0f.svg new file mode 100644 index 00000000..97bec5bc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64e.svg b/qortal-ui-core/emoji/svg/1f64e.svg new file mode 100644 index 00000000..bc4da1cc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64f-1f3fb.svg b/qortal-ui-core/emoji/svg/1f64f-1f3fb.svg new file mode 100644 index 00000000..c7b09690 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64f-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64f-1f3fc.svg b/qortal-ui-core/emoji/svg/1f64f-1f3fc.svg new file mode 100644 index 00000000..6dcbad55 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64f-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64f-1f3fd.svg b/qortal-ui-core/emoji/svg/1f64f-1f3fd.svg new file mode 100644 index 00000000..5d11d088 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64f-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64f-1f3fe.svg b/qortal-ui-core/emoji/svg/1f64f-1f3fe.svg new file mode 100644 index 00000000..7026174b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64f-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64f-1f3ff.svg b/qortal-ui-core/emoji/svg/1f64f-1f3ff.svg new file mode 100644 index 00000000..09831e0d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64f-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f64f.svg b/qortal-ui-core/emoji/svg/1f64f.svg new file mode 100644 index 00000000..8b33d80c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f64f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f680.svg b/qortal-ui-core/emoji/svg/1f680.svg new file mode 100644 index 00000000..8658d439 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f681.svg b/qortal-ui-core/emoji/svg/1f681.svg new file mode 100644 index 00000000..8b7a4032 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f681.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f682.svg b/qortal-ui-core/emoji/svg/1f682.svg new file mode 100644 index 00000000..c93874db --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f682.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f683.svg b/qortal-ui-core/emoji/svg/1f683.svg new file mode 100644 index 00000000..775ae86f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f683.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f684.svg b/qortal-ui-core/emoji/svg/1f684.svg new file mode 100644 index 00000000..31e4d69f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f684.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f685.svg b/qortal-ui-core/emoji/svg/1f685.svg new file mode 100644 index 00000000..2b24d9ab --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f685.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f686.svg b/qortal-ui-core/emoji/svg/1f686.svg new file mode 100644 index 00000000..3f5f5b85 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f686.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f687.svg b/qortal-ui-core/emoji/svg/1f687.svg new file mode 100644 index 00000000..acd11bd4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f687.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f688.svg b/qortal-ui-core/emoji/svg/1f688.svg new file mode 100644 index 00000000..160cc71d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f688.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f689.svg b/qortal-ui-core/emoji/svg/1f689.svg new file mode 100644 index 00000000..cebf01dd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f689.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f68a.svg b/qortal-ui-core/emoji/svg/1f68a.svg new file mode 100644 index 00000000..b93eab0a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f68a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f68b.svg b/qortal-ui-core/emoji/svg/1f68b.svg new file mode 100644 index 00000000..da204b81 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f68b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f68c.svg b/qortal-ui-core/emoji/svg/1f68c.svg new file mode 100644 index 00000000..45751690 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f68c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f68d.svg b/qortal-ui-core/emoji/svg/1f68d.svg new file mode 100644 index 00000000..68ca65fa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f68d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f68e.svg b/qortal-ui-core/emoji/svg/1f68e.svg new file mode 100644 index 00000000..e3dc44dc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f68e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f68f.svg b/qortal-ui-core/emoji/svg/1f68f.svg new file mode 100644 index 00000000..f833b4aa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f68f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f690.svg b/qortal-ui-core/emoji/svg/1f690.svg new file mode 100644 index 00000000..d3f10573 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f690.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f691.svg b/qortal-ui-core/emoji/svg/1f691.svg new file mode 100644 index 00000000..844dd40f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f691.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f692.svg b/qortal-ui-core/emoji/svg/1f692.svg new file mode 100644 index 00000000..711c9960 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f693.svg b/qortal-ui-core/emoji/svg/1f693.svg new file mode 100644 index 00000000..cbf344d7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f693.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f694.svg b/qortal-ui-core/emoji/svg/1f694.svg new file mode 100644 index 00000000..ef1662d9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f694.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f695.svg b/qortal-ui-core/emoji/svg/1f695.svg new file mode 100644 index 00000000..5446414a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f695.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f696.svg b/qortal-ui-core/emoji/svg/1f696.svg new file mode 100644 index 00000000..e066a124 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f696.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f697.svg b/qortal-ui-core/emoji/svg/1f697.svg new file mode 100644 index 00000000..97b5f10d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f697.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f698.svg b/qortal-ui-core/emoji/svg/1f698.svg new file mode 100644 index 00000000..25d8df01 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f698.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f699.svg b/qortal-ui-core/emoji/svg/1f699.svg new file mode 100644 index 00000000..28e27719 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f699.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f69a.svg b/qortal-ui-core/emoji/svg/1f69a.svg new file mode 100644 index 00000000..7441d1bb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f69a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f69b.svg b/qortal-ui-core/emoji/svg/1f69b.svg new file mode 100644 index 00000000..271fec11 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f69b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f69c.svg b/qortal-ui-core/emoji/svg/1f69c.svg new file mode 100644 index 00000000..014ca11d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f69c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f69d.svg b/qortal-ui-core/emoji/svg/1f69d.svg new file mode 100644 index 00000000..64ab140c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f69d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f69e.svg b/qortal-ui-core/emoji/svg/1f69e.svg new file mode 100644 index 00000000..79a9320c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f69e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f69f.svg b/qortal-ui-core/emoji/svg/1f69f.svg new file mode 100644 index 00000000..72eac03f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f69f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a0.svg b/qortal-ui-core/emoji/svg/1f6a0.svg new file mode 100644 index 00000000..8510956d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a1.svg b/qortal-ui-core/emoji/svg/1f6a1.svg new file mode 100644 index 00000000..855c5664 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a2.svg b/qortal-ui-core/emoji/svg/1f6a2.svg new file mode 100644 index 00000000..79077f00 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6a3-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..e5c19c94 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6a3-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..a9651dca --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-1f3fb.svg b/qortal-ui-core/emoji/svg/1f6a3-1f3fb.svg new file mode 100644 index 00000000..b8ae875d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6a3-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..a0c9e1ce --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6a3-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..d5d8a1b1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-1f3fc.svg b/qortal-ui-core/emoji/svg/1f6a3-1f3fc.svg new file mode 100644 index 00000000..13cde3cb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6a3-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..16b7ac0b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6a3-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..350a363a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-1f3fd.svg b/qortal-ui-core/emoji/svg/1f6a3-1f3fd.svg new file mode 100644 index 00000000..1861758f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6a3-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..08ab1cce --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6a3-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..58d8d4e8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-1f3fe.svg b/qortal-ui-core/emoji/svg/1f6a3-1f3fe.svg new file mode 100644 index 00000000..8d52d639 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6a3-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..05a2304c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6a3-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..d461a410 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-1f3ff.svg b/qortal-ui-core/emoji/svg/1f6a3-1f3ff.svg new file mode 100644 index 00000000..b93ca918 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6a3-200d-2640-fe0f.svg new file mode 100644 index 00000000..8e0c5adc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6a3-200d-2642-fe0f.svg new file mode 100644 index 00000000..d6282293 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a3.svg b/qortal-ui-core/emoji/svg/1f6a3.svg new file mode 100644 index 00000000..a427ce68 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a4.svg b/qortal-ui-core/emoji/svg/1f6a4.svg new file mode 100644 index 00000000..7dfe5a6b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a5.svg b/qortal-ui-core/emoji/svg/1f6a5.svg new file mode 100644 index 00000000..6cb38271 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a6.svg b/qortal-ui-core/emoji/svg/1f6a6.svg new file mode 100644 index 00000000..252e85cc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a7.svg b/qortal-ui-core/emoji/svg/1f6a7.svg new file mode 100644 index 00000000..a5d135cb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a8.svg b/qortal-ui-core/emoji/svg/1f6a8.svg new file mode 100644 index 00000000..5ed7ec85 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6a9.svg b/qortal-ui-core/emoji/svg/1f6a9.svg new file mode 100644 index 00000000..a9338f19 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6a9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6aa.svg b/qortal-ui-core/emoji/svg/1f6aa.svg new file mode 100644 index 00000000..1542aba5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6aa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6ab.svg b/qortal-ui-core/emoji/svg/1f6ab.svg new file mode 100644 index 00000000..4b913ae5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6ab.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6ac.svg b/qortal-ui-core/emoji/svg/1f6ac.svg new file mode 100644 index 00000000..1c0dff27 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6ac.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6ad.svg b/qortal-ui-core/emoji/svg/1f6ad.svg new file mode 100644 index 00000000..bda285a5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6ad.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6ae.svg b/qortal-ui-core/emoji/svg/1f6ae.svg new file mode 100644 index 00000000..dadbe6ef --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6ae.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6af.svg b/qortal-ui-core/emoji/svg/1f6af.svg new file mode 100644 index 00000000..74fad212 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b0.svg b/qortal-ui-core/emoji/svg/1f6b0.svg new file mode 100644 index 00000000..40f57746 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b1.svg b/qortal-ui-core/emoji/svg/1f6b1.svg new file mode 100644 index 00000000..5d2b5a01 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b2.svg b/qortal-ui-core/emoji/svg/1f6b2.svg new file mode 100644 index 00000000..b3626aee --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b3.svg b/qortal-ui-core/emoji/svg/1f6b3.svg new file mode 100644 index 00000000..ab08b6bb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b4-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..947042da --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b4-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..def3807b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-1f3fb.svg b/qortal-ui-core/emoji/svg/1f6b4-1f3fb.svg new file mode 100644 index 00000000..581a4471 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b4-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..bdabdf85 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b4-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..d163a47c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-1f3fc.svg b/qortal-ui-core/emoji/svg/1f6b4-1f3fc.svg new file mode 100644 index 00000000..565fe9f1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b4-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..c3057143 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b4-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..afc749ad --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-1f3fd.svg b/qortal-ui-core/emoji/svg/1f6b4-1f3fd.svg new file mode 100644 index 00000000..5a980097 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b4-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..fa310bfb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b4-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..55178951 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-1f3fe.svg b/qortal-ui-core/emoji/svg/1f6b4-1f3fe.svg new file mode 100644 index 00000000..2a22bf01 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b4-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..25c02de2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b4-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..c06f3593 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-1f3ff.svg b/qortal-ui-core/emoji/svg/1f6b4-1f3ff.svg new file mode 100644 index 00000000..c62512e5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b4-200d-2640-fe0f.svg new file mode 100644 index 00000000..4ecaf724 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b4-200d-2642-fe0f.svg new file mode 100644 index 00000000..ae3112ed --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b4.svg b/qortal-ui-core/emoji/svg/1f6b4.svg new file mode 100644 index 00000000..f1bbb724 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b5-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..b203db44 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b5-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..63627abc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-1f3fb.svg b/qortal-ui-core/emoji/svg/1f6b5-1f3fb.svg new file mode 100644 index 00000000..10e9b635 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b5-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..e94e02ef --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b5-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..e629c6cf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-1f3fc.svg b/qortal-ui-core/emoji/svg/1f6b5-1f3fc.svg new file mode 100644 index 00000000..202bc22e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b5-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..79bf2041 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b5-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..c1e95693 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-1f3fd.svg b/qortal-ui-core/emoji/svg/1f6b5-1f3fd.svg new file mode 100644 index 00000000..947c5460 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b5-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..e0b6d224 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b5-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..55a8b20b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-1f3fe.svg b/qortal-ui-core/emoji/svg/1f6b5-1f3fe.svg new file mode 100644 index 00000000..99154e4f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b5-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..17a39310 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b5-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..c856c95b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-1f3ff.svg b/qortal-ui-core/emoji/svg/1f6b5-1f3ff.svg new file mode 100644 index 00000000..9e98fb46 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b5-200d-2640-fe0f.svg new file mode 100644 index 00000000..aaf71dca --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b5-200d-2642-fe0f.svg new file mode 100644 index 00000000..99143083 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b5.svg b/qortal-ui-core/emoji/svg/1f6b5.svg new file mode 100644 index 00000000..fb824d58 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b6-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..396c56b4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b6-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..8f5f4ce2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-1f3fb.svg b/qortal-ui-core/emoji/svg/1f6b6-1f3fb.svg new file mode 100644 index 00000000..e361a286 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b6-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..571d8f0f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b6-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..cba51a41 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-1f3fc.svg b/qortal-ui-core/emoji/svg/1f6b6-1f3fc.svg new file mode 100644 index 00000000..ff5f7045 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b6-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..65a6df4d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b6-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..84169ed7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-1f3fd.svg b/qortal-ui-core/emoji/svg/1f6b6-1f3fd.svg new file mode 100644 index 00000000..1862ab31 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b6-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..352e7af5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b6-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..591c5622 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-1f3fe.svg b/qortal-ui-core/emoji/svg/1f6b6-1f3fe.svg new file mode 100644 index 00000000..b6476fef --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b6-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..ae7e4143 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b6-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..198a8377 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-1f3ff.svg b/qortal-ui-core/emoji/svg/1f6b6-1f3ff.svg new file mode 100644 index 00000000..d410eb39 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b6-200d-2640-fe0f.svg new file mode 100644 index 00000000..8e187bfa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f6b6-200d-2642-fe0f.svg new file mode 100644 index 00000000..9217939d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b6.svg b/qortal-ui-core/emoji/svg/1f6b6.svg new file mode 100644 index 00000000..124c2967 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b7.svg b/qortal-ui-core/emoji/svg/1f6b7.svg new file mode 100644 index 00000000..ebe039fa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b8.svg b/qortal-ui-core/emoji/svg/1f6b8.svg new file mode 100644 index 00000000..a9dca0f9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6b9.svg b/qortal-ui-core/emoji/svg/1f6b9.svg new file mode 100644 index 00000000..2f7a492d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6b9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6ba.svg b/qortal-ui-core/emoji/svg/1f6ba.svg new file mode 100644 index 00000000..d73ed94b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6ba.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6bb.svg b/qortal-ui-core/emoji/svg/1f6bb.svg new file mode 100644 index 00000000..0ecbb535 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6bc.svg b/qortal-ui-core/emoji/svg/1f6bc.svg new file mode 100644 index 00000000..300b10e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6bd.svg b/qortal-ui-core/emoji/svg/1f6bd.svg new file mode 100644 index 00000000..24634484 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6be.svg b/qortal-ui-core/emoji/svg/1f6be.svg new file mode 100644 index 00000000..aad724c3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6be.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6bf.svg b/qortal-ui-core/emoji/svg/1f6bf.svg new file mode 100644 index 00000000..004dadf7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6bf.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6c0-1f3fb.svg b/qortal-ui-core/emoji/svg/1f6c0-1f3fb.svg new file mode 100644 index 00000000..ad93c8c6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6c0-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6c0-1f3fc.svg b/qortal-ui-core/emoji/svg/1f6c0-1f3fc.svg new file mode 100644 index 00000000..4f1e2fa1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6c0-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6c0-1f3fd.svg b/qortal-ui-core/emoji/svg/1f6c0-1f3fd.svg new file mode 100644 index 00000000..55b04599 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6c0-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6c0-1f3fe.svg b/qortal-ui-core/emoji/svg/1f6c0-1f3fe.svg new file mode 100644 index 00000000..d7e88365 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6c0-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6c0-1f3ff.svg b/qortal-ui-core/emoji/svg/1f6c0-1f3ff.svg new file mode 100644 index 00000000..b667e460 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6c0-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6c0.svg b/qortal-ui-core/emoji/svg/1f6c0.svg new file mode 100644 index 00000000..1ccfa208 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6c0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6c1.svg b/qortal-ui-core/emoji/svg/1f6c1.svg new file mode 100644 index 00000000..399bd44b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6c1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6c2.svg b/qortal-ui-core/emoji/svg/1f6c2.svg new file mode 100644 index 00000000..2e9dfdf7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6c2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6c3.svg b/qortal-ui-core/emoji/svg/1f6c3.svg new file mode 100644 index 00000000..9e58a3be --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6c3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6c4.svg b/qortal-ui-core/emoji/svg/1f6c4.svg new file mode 100644 index 00000000..63edd5a1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6c4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6c5.svg b/qortal-ui-core/emoji/svg/1f6c5.svg new file mode 100644 index 00000000..f67135d5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6c5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6cb.svg b/qortal-ui-core/emoji/svg/1f6cb.svg new file mode 100644 index 00000000..c80d190d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6cb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6cc-1f3fb.svg b/qortal-ui-core/emoji/svg/1f6cc-1f3fb.svg new file mode 100644 index 00000000..6a96af59 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6cc-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6cc-1f3fc.svg b/qortal-ui-core/emoji/svg/1f6cc-1f3fc.svg new file mode 100644 index 00000000..3578121b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6cc-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6cc-1f3fd.svg b/qortal-ui-core/emoji/svg/1f6cc-1f3fd.svg new file mode 100644 index 00000000..e16d51cb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6cc-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6cc-1f3fe.svg b/qortal-ui-core/emoji/svg/1f6cc-1f3fe.svg new file mode 100644 index 00000000..ea3403bd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6cc-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6cc-1f3ff.svg b/qortal-ui-core/emoji/svg/1f6cc-1f3ff.svg new file mode 100644 index 00000000..82d72558 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6cc-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6cc.svg b/qortal-ui-core/emoji/svg/1f6cc.svg new file mode 100644 index 00000000..183ccf0e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6cc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6cd.svg b/qortal-ui-core/emoji/svg/1f6cd.svg new file mode 100644 index 00000000..e2ae9167 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6cd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6ce.svg b/qortal-ui-core/emoji/svg/1f6ce.svg new file mode 100644 index 00000000..80343b63 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6ce.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6cf.svg b/qortal-ui-core/emoji/svg/1f6cf.svg new file mode 100644 index 00000000..9c34ec0e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6cf.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6d0.svg b/qortal-ui-core/emoji/svg/1f6d0.svg new file mode 100644 index 00000000..086e273c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6d0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6d1.svg b/qortal-ui-core/emoji/svg/1f6d1.svg new file mode 100644 index 00000000..c8eb021b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6d1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6d2.svg b/qortal-ui-core/emoji/svg/1f6d2.svg new file mode 100644 index 00000000..03608d5f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6d2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6d5.svg b/qortal-ui-core/emoji/svg/1f6d5.svg new file mode 100644 index 00000000..4a2e9be2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6d5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6d6.svg b/qortal-ui-core/emoji/svg/1f6d6.svg new file mode 100644 index 00000000..b2866e07 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6d6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6d7.svg b/qortal-ui-core/emoji/svg/1f6d7.svg new file mode 100644 index 00000000..5369e579 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6d7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6e0.svg b/qortal-ui-core/emoji/svg/1f6e0.svg new file mode 100644 index 00000000..085f9025 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6e0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6e1.svg b/qortal-ui-core/emoji/svg/1f6e1.svg new file mode 100644 index 00000000..97f68942 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6e1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6e2.svg b/qortal-ui-core/emoji/svg/1f6e2.svg new file mode 100644 index 00000000..b7f9cc61 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6e2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6e3.svg b/qortal-ui-core/emoji/svg/1f6e3.svg new file mode 100644 index 00000000..35e82158 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6e4.svg b/qortal-ui-core/emoji/svg/1f6e4.svg new file mode 100644 index 00000000..f11069e8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6e4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6e5.svg b/qortal-ui-core/emoji/svg/1f6e5.svg new file mode 100644 index 00000000..b9badb2e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6e5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6e9.svg b/qortal-ui-core/emoji/svg/1f6e9.svg new file mode 100644 index 00000000..fce6b511 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6eb.svg b/qortal-ui-core/emoji/svg/1f6eb.svg new file mode 100644 index 00000000..7bcbb8c9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6ec.svg b/qortal-ui-core/emoji/svg/1f6ec.svg new file mode 100644 index 00000000..ee10becd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6f0.svg b/qortal-ui-core/emoji/svg/1f6f0.svg new file mode 100644 index 00000000..6d9bb3d2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6f3.svg b/qortal-ui-core/emoji/svg/1f6f3.svg new file mode 100644 index 00000000..44862135 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6f4.svg b/qortal-ui-core/emoji/svg/1f6f4.svg new file mode 100644 index 00000000..e217dc43 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6f5.svg b/qortal-ui-core/emoji/svg/1f6f5.svg new file mode 100644 index 00000000..a1e0f4b9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6f5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6f6.svg b/qortal-ui-core/emoji/svg/1f6f6.svg new file mode 100644 index 00000000..b6a21652 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6f6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6f7.svg b/qortal-ui-core/emoji/svg/1f6f7.svg new file mode 100644 index 00000000..12d776db --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6f8.svg b/qortal-ui-core/emoji/svg/1f6f8.svg new file mode 100644 index 00000000..5f015fe7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6f9.svg b/qortal-ui-core/emoji/svg/1f6f9.svg new file mode 100644 index 00000000..1ee4bfec --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6fa.svg b/qortal-ui-core/emoji/svg/1f6fa.svg new file mode 100644 index 00000000..aae4e94a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6fb.svg b/qortal-ui-core/emoji/svg/1f6fb.svg new file mode 100644 index 00000000..87643ae9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f6fc.svg b/qortal-ui-core/emoji/svg/1f6fc.svg new file mode 100644 index 00000000..091d51ef --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f6fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f7e0.svg b/qortal-ui-core/emoji/svg/1f7e0.svg new file mode 100644 index 00000000..f5e12007 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f7e0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f7e1.svg b/qortal-ui-core/emoji/svg/1f7e1.svg new file mode 100644 index 00000000..5c05d438 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f7e1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f7e2.svg b/qortal-ui-core/emoji/svg/1f7e2.svg new file mode 100644 index 00000000..3e68a3fb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f7e2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f7e3.svg b/qortal-ui-core/emoji/svg/1f7e3.svg new file mode 100644 index 00000000..8a034cab --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f7e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f7e4.svg b/qortal-ui-core/emoji/svg/1f7e4.svg new file mode 100644 index 00000000..ebbc3a73 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f7e4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f7e5.svg b/qortal-ui-core/emoji/svg/1f7e5.svg new file mode 100644 index 00000000..5326d657 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f7e5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f7e6.svg b/qortal-ui-core/emoji/svg/1f7e6.svg new file mode 100644 index 00000000..08242260 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f7e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f7e7.svg b/qortal-ui-core/emoji/svg/1f7e7.svg new file mode 100644 index 00000000..1377a4eb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f7e7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f7e8.svg b/qortal-ui-core/emoji/svg/1f7e8.svg new file mode 100644 index 00000000..64795b1f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f7e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f7e9.svg b/qortal-ui-core/emoji/svg/1f7e9.svg new file mode 100644 index 00000000..73ed4fa4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f7e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f7ea.svg b/qortal-ui-core/emoji/svg/1f7ea.svg new file mode 100644 index 00000000..c331b1f7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f7ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f7eb.svg b/qortal-ui-core/emoji/svg/1f7eb.svg new file mode 100644 index 00000000..24ee9827 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f7eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f90c-1f3fb.svg b/qortal-ui-core/emoji/svg/1f90c-1f3fb.svg new file mode 100644 index 00000000..8af45213 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f90c-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f90c-1f3fc.svg b/qortal-ui-core/emoji/svg/1f90c-1f3fc.svg new file mode 100644 index 00000000..7cee5bd5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f90c-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f90c-1f3fd.svg b/qortal-ui-core/emoji/svg/1f90c-1f3fd.svg new file mode 100644 index 00000000..2898fe39 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f90c-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f90c-1f3fe.svg b/qortal-ui-core/emoji/svg/1f90c-1f3fe.svg new file mode 100644 index 00000000..2e706ba4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f90c-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f90c-1f3ff.svg b/qortal-ui-core/emoji/svg/1f90c-1f3ff.svg new file mode 100644 index 00000000..e17d4b09 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f90c-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f90c.svg b/qortal-ui-core/emoji/svg/1f90c.svg new file mode 100644 index 00000000..56b40f34 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f90c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f90d.svg b/qortal-ui-core/emoji/svg/1f90d.svg new file mode 100644 index 00000000..7deb0cd7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f90d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f90e.svg b/qortal-ui-core/emoji/svg/1f90e.svg new file mode 100644 index 00000000..275f3c98 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f90e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f90f-1f3fb.svg b/qortal-ui-core/emoji/svg/1f90f-1f3fb.svg new file mode 100644 index 00000000..a14c9074 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f90f-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f90f-1f3fc.svg b/qortal-ui-core/emoji/svg/1f90f-1f3fc.svg new file mode 100644 index 00000000..8f109cde --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f90f-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f90f-1f3fd.svg b/qortal-ui-core/emoji/svg/1f90f-1f3fd.svg new file mode 100644 index 00000000..0e9b3e62 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f90f-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f90f-1f3fe.svg b/qortal-ui-core/emoji/svg/1f90f-1f3fe.svg new file mode 100644 index 00000000..07ccb2b6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f90f-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f90f-1f3ff.svg b/qortal-ui-core/emoji/svg/1f90f-1f3ff.svg new file mode 100644 index 00000000..78893d0e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f90f-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f90f.svg b/qortal-ui-core/emoji/svg/1f90f.svg new file mode 100644 index 00000000..626e3b5f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f90f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f910.svg b/qortal-ui-core/emoji/svg/1f910.svg new file mode 100644 index 00000000..873621f3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f910.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f911.svg b/qortal-ui-core/emoji/svg/1f911.svg new file mode 100644 index 00000000..5616de71 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f911.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f912.svg b/qortal-ui-core/emoji/svg/1f912.svg new file mode 100644 index 00000000..b6ac0a98 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f912.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f913.svg b/qortal-ui-core/emoji/svg/1f913.svg new file mode 100644 index 00000000..d430a684 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f913.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f914.svg b/qortal-ui-core/emoji/svg/1f914.svg new file mode 100644 index 00000000..4e8c4cc2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f914.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f915.svg b/qortal-ui-core/emoji/svg/1f915.svg new file mode 100644 index 00000000..fce67fc5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f915.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f916.svg b/qortal-ui-core/emoji/svg/1f916.svg new file mode 100644 index 00000000..1dbe6d68 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f916.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f917.svg b/qortal-ui-core/emoji/svg/1f917.svg new file mode 100644 index 00000000..13416754 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f917.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f918-1f3fb.svg b/qortal-ui-core/emoji/svg/1f918-1f3fb.svg new file mode 100644 index 00000000..56fa28a5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f918-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f918-1f3fc.svg b/qortal-ui-core/emoji/svg/1f918-1f3fc.svg new file mode 100644 index 00000000..bae1401c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f918-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f918-1f3fd.svg b/qortal-ui-core/emoji/svg/1f918-1f3fd.svg new file mode 100644 index 00000000..98ebab08 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f918-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f918-1f3fe.svg b/qortal-ui-core/emoji/svg/1f918-1f3fe.svg new file mode 100644 index 00000000..873cef08 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f918-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f918-1f3ff.svg b/qortal-ui-core/emoji/svg/1f918-1f3ff.svg new file mode 100644 index 00000000..052adbb6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f918-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f918.svg b/qortal-ui-core/emoji/svg/1f918.svg new file mode 100644 index 00000000..c3a10630 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f918.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f919-1f3fb.svg b/qortal-ui-core/emoji/svg/1f919-1f3fb.svg new file mode 100644 index 00000000..1a9691f9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f919-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f919-1f3fc.svg b/qortal-ui-core/emoji/svg/1f919-1f3fc.svg new file mode 100644 index 00000000..add5b47b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f919-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f919-1f3fd.svg b/qortal-ui-core/emoji/svg/1f919-1f3fd.svg new file mode 100644 index 00000000..993c6f77 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f919-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f919-1f3fe.svg b/qortal-ui-core/emoji/svg/1f919-1f3fe.svg new file mode 100644 index 00000000..a433b38b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f919-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f919-1f3ff.svg b/qortal-ui-core/emoji/svg/1f919-1f3ff.svg new file mode 100644 index 00000000..226cd45d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f919-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f919.svg b/qortal-ui-core/emoji/svg/1f919.svg new file mode 100644 index 00000000..4ab04541 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f919.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91a-1f3fb.svg b/qortal-ui-core/emoji/svg/1f91a-1f3fb.svg new file mode 100644 index 00000000..646618e6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91a-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91a-1f3fc.svg b/qortal-ui-core/emoji/svg/1f91a-1f3fc.svg new file mode 100644 index 00000000..4b5f9839 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91a-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91a-1f3fd.svg b/qortal-ui-core/emoji/svg/1f91a-1f3fd.svg new file mode 100644 index 00000000..6d85626e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91a-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91a-1f3fe.svg b/qortal-ui-core/emoji/svg/1f91a-1f3fe.svg new file mode 100644 index 00000000..cc36a248 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91a-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91a-1f3ff.svg b/qortal-ui-core/emoji/svg/1f91a-1f3ff.svg new file mode 100644 index 00000000..1345e971 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91a-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91a.svg b/qortal-ui-core/emoji/svg/1f91a.svg new file mode 100644 index 00000000..a3d2b1c9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91b-1f3fb.svg b/qortal-ui-core/emoji/svg/1f91b-1f3fb.svg new file mode 100644 index 00000000..1deb10c5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91b-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91b-1f3fc.svg b/qortal-ui-core/emoji/svg/1f91b-1f3fc.svg new file mode 100644 index 00000000..7edf532b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91b-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91b-1f3fd.svg b/qortal-ui-core/emoji/svg/1f91b-1f3fd.svg new file mode 100644 index 00000000..d98a536c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91b-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91b-1f3fe.svg b/qortal-ui-core/emoji/svg/1f91b-1f3fe.svg new file mode 100644 index 00000000..e48b751a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91b-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91b-1f3ff.svg b/qortal-ui-core/emoji/svg/1f91b-1f3ff.svg new file mode 100644 index 00000000..3998353b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91b-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91b.svg b/qortal-ui-core/emoji/svg/1f91b.svg new file mode 100644 index 00000000..a5a142b5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91c-1f3fb.svg b/qortal-ui-core/emoji/svg/1f91c-1f3fb.svg new file mode 100644 index 00000000..ff817fd7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91c-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91c-1f3fc.svg b/qortal-ui-core/emoji/svg/1f91c-1f3fc.svg new file mode 100644 index 00000000..732af9c0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91c-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91c-1f3fd.svg b/qortal-ui-core/emoji/svg/1f91c-1f3fd.svg new file mode 100644 index 00000000..79ed35f0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91c-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91c-1f3fe.svg b/qortal-ui-core/emoji/svg/1f91c-1f3fe.svg new file mode 100644 index 00000000..948472fc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91c-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91c-1f3ff.svg b/qortal-ui-core/emoji/svg/1f91c-1f3ff.svg new file mode 100644 index 00000000..eb89c3a8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91c-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91c.svg b/qortal-ui-core/emoji/svg/1f91c.svg new file mode 100644 index 00000000..afaa803b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91d.svg b/qortal-ui-core/emoji/svg/1f91d.svg new file mode 100644 index 00000000..3d797a08 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91e-1f3fb.svg b/qortal-ui-core/emoji/svg/1f91e-1f3fb.svg new file mode 100644 index 00000000..30a387d3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91e-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91e-1f3fc.svg b/qortal-ui-core/emoji/svg/1f91e-1f3fc.svg new file mode 100644 index 00000000..ec2fa508 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91e-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91e-1f3fd.svg b/qortal-ui-core/emoji/svg/1f91e-1f3fd.svg new file mode 100644 index 00000000..b17f2690 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91e-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91e-1f3fe.svg b/qortal-ui-core/emoji/svg/1f91e-1f3fe.svg new file mode 100644 index 00000000..28cbb788 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91e-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91e-1f3ff.svg b/qortal-ui-core/emoji/svg/1f91e-1f3ff.svg new file mode 100644 index 00000000..86e91b2a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91e-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91e.svg b/qortal-ui-core/emoji/svg/1f91e.svg new file mode 100644 index 00000000..f85ba652 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91f-1f3fb.svg b/qortal-ui-core/emoji/svg/1f91f-1f3fb.svg new file mode 100644 index 00000000..aa262319 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91f-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91f-1f3fc.svg b/qortal-ui-core/emoji/svg/1f91f-1f3fc.svg new file mode 100644 index 00000000..13e4bac5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91f-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91f-1f3fd.svg b/qortal-ui-core/emoji/svg/1f91f-1f3fd.svg new file mode 100644 index 00000000..274170b9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91f-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91f-1f3fe.svg b/qortal-ui-core/emoji/svg/1f91f-1f3fe.svg new file mode 100644 index 00000000..f4f18d8d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91f-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91f-1f3ff.svg b/qortal-ui-core/emoji/svg/1f91f-1f3ff.svg new file mode 100644 index 00000000..d2f5581f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91f-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f91f.svg b/qortal-ui-core/emoji/svg/1f91f.svg new file mode 100644 index 00000000..4f3d74f0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f91f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f920.svg b/qortal-ui-core/emoji/svg/1f920.svg new file mode 100644 index 00000000..da7cfa26 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f920.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f921.svg b/qortal-ui-core/emoji/svg/1f921.svg new file mode 100644 index 00000000..6d16a662 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f921.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f922.svg b/qortal-ui-core/emoji/svg/1f922.svg new file mode 100644 index 00000000..ed7c86c0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f922.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f923.svg b/qortal-ui-core/emoji/svg/1f923.svg new file mode 100644 index 00000000..7ddfcae3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f923.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f924.svg b/qortal-ui-core/emoji/svg/1f924.svg new file mode 100644 index 00000000..9af71fc9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f924.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f925.svg b/qortal-ui-core/emoji/svg/1f925.svg new file mode 100644 index 00000000..9f255307 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f925.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f926-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..01f59a19 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f926-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..90f06b3e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-1f3fb.svg b/qortal-ui-core/emoji/svg/1f926-1f3fb.svg new file mode 100644 index 00000000..80e07bb5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f926-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..a479826f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f926-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..ea55c5ad --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-1f3fc.svg b/qortal-ui-core/emoji/svg/1f926-1f3fc.svg new file mode 100644 index 00000000..227838db --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f926-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..ece26ca0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f926-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..5df9aa23 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-1f3fd.svg b/qortal-ui-core/emoji/svg/1f926-1f3fd.svg new file mode 100644 index 00000000..7ef592b7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f926-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..8e677c49 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f926-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..df48aee7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-1f3fe.svg b/qortal-ui-core/emoji/svg/1f926-1f3fe.svg new file mode 100644 index 00000000..caf3e782 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f926-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..c5a86035 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f926-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..e19ae754 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-1f3ff.svg b/qortal-ui-core/emoji/svg/1f926-1f3ff.svg new file mode 100644 index 00000000..e3f244a8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f926-200d-2640-fe0f.svg new file mode 100644 index 00000000..a31d72bd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f926-200d-2642-fe0f.svg new file mode 100644 index 00000000..29cbd0bb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f926.svg b/qortal-ui-core/emoji/svg/1f926.svg new file mode 100644 index 00000000..631e91c3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f926.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f927.svg b/qortal-ui-core/emoji/svg/1f927.svg new file mode 100644 index 00000000..dc86ab35 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f927.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f928.svg b/qortal-ui-core/emoji/svg/1f928.svg new file mode 100644 index 00000000..126e459b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f928.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f929.svg b/qortal-ui-core/emoji/svg/1f929.svg new file mode 100644 index 00000000..260cd80a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f929.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f92a.svg b/qortal-ui-core/emoji/svg/1f92a.svg new file mode 100644 index 00000000..baf58f21 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f92a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f92b.svg b/qortal-ui-core/emoji/svg/1f92b.svg new file mode 100644 index 00000000..a00edc96 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f92b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f92c.svg b/qortal-ui-core/emoji/svg/1f92c.svg new file mode 100644 index 00000000..c26a5aa4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f92c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f92d.svg b/qortal-ui-core/emoji/svg/1f92d.svg new file mode 100644 index 00000000..b79e0673 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f92d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f92e.svg b/qortal-ui-core/emoji/svg/1f92e.svg new file mode 100644 index 00000000..d792679f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f92e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f92f.svg b/qortal-ui-core/emoji/svg/1f92f.svg new file mode 100644 index 00000000..3ac19ed4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f92f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f930-1f3fb.svg b/qortal-ui-core/emoji/svg/1f930-1f3fb.svg new file mode 100644 index 00000000..925d1e45 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f930-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f930-1f3fc.svg b/qortal-ui-core/emoji/svg/1f930-1f3fc.svg new file mode 100644 index 00000000..e308ef95 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f930-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f930-1f3fd.svg b/qortal-ui-core/emoji/svg/1f930-1f3fd.svg new file mode 100644 index 00000000..39d55f47 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f930-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f930-1f3fe.svg b/qortal-ui-core/emoji/svg/1f930-1f3fe.svg new file mode 100644 index 00000000..ee049b84 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f930-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f930-1f3ff.svg b/qortal-ui-core/emoji/svg/1f930-1f3ff.svg new file mode 100644 index 00000000..607d72eb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f930-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f930.svg b/qortal-ui-core/emoji/svg/1f930.svg new file mode 100644 index 00000000..31a93772 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f930.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f931-1f3fb.svg b/qortal-ui-core/emoji/svg/1f931-1f3fb.svg new file mode 100644 index 00000000..e4815f2a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f931-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f931-1f3fc.svg b/qortal-ui-core/emoji/svg/1f931-1f3fc.svg new file mode 100644 index 00000000..c02ddc31 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f931-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f931-1f3fd.svg b/qortal-ui-core/emoji/svg/1f931-1f3fd.svg new file mode 100644 index 00000000..fc4150b9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f931-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f931-1f3fe.svg b/qortal-ui-core/emoji/svg/1f931-1f3fe.svg new file mode 100644 index 00000000..7cd0602f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f931-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f931-1f3ff.svg b/qortal-ui-core/emoji/svg/1f931-1f3ff.svg new file mode 100644 index 00000000..6ea48e4c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f931-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f931.svg b/qortal-ui-core/emoji/svg/1f931.svg new file mode 100644 index 00000000..86dc551c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f931.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f932-1f3fb.svg b/qortal-ui-core/emoji/svg/1f932-1f3fb.svg new file mode 100644 index 00000000..c1d616ec --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f932-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f932-1f3fc.svg b/qortal-ui-core/emoji/svg/1f932-1f3fc.svg new file mode 100644 index 00000000..ee95f09b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f932-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f932-1f3fd.svg b/qortal-ui-core/emoji/svg/1f932-1f3fd.svg new file mode 100644 index 00000000..78d13a06 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f932-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f932-1f3fe.svg b/qortal-ui-core/emoji/svg/1f932-1f3fe.svg new file mode 100644 index 00000000..4a22a200 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f932-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f932-1f3ff.svg b/qortal-ui-core/emoji/svg/1f932-1f3ff.svg new file mode 100644 index 00000000..2cd1f7d7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f932-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f932.svg b/qortal-ui-core/emoji/svg/1f932.svg new file mode 100644 index 00000000..96b6c65c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f932.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f933-1f3fb.svg b/qortal-ui-core/emoji/svg/1f933-1f3fb.svg new file mode 100644 index 00000000..066c2a83 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f933-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f933-1f3fc.svg b/qortal-ui-core/emoji/svg/1f933-1f3fc.svg new file mode 100644 index 00000000..6722d158 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f933-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f933-1f3fd.svg b/qortal-ui-core/emoji/svg/1f933-1f3fd.svg new file mode 100644 index 00000000..b3f2bd5a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f933-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f933-1f3fe.svg b/qortal-ui-core/emoji/svg/1f933-1f3fe.svg new file mode 100644 index 00000000..f95578a6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f933-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f933-1f3ff.svg b/qortal-ui-core/emoji/svg/1f933-1f3ff.svg new file mode 100644 index 00000000..1cad7851 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f933-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f933.svg b/qortal-ui-core/emoji/svg/1f933.svg new file mode 100644 index 00000000..88382e13 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f933.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f934-1f3fb.svg b/qortal-ui-core/emoji/svg/1f934-1f3fb.svg new file mode 100644 index 00000000..eaa8fb27 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f934-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f934-1f3fc.svg b/qortal-ui-core/emoji/svg/1f934-1f3fc.svg new file mode 100644 index 00000000..5feff0ac --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f934-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f934-1f3fd.svg b/qortal-ui-core/emoji/svg/1f934-1f3fd.svg new file mode 100644 index 00000000..04db0c91 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f934-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f934-1f3fe.svg b/qortal-ui-core/emoji/svg/1f934-1f3fe.svg new file mode 100644 index 00000000..a26398fa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f934-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f934-1f3ff.svg b/qortal-ui-core/emoji/svg/1f934-1f3ff.svg new file mode 100644 index 00000000..ad40c9d5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f934-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f934.svg b/qortal-ui-core/emoji/svg/1f934.svg new file mode 100644 index 00000000..666ac38c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f934.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f935-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..d0e7ba4e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f935-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..abd68b8f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-1f3fb.svg b/qortal-ui-core/emoji/svg/1f935-1f3fb.svg new file mode 100644 index 00000000..0994b27a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f935-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..5b10171c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f935-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..f7093beb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-1f3fc.svg b/qortal-ui-core/emoji/svg/1f935-1f3fc.svg new file mode 100644 index 00000000..a674ce96 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f935-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..35d0ab5d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f935-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..5ed3aa32 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-1f3fd.svg b/qortal-ui-core/emoji/svg/1f935-1f3fd.svg new file mode 100644 index 00000000..af123557 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f935-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..5b062360 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f935-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..6ed7fb36 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-1f3fe.svg b/qortal-ui-core/emoji/svg/1f935-1f3fe.svg new file mode 100644 index 00000000..3e69b42c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f935-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..70f6517f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f935-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..3af34ef2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-1f3ff.svg b/qortal-ui-core/emoji/svg/1f935-1f3ff.svg new file mode 100644 index 00000000..3df4f27f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f935-200d-2640-fe0f.svg new file mode 100644 index 00000000..63ef4c95 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f935-200d-2642-fe0f.svg new file mode 100644 index 00000000..5c87be48 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f935.svg b/qortal-ui-core/emoji/svg/1f935.svg new file mode 100644 index 00000000..5b0498b1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f935.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f936-1f3fb.svg b/qortal-ui-core/emoji/svg/1f936-1f3fb.svg new file mode 100644 index 00000000..0227456d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f936-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f936-1f3fc.svg b/qortal-ui-core/emoji/svg/1f936-1f3fc.svg new file mode 100644 index 00000000..5887d75e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f936-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f936-1f3fd.svg b/qortal-ui-core/emoji/svg/1f936-1f3fd.svg new file mode 100644 index 00000000..3e1853d2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f936-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f936-1f3fe.svg b/qortal-ui-core/emoji/svg/1f936-1f3fe.svg new file mode 100644 index 00000000..6d94d270 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f936-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f936-1f3ff.svg b/qortal-ui-core/emoji/svg/1f936-1f3ff.svg new file mode 100644 index 00000000..2178a33c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f936-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f936.svg b/qortal-ui-core/emoji/svg/1f936.svg new file mode 100644 index 00000000..6cabe582 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f936.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f937-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..1c60fc38 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f937-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..0a92c44a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-1f3fb.svg b/qortal-ui-core/emoji/svg/1f937-1f3fb.svg new file mode 100644 index 00000000..b44ceefc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f937-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..af1de040 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f937-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..b8791a96 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-1f3fc.svg b/qortal-ui-core/emoji/svg/1f937-1f3fc.svg new file mode 100644 index 00000000..dc703ebd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f937-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..1e7109af --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f937-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..48de9945 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-1f3fd.svg b/qortal-ui-core/emoji/svg/1f937-1f3fd.svg new file mode 100644 index 00000000..9037d4e2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f937-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..b5731d5e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f937-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..1ce63b9e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-1f3fe.svg b/qortal-ui-core/emoji/svg/1f937-1f3fe.svg new file mode 100644 index 00000000..36763bb0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f937-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..2400a4e7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f937-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..534538c2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-1f3ff.svg b/qortal-ui-core/emoji/svg/1f937-1f3ff.svg new file mode 100644 index 00000000..e39f0707 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f937-200d-2640-fe0f.svg new file mode 100644 index 00000000..f78db073 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f937-200d-2642-fe0f.svg new file mode 100644 index 00000000..29d7e1ef --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f937.svg b/qortal-ui-core/emoji/svg/1f937.svg new file mode 100644 index 00000000..d5984aa1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f937.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f938-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..c5a0d1e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f938-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..24576655 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-1f3fb.svg b/qortal-ui-core/emoji/svg/1f938-1f3fb.svg new file mode 100644 index 00000000..aeb71a86 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f938-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..15b2df73 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f938-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..32a69385 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-1f3fc.svg b/qortal-ui-core/emoji/svg/1f938-1f3fc.svg new file mode 100644 index 00000000..99b46eac --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f938-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..58447e65 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f938-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..bb9f50ce --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-1f3fd.svg b/qortal-ui-core/emoji/svg/1f938-1f3fd.svg new file mode 100644 index 00000000..fb0e2798 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f938-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..b17fdb44 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f938-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..cce9c90e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-1f3fe.svg b/qortal-ui-core/emoji/svg/1f938-1f3fe.svg new file mode 100644 index 00000000..41abefee --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f938-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..076b69d9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f938-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..4f61ec9e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-1f3ff.svg b/qortal-ui-core/emoji/svg/1f938-1f3ff.svg new file mode 100644 index 00000000..52eb41e8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f938-200d-2640-fe0f.svg new file mode 100644 index 00000000..9cec3f99 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f938-200d-2642-fe0f.svg new file mode 100644 index 00000000..7aa23feb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f938.svg b/qortal-ui-core/emoji/svg/1f938.svg new file mode 100644 index 00000000..aaf5b18d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f938.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f939-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..e6cda1aa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f939-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..8b7579bf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-1f3fb.svg b/qortal-ui-core/emoji/svg/1f939-1f3fb.svg new file mode 100644 index 00000000..b794735d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f939-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..511b808e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f939-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..11006e21 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-1f3fc.svg b/qortal-ui-core/emoji/svg/1f939-1f3fc.svg new file mode 100644 index 00000000..1bc4dba9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f939-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..cada29fe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f939-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..98b3b798 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-1f3fd.svg b/qortal-ui-core/emoji/svg/1f939-1f3fd.svg new file mode 100644 index 00000000..fe7c94fc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f939-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..7ecc0913 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f939-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..dd367057 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-1f3fe.svg b/qortal-ui-core/emoji/svg/1f939-1f3fe.svg new file mode 100644 index 00000000..5bd7d053 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f939-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..87bf7e09 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f939-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..ab10e892 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-1f3ff.svg b/qortal-ui-core/emoji/svg/1f939-1f3ff.svg new file mode 100644 index 00000000..43016b27 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f939-200d-2640-fe0f.svg new file mode 100644 index 00000000..0e3e5e4d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f939-200d-2642-fe0f.svg new file mode 100644 index 00000000..62230dc4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f939.svg b/qortal-ui-core/emoji/svg/1f939.svg new file mode 100644 index 00000000..d79aad75 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f939.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93a.svg b/qortal-ui-core/emoji/svg/1f93a.svg new file mode 100644 index 00000000..5cfb388e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93c-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f93c-200d-2640-fe0f.svg new file mode 100644 index 00000000..9abd8337 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93c-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93c-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f93c-200d-2642-fe0f.svg new file mode 100644 index 00000000..13ec50b4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93c-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93c.svg b/qortal-ui-core/emoji/svg/1f93c.svg new file mode 100644 index 00000000..fcd902e7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f93d-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..5f6fa5a8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f93d-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..62da945e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-1f3fb.svg b/qortal-ui-core/emoji/svg/1f93d-1f3fb.svg new file mode 100644 index 00000000..5bba0fba --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f93d-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..f0f9e7fc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f93d-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..6df27874 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-1f3fc.svg b/qortal-ui-core/emoji/svg/1f93d-1f3fc.svg new file mode 100644 index 00000000..ed5845ab --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f93d-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..49c426de --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f93d-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..2b8c67d1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-1f3fd.svg b/qortal-ui-core/emoji/svg/1f93d-1f3fd.svg new file mode 100644 index 00000000..4056ca51 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f93d-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..1efd46ae --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f93d-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..045d9fde --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-1f3fe.svg b/qortal-ui-core/emoji/svg/1f93d-1f3fe.svg new file mode 100644 index 00000000..2de4cfaf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f93d-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..bf063016 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f93d-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..60c34455 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-1f3ff.svg b/qortal-ui-core/emoji/svg/1f93d-1f3ff.svg new file mode 100644 index 00000000..37c3616c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f93d-200d-2640-fe0f.svg new file mode 100644 index 00000000..1cca2e7c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f93d-200d-2642-fe0f.svg new file mode 100644 index 00000000..9469b6a0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93d.svg b/qortal-ui-core/emoji/svg/1f93d.svg new file mode 100644 index 00000000..df8453d8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f93e-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..46d9bdca --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f93e-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..02989634 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-1f3fb.svg b/qortal-ui-core/emoji/svg/1f93e-1f3fb.svg new file mode 100644 index 00000000..0988f267 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f93e-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..2a6191fd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f93e-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..ac5a4bb8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-1f3fc.svg b/qortal-ui-core/emoji/svg/1f93e-1f3fc.svg new file mode 100644 index 00000000..8ee96e0b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f93e-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..ca6f6c27 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f93e-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..63fe0d4c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-1f3fd.svg b/qortal-ui-core/emoji/svg/1f93e-1f3fd.svg new file mode 100644 index 00000000..a4e93ba4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f93e-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..692ed9d3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f93e-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..5639542c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-1f3fe.svg b/qortal-ui-core/emoji/svg/1f93e-1f3fe.svg new file mode 100644 index 00000000..95c71b92 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f93e-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..ec3b45f8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f93e-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..1d547f9b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-1f3ff.svg b/qortal-ui-core/emoji/svg/1f93e-1f3ff.svg new file mode 100644 index 00000000..8456c783 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f93e-200d-2640-fe0f.svg new file mode 100644 index 00000000..28e86b3e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f93e-200d-2642-fe0f.svg new file mode 100644 index 00000000..3efb4668 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93e.svg b/qortal-ui-core/emoji/svg/1f93e.svg new file mode 100644 index 00000000..b678e656 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f93f.svg b/qortal-ui-core/emoji/svg/1f93f.svg new file mode 100644 index 00000000..01239db8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f93f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f940.svg b/qortal-ui-core/emoji/svg/1f940.svg new file mode 100644 index 00000000..dedff208 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f940.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f941.svg b/qortal-ui-core/emoji/svg/1f941.svg new file mode 100644 index 00000000..e197d16c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f941.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f942.svg b/qortal-ui-core/emoji/svg/1f942.svg new file mode 100644 index 00000000..30167b03 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f942.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f943.svg b/qortal-ui-core/emoji/svg/1f943.svg new file mode 100644 index 00000000..27750ea6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f943.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f944.svg b/qortal-ui-core/emoji/svg/1f944.svg new file mode 100644 index 00000000..1f2d69fa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f944.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f945.svg b/qortal-ui-core/emoji/svg/1f945.svg new file mode 100644 index 00000000..4d187f2f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f945.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f947.svg b/qortal-ui-core/emoji/svg/1f947.svg new file mode 100644 index 00000000..c67af77c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f947.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f948.svg b/qortal-ui-core/emoji/svg/1f948.svg new file mode 100644 index 00000000..685db6d1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f948.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f949.svg b/qortal-ui-core/emoji/svg/1f949.svg new file mode 100644 index 00000000..6bb5f773 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f949.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f94a.svg b/qortal-ui-core/emoji/svg/1f94a.svg new file mode 100644 index 00000000..fa16edbd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f94a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f94b.svg b/qortal-ui-core/emoji/svg/1f94b.svg new file mode 100644 index 00000000..33d6e213 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f94b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f94c.svg b/qortal-ui-core/emoji/svg/1f94c.svg new file mode 100644 index 00000000..9bc8f8a5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f94c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f94d.svg b/qortal-ui-core/emoji/svg/1f94d.svg new file mode 100644 index 00000000..8c6bcb98 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f94d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f94e.svg b/qortal-ui-core/emoji/svg/1f94e.svg new file mode 100644 index 00000000..1c9270ce --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f94e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f94f.svg b/qortal-ui-core/emoji/svg/1f94f.svg new file mode 100644 index 00000000..84fdba47 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f94f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f950.svg b/qortal-ui-core/emoji/svg/1f950.svg new file mode 100644 index 00000000..eef4358d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f950.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f951.svg b/qortal-ui-core/emoji/svg/1f951.svg new file mode 100644 index 00000000..ed1d9f9f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f951.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f952.svg b/qortal-ui-core/emoji/svg/1f952.svg new file mode 100644 index 00000000..83cba03c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f952.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f953.svg b/qortal-ui-core/emoji/svg/1f953.svg new file mode 100644 index 00000000..82d4c82b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f953.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f954.svg b/qortal-ui-core/emoji/svg/1f954.svg new file mode 100644 index 00000000..b8d120d9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f954.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f955.svg b/qortal-ui-core/emoji/svg/1f955.svg new file mode 100644 index 00000000..b949554f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f955.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f956.svg b/qortal-ui-core/emoji/svg/1f956.svg new file mode 100644 index 00000000..8da10427 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f956.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f957.svg b/qortal-ui-core/emoji/svg/1f957.svg new file mode 100644 index 00000000..f18b0965 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f957.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f958.svg b/qortal-ui-core/emoji/svg/1f958.svg new file mode 100644 index 00000000..878520cf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f958.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f959.svg b/qortal-ui-core/emoji/svg/1f959.svg new file mode 100644 index 00000000..baa9a4b9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f959.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f95a.svg b/qortal-ui-core/emoji/svg/1f95a.svg new file mode 100644 index 00000000..1e760176 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f95a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f95b.svg b/qortal-ui-core/emoji/svg/1f95b.svg new file mode 100644 index 00000000..73947e88 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f95b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f95c.svg b/qortal-ui-core/emoji/svg/1f95c.svg new file mode 100644 index 00000000..c809689a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f95c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f95d.svg b/qortal-ui-core/emoji/svg/1f95d.svg new file mode 100644 index 00000000..4007a720 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f95d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f95e.svg b/qortal-ui-core/emoji/svg/1f95e.svg new file mode 100644 index 00000000..795fb134 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f95e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f95f.svg b/qortal-ui-core/emoji/svg/1f95f.svg new file mode 100644 index 00000000..57f13af8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f95f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f960.svg b/qortal-ui-core/emoji/svg/1f960.svg new file mode 100644 index 00000000..5d61144b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f960.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f961.svg b/qortal-ui-core/emoji/svg/1f961.svg new file mode 100644 index 00000000..6a05c9c2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f961.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f962.svg b/qortal-ui-core/emoji/svg/1f962.svg new file mode 100644 index 00000000..adde7aa5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f962.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f963.svg b/qortal-ui-core/emoji/svg/1f963.svg new file mode 100644 index 00000000..00e5ae6f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f963.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f964.svg b/qortal-ui-core/emoji/svg/1f964.svg new file mode 100644 index 00000000..3556dd9e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f964.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f965.svg b/qortal-ui-core/emoji/svg/1f965.svg new file mode 100644 index 00000000..7f169279 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f965.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f966.svg b/qortal-ui-core/emoji/svg/1f966.svg new file mode 100644 index 00000000..ee2bc1cb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f966.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f967.svg b/qortal-ui-core/emoji/svg/1f967.svg new file mode 100644 index 00000000..5916cacd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f967.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f968.svg b/qortal-ui-core/emoji/svg/1f968.svg new file mode 100644 index 00000000..10bd682b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f968.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f969.svg b/qortal-ui-core/emoji/svg/1f969.svg new file mode 100644 index 00000000..28a6a1ac --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f969.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f96a.svg b/qortal-ui-core/emoji/svg/1f96a.svg new file mode 100644 index 00000000..d514ba76 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f96a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f96b.svg b/qortal-ui-core/emoji/svg/1f96b.svg new file mode 100644 index 00000000..9c451ed0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f96b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f96c.svg b/qortal-ui-core/emoji/svg/1f96c.svg new file mode 100644 index 00000000..6ef36cb2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f96c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f96d.svg b/qortal-ui-core/emoji/svg/1f96d.svg new file mode 100644 index 00000000..b5607c10 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f96d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f96e.svg b/qortal-ui-core/emoji/svg/1f96e.svg new file mode 100644 index 00000000..ebb7ba98 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f96e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f96f.svg b/qortal-ui-core/emoji/svg/1f96f.svg new file mode 100644 index 00000000..6a65f4c1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f96f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f970.svg b/qortal-ui-core/emoji/svg/1f970.svg new file mode 100644 index 00000000..6b063dfc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f970.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f971.svg b/qortal-ui-core/emoji/svg/1f971.svg new file mode 100644 index 00000000..26444c6a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f971.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f972.svg b/qortal-ui-core/emoji/svg/1f972.svg new file mode 100644 index 00000000..f309c223 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f972.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f973.svg b/qortal-ui-core/emoji/svg/1f973.svg new file mode 100644 index 00000000..c7a95387 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f973.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f974.svg b/qortal-ui-core/emoji/svg/1f974.svg new file mode 100644 index 00000000..87bb859c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f974.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f975.svg b/qortal-ui-core/emoji/svg/1f975.svg new file mode 100644 index 00000000..09e99a3e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f975.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f976.svg b/qortal-ui-core/emoji/svg/1f976.svg new file mode 100644 index 00000000..e32efddc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f976.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f977-1f3fb.svg b/qortal-ui-core/emoji/svg/1f977-1f3fb.svg new file mode 100644 index 00000000..5c981c21 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f977-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f977-1f3fc.svg b/qortal-ui-core/emoji/svg/1f977-1f3fc.svg new file mode 100644 index 00000000..6c3545e5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f977-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f977-1f3fd.svg b/qortal-ui-core/emoji/svg/1f977-1f3fd.svg new file mode 100644 index 00000000..557267b7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f977-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f977-1f3fe.svg b/qortal-ui-core/emoji/svg/1f977-1f3fe.svg new file mode 100644 index 00000000..8b65491b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f977-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f977-1f3ff.svg b/qortal-ui-core/emoji/svg/1f977-1f3ff.svg new file mode 100644 index 00000000..7d328727 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f977-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f977.svg b/qortal-ui-core/emoji/svg/1f977.svg new file mode 100644 index 00000000..84be7d7a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f977.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f978.svg b/qortal-ui-core/emoji/svg/1f978.svg new file mode 100644 index 00000000..6d1e4e11 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f978.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f97a.svg b/qortal-ui-core/emoji/svg/1f97a.svg new file mode 100644 index 00000000..fe933608 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f97a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f97b.svg b/qortal-ui-core/emoji/svg/1f97b.svg new file mode 100644 index 00000000..846d591c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f97b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f97c.svg b/qortal-ui-core/emoji/svg/1f97c.svg new file mode 100644 index 00000000..5d19b273 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f97c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f97d.svg b/qortal-ui-core/emoji/svg/1f97d.svg new file mode 100644 index 00000000..cdb79f9f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f97d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f97e.svg b/qortal-ui-core/emoji/svg/1f97e.svg new file mode 100644 index 00000000..67150285 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f97e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f97f.svg b/qortal-ui-core/emoji/svg/1f97f.svg new file mode 100644 index 00000000..22063078 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f97f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f980.svg b/qortal-ui-core/emoji/svg/1f980.svg new file mode 100644 index 00000000..8f45b53d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f980.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f981.svg b/qortal-ui-core/emoji/svg/1f981.svg new file mode 100644 index 00000000..674ff24e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f981.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f982.svg b/qortal-ui-core/emoji/svg/1f982.svg new file mode 100644 index 00000000..582c7223 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f982.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f983.svg b/qortal-ui-core/emoji/svg/1f983.svg new file mode 100644 index 00000000..e9de7de9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f983.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f984.svg b/qortal-ui-core/emoji/svg/1f984.svg new file mode 100644 index 00000000..19d9ff16 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f984.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f985.svg b/qortal-ui-core/emoji/svg/1f985.svg new file mode 100644 index 00000000..81b7b3cc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f985.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f986.svg b/qortal-ui-core/emoji/svg/1f986.svg new file mode 100644 index 00000000..085c9006 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f986.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f987.svg b/qortal-ui-core/emoji/svg/1f987.svg new file mode 100644 index 00000000..4ebb5ad4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f987.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f988.svg b/qortal-ui-core/emoji/svg/1f988.svg new file mode 100644 index 00000000..f6381c52 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f988.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f989.svg b/qortal-ui-core/emoji/svg/1f989.svg new file mode 100644 index 00000000..bb0d461a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f989.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f98a.svg b/qortal-ui-core/emoji/svg/1f98a.svg new file mode 100644 index 00000000..13704a41 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f98a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f98b.svg b/qortal-ui-core/emoji/svg/1f98b.svg new file mode 100644 index 00000000..22c6ead8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f98b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f98c.svg b/qortal-ui-core/emoji/svg/1f98c.svg new file mode 100644 index 00000000..86623680 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f98c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f98d.svg b/qortal-ui-core/emoji/svg/1f98d.svg new file mode 100644 index 00000000..aa599232 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f98d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f98e.svg b/qortal-ui-core/emoji/svg/1f98e.svg new file mode 100644 index 00000000..1164a73b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f98e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f98f.svg b/qortal-ui-core/emoji/svg/1f98f.svg new file mode 100644 index 00000000..0d07017a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f98f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f990.svg b/qortal-ui-core/emoji/svg/1f990.svg new file mode 100644 index 00000000..8279307e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f990.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f991.svg b/qortal-ui-core/emoji/svg/1f991.svg new file mode 100644 index 00000000..e0bbf92c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f991.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f992.svg b/qortal-ui-core/emoji/svg/1f992.svg new file mode 100644 index 00000000..233e3c98 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f992.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f993.svg b/qortal-ui-core/emoji/svg/1f993.svg new file mode 100644 index 00000000..2cb4b9eb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f993.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f994.svg b/qortal-ui-core/emoji/svg/1f994.svg new file mode 100644 index 00000000..ebbfc2ad --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f994.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f995.svg b/qortal-ui-core/emoji/svg/1f995.svg new file mode 100644 index 00000000..fb046c69 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f995.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f996.svg b/qortal-ui-core/emoji/svg/1f996.svg new file mode 100644 index 00000000..64b68d75 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f996.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f997.svg b/qortal-ui-core/emoji/svg/1f997.svg new file mode 100644 index 00000000..f26413fd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f997.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f998.svg b/qortal-ui-core/emoji/svg/1f998.svg new file mode 100644 index 00000000..8a72b40a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f998.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f999.svg b/qortal-ui-core/emoji/svg/1f999.svg new file mode 100644 index 00000000..b505faf8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f999.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f99a.svg b/qortal-ui-core/emoji/svg/1f99a.svg new file mode 100644 index 00000000..7606d382 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f99a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f99b.svg b/qortal-ui-core/emoji/svg/1f99b.svg new file mode 100644 index 00000000..2764249c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f99b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f99c.svg b/qortal-ui-core/emoji/svg/1f99c.svg new file mode 100644 index 00000000..f7f743c5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f99c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f99d.svg b/qortal-ui-core/emoji/svg/1f99d.svg new file mode 100644 index 00000000..30c88720 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f99d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f99e.svg b/qortal-ui-core/emoji/svg/1f99e.svg new file mode 100644 index 00000000..8df2a746 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f99e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f99f.svg b/qortal-ui-core/emoji/svg/1f99f.svg new file mode 100644 index 00000000..58881512 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f99f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9a0.svg b/qortal-ui-core/emoji/svg/1f9a0.svg new file mode 100644 index 00000000..cea144ea --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9a0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9a1.svg b/qortal-ui-core/emoji/svg/1f9a1.svg new file mode 100644 index 00000000..92f42fd8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9a1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9a2.svg b/qortal-ui-core/emoji/svg/1f9a2.svg new file mode 100644 index 00000000..9c383817 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9a2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9a3.svg b/qortal-ui-core/emoji/svg/1f9a3.svg new file mode 100644 index 00000000..1aa87190 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9a3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9a4.svg b/qortal-ui-core/emoji/svg/1f9a4.svg new file mode 100644 index 00000000..1dbac1e3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9a5.svg b/qortal-ui-core/emoji/svg/1f9a5.svg new file mode 100644 index 00000000..7371a8ed --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9a5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9a6.svg b/qortal-ui-core/emoji/svg/1f9a6.svg new file mode 100644 index 00000000..5ea0173a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9a6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9a7.svg b/qortal-ui-core/emoji/svg/1f9a7.svg new file mode 100644 index 00000000..03828455 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9a7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9a8.svg b/qortal-ui-core/emoji/svg/1f9a8.svg new file mode 100644 index 00000000..47478ffe --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9a9.svg b/qortal-ui-core/emoji/svg/1f9a9.svg new file mode 100644 index 00000000..aaa5cfa2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9a9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9aa.svg b/qortal-ui-core/emoji/svg/1f9aa.svg new file mode 100644 index 00000000..f0f47786 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9aa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ab.svg b/qortal-ui-core/emoji/svg/1f9ab.svg new file mode 100644 index 00000000..7967d678 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ab.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ac.svg b/qortal-ui-core/emoji/svg/1f9ac.svg new file mode 100644 index 00000000..c8156813 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ac.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ad.svg b/qortal-ui-core/emoji/svg/1f9ad.svg new file mode 100644 index 00000000..6904e81a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ad.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ae.svg b/qortal-ui-core/emoji/svg/1f9ae.svg new file mode 100644 index 00000000..fc635872 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ae.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9af.svg b/qortal-ui-core/emoji/svg/1f9af.svg new file mode 100644 index 00000000..aba8a980 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b0.svg b/qortal-ui-core/emoji/svg/1f9b0.svg new file mode 100644 index 00000000..5cb487ef --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b1.svg b/qortal-ui-core/emoji/svg/1f9b1.svg new file mode 100644 index 00000000..414422b8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b2.svg b/qortal-ui-core/emoji/svg/1f9b2.svg new file mode 100644 index 00000000..035b6919 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b3.svg b/qortal-ui-core/emoji/svg/1f9b3.svg new file mode 100644 index 00000000..ea3072c4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b4.svg b/qortal-ui-core/emoji/svg/1f9b4.svg new file mode 100644 index 00000000..624de728 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b5-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9b5-1f3fb.svg new file mode 100644 index 00000000..0a233cf4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b5-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b5-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9b5-1f3fc.svg new file mode 100644 index 00000000..229bd21d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b5-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b5-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9b5-1f3fd.svg new file mode 100644 index 00000000..dce4696f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b5-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b5-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9b5-1f3fe.svg new file mode 100644 index 00000000..5cb99073 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b5-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b5-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9b5-1f3ff.svg new file mode 100644 index 00000000..6bdc2f93 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b5-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b5.svg b/qortal-ui-core/emoji/svg/1f9b5.svg new file mode 100644 index 00000000..178fd158 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b6-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9b6-1f3fb.svg new file mode 100644 index 00000000..29677fb3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b6-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b6-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9b6-1f3fc.svg new file mode 100644 index 00000000..dc679d09 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b6-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b6-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9b6-1f3fd.svg new file mode 100644 index 00000000..8f0f6892 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b6-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b6-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9b6-1f3fe.svg new file mode 100644 index 00000000..0752f698 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b6-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b6-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9b6-1f3ff.svg new file mode 100644 index 00000000..297e0b41 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b6-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b6.svg b/qortal-ui-core/emoji/svg/1f9b6.svg new file mode 100644 index 00000000..abbbbac9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b7.svg b/qortal-ui-core/emoji/svg/1f9b7.svg new file mode 100644 index 00000000..49cc5f9c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b8-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..f50f846a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b8-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..fc3adcb6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9b8-1f3fb.svg new file mode 100644 index 00000000..52a50d9e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b8-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..3b0a5be2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b8-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..3e223f3e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9b8-1f3fc.svg new file mode 100644 index 00000000..8a2fc9b6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b8-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..e87b63fd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b8-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..f3575906 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9b8-1f3fd.svg new file mode 100644 index 00000000..a9ee6d80 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b8-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..355bbad7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b8-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..a1535bfd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9b8-1f3fe.svg new file mode 100644 index 00000000..11d689b4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b8-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..d4126a1b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b8-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..8e5c1505 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9b8-1f3ff.svg new file mode 100644 index 00000000..58b200eb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b8-200d-2640-fe0f.svg new file mode 100644 index 00000000..120097ee --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b8-200d-2642-fe0f.svg new file mode 100644 index 00000000..404dcb20 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b8.svg b/qortal-ui-core/emoji/svg/1f9b8.svg new file mode 100644 index 00000000..f0122153 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b9-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..e52e0d8d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b9-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..ced012a4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9b9-1f3fb.svg new file mode 100644 index 00000000..2070980d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b9-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..61c9be88 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b9-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..67a93de7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9b9-1f3fc.svg new file mode 100644 index 00000000..2a0ce49f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b9-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..eeb4f074 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b9-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..091e36b2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9b9-1f3fd.svg new file mode 100644 index 00000000..199cceb6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b9-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..463ee894 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b9-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..008a07f1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9b9-1f3fe.svg new file mode 100644 index 00000000..63f24fd9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b9-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..a110d6d4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b9-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..ec17e3b5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9b9-1f3ff.svg new file mode 100644 index 00000000..bd52692b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b9-200d-2640-fe0f.svg new file mode 100644 index 00000000..97ee7719 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9b9-200d-2642-fe0f.svg new file mode 100644 index 00000000..6c207613 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9b9.svg b/qortal-ui-core/emoji/svg/1f9b9.svg new file mode 100644 index 00000000..43922b08 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9b9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ba.svg b/qortal-ui-core/emoji/svg/1f9ba.svg new file mode 100644 index 00000000..50bf8e37 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ba.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9bb-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9bb-1f3fb.svg new file mode 100644 index 00000000..b94d484a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9bb-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9bb-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9bb-1f3fc.svg new file mode 100644 index 00000000..d187bad0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9bb-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9bb-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9bb-1f3fd.svg new file mode 100644 index 00000000..51ed272c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9bb-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9bb-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9bb-1f3fe.svg new file mode 100644 index 00000000..af889ade --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9bb-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9bb-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9bb-1f3ff.svg new file mode 100644 index 00000000..818e532d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9bb-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9bb.svg b/qortal-ui-core/emoji/svg/1f9bb.svg new file mode 100644 index 00000000..05bc0201 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9bc.svg b/qortal-ui-core/emoji/svg/1f9bc.svg new file mode 100644 index 00000000..153f5531 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9bd.svg b/qortal-ui-core/emoji/svg/1f9bd.svg new file mode 100644 index 00000000..c371d4bf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9be.svg b/qortal-ui-core/emoji/svg/1f9be.svg new file mode 100644 index 00000000..c3d2db4f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9be.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9bf.svg b/qortal-ui-core/emoji/svg/1f9bf.svg new file mode 100644 index 00000000..db17a633 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9bf.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9c0.svg b/qortal-ui-core/emoji/svg/1f9c0.svg new file mode 100644 index 00000000..20e6a92f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9c0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9c1.svg b/qortal-ui-core/emoji/svg/1f9c1.svg new file mode 100644 index 00000000..1f966c36 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9c1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9c2.svg b/qortal-ui-core/emoji/svg/1f9c2.svg new file mode 100644 index 00000000..40dea883 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9c2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9c3.svg b/qortal-ui-core/emoji/svg/1f9c3.svg new file mode 100644 index 00000000..51a3f26d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9c3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9c4.svg b/qortal-ui-core/emoji/svg/1f9c4.svg new file mode 100644 index 00000000..37a9f36e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9c4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9c5.svg b/qortal-ui-core/emoji/svg/1f9c5.svg new file mode 100644 index 00000000..ab68cb1d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9c5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9c6.svg b/qortal-ui-core/emoji/svg/1f9c6.svg new file mode 100644 index 00000000..c360564e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9c6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9c7.svg b/qortal-ui-core/emoji/svg/1f9c7.svg new file mode 100644 index 00000000..cc92a9d1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9c7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9c8.svg b/qortal-ui-core/emoji/svg/1f9c8.svg new file mode 100644 index 00000000..d7a5674c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9c8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9c9.svg b/qortal-ui-core/emoji/svg/1f9c9.svg new file mode 100644 index 00000000..16b0db82 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9c9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ca.svg b/qortal-ui-core/emoji/svg/1f9ca.svg new file mode 100644 index 00000000..569fe039 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ca.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cb.svg b/qortal-ui-core/emoji/svg/1f9cb.svg new file mode 100644 index 00000000..8cb61784 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cd-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..d5981e34 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cd-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..8fbd6c03 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9cd-1f3fb.svg new file mode 100644 index 00000000..3492853c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cd-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..7f81ff85 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cd-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..0ea6dafd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9cd-1f3fc.svg new file mode 100644 index 00000000..b974f41f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cd-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..48329af5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cd-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..3197184b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9cd-1f3fd.svg new file mode 100644 index 00000000..468edc6b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cd-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..696243dc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cd-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..8b05543d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9cd-1f3fe.svg new file mode 100644 index 00000000..db22d184 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cd-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..c96659ce --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cd-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..59fb6a93 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9cd-1f3ff.svg new file mode 100644 index 00000000..5191b96d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cd-200d-2640-fe0f.svg new file mode 100644 index 00000000..1b8bfc38 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cd-200d-2642-fe0f.svg new file mode 100644 index 00000000..450561e2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cd.svg b/qortal-ui-core/emoji/svg/1f9cd.svg new file mode 100644 index 00000000..331041b7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9ce-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..37507496 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9ce-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..97de596d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9ce-1f3fb.svg new file mode 100644 index 00000000..6f97b1b9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9ce-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..ee5bf15a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9ce-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..e5186577 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9ce-1f3fc.svg new file mode 100644 index 00000000..0977ee6d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9ce-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..e210695d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9ce-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..269c7cec --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9ce-1f3fd.svg new file mode 100644 index 00000000..7fe4f06e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9ce-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..e2b09309 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9ce-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..54e4ba95 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9ce-1f3fe.svg new file mode 100644 index 00000000..2f70944a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9ce-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..0f2dc0c4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9ce-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..b51d7ff8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9ce-1f3ff.svg new file mode 100644 index 00000000..542a6041 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9ce-200d-2640-fe0f.svg new file mode 100644 index 00000000..40b5754e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9ce-200d-2642-fe0f.svg new file mode 100644 index 00000000..1c8ddcd8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ce.svg b/qortal-ui-core/emoji/svg/1f9ce.svg new file mode 100644 index 00000000..86a60cb1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ce.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cf-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..9605fac0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cf-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..be0cd900 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9cf-1f3fb.svg new file mode 100644 index 00000000..297d20ac --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cf-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..a463bd6e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cf-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..31236464 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9cf-1f3fc.svg new file mode 100644 index 00000000..ef8f1d8c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cf-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..623b3445 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cf-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..d41a0fa6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9cf-1f3fd.svg new file mode 100644 index 00000000..f1ed199e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cf-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..d63eee45 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cf-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..dd439266 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9cf-1f3fe.svg new file mode 100644 index 00000000..480a1a66 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cf-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..6064882a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cf-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..748ab421 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9cf-1f3ff.svg new file mode 100644 index 00000000..d44bde71 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cf-200d-2640-fe0f.svg new file mode 100644 index 00000000..7d8f058a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9cf-200d-2642-fe0f.svg new file mode 100644 index 00000000..8c119c99 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9cf.svg b/qortal-ui-core/emoji/svg/1f9cf.svg new file mode 100644 index 00000000..b6325213 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9cf.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d0.svg b/qortal-ui-core/emoji/svg/1f9d0.svg new file mode 100644 index 00000000..86198f7f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f33e.svg new file mode 100644 index 00000000..9963675b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f373.svg new file mode 100644 index 00000000..35898dad --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f37c.svg new file mode 100644 index 00000000..624d945f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f384.svg new file mode 100644 index 00000000..e204d68a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f393.svg new file mode 100644 index 00000000..73f9b6d0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f3a4.svg new file mode 100644 index 00000000..b093c515 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f3a8.svg new file mode 100644 index 00000000..260397c5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f3eb.svg new file mode 100644 index 00000000..09c5866a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f3ed.svg new file mode 100644 index 00000000..00836e95 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f4bb.svg new file mode 100644 index 00000000..b38cf485 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f4bc.svg new file mode 100644 index 00000000..5c448c35 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f527.svg new file mode 100644 index 00000000..94bf92c2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f52c.svg new file mode 100644 index 00000000..726e3780 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f680.svg new file mode 100644 index 00000000..45e13619 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f692.svg new file mode 100644 index 00000000..319c6877 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f91d-200d-1f9d1-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f91d-200d-1f9d1-1f3fb.svg new file mode 100644 index 00000000..872bbb01 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f91d-200d-1f9d1-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f91d-200d-1f9d1-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f91d-200d-1f9d1-1f3fc.svg new file mode 100644 index 00000000..fee6221e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f91d-200d-1f9d1-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f91d-200d-1f9d1-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f91d-200d-1f9d1-1f3fd.svg new file mode 100644 index 00000000..937470f6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f91d-200d-1f9d1-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f91d-200d-1f9d1-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f91d-200d-1f9d1-1f3fe.svg new file mode 100644 index 00000000..782e26e7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f91d-200d-1f9d1-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f91d-200d-1f9d1-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f91d-200d-1f9d1-1f3ff.svg new file mode 100644 index 00000000..93b224ad --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f91d-200d-1f9d1-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9af.svg new file mode 100644 index 00000000..66a5330a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9b0.svg new file mode 100644 index 00000000..d32aaaf7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9b1.svg new file mode 100644 index 00000000..81b32ae0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9b2.svg new file mode 100644 index 00000000..74beee11 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9b3.svg new file mode 100644 index 00000000..c0c69875 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9bc.svg new file mode 100644 index 00000000..0fdb383a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9bd.svg new file mode 100644 index 00000000..aaff786e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-2695-fe0f.svg new file mode 100644 index 00000000..40e3f3ee --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-2696-fe0f.svg new file mode 100644 index 00000000..4eb55101 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-2708-fe0f.svg new file mode 100644 index 00000000..97c34403 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fb.svg new file mode 100644 index 00000000..9235058b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f33e.svg new file mode 100644 index 00000000..ca8c8b7e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f373.svg new file mode 100644 index 00000000..9a065b5b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f37c.svg new file mode 100644 index 00000000..cd1b853e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f384.svg new file mode 100644 index 00000000..c86b6d37 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f393.svg new file mode 100644 index 00000000..6923efa5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f3a4.svg new file mode 100644 index 00000000..f35861f4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f3a8.svg new file mode 100644 index 00000000..6666557a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f3eb.svg new file mode 100644 index 00000000..c0e5cd14 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f3ed.svg new file mode 100644 index 00000000..2a9e89a0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f4bb.svg new file mode 100644 index 00000000..39c5f63d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f4bc.svg new file mode 100644 index 00000000..4ec99b23 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f527.svg new file mode 100644 index 00000000..20526c61 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f52c.svg new file mode 100644 index 00000000..5912cbce --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f680.svg new file mode 100644 index 00000000..9e5eee39 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f692.svg new file mode 100644 index 00000000..c03e8ecf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f91d-200d-1f9d1-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f91d-200d-1f9d1-1f3fb.svg new file mode 100644 index 00000000..db9e577b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f91d-200d-1f9d1-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f91d-200d-1f9d1-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f91d-200d-1f9d1-1f3fc.svg new file mode 100644 index 00000000..91bae533 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f91d-200d-1f9d1-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f91d-200d-1f9d1-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f91d-200d-1f9d1-1f3fd.svg new file mode 100644 index 00000000..b76524f2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f91d-200d-1f9d1-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f91d-200d-1f9d1-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f91d-200d-1f9d1-1f3fe.svg new file mode 100644 index 00000000..166e2711 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f91d-200d-1f9d1-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f91d-200d-1f9d1-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f91d-200d-1f9d1-1f3ff.svg new file mode 100644 index 00000000..cbcf327e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f91d-200d-1f9d1-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9af.svg new file mode 100644 index 00000000..5dfba690 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9b0.svg new file mode 100644 index 00000000..95e52682 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9b1.svg new file mode 100644 index 00000000..27e3ad6d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9b2.svg new file mode 100644 index 00000000..4235ea03 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9b3.svg new file mode 100644 index 00000000..71bce8fa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9bc.svg new file mode 100644 index 00000000..72413161 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9bd.svg new file mode 100644 index 00000000..740422fc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-2695-fe0f.svg new file mode 100644 index 00000000..8c5d1067 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-2696-fe0f.svg new file mode 100644 index 00000000..a39ad4ec --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-2708-fe0f.svg new file mode 100644 index 00000000..cbba7776 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fc.svg new file mode 100644 index 00000000..e47b1b24 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f33e.svg new file mode 100644 index 00000000..4526ae45 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f373.svg new file mode 100644 index 00000000..af6f1f27 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f37c.svg new file mode 100644 index 00000000..c1d45aa3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f384.svg new file mode 100644 index 00000000..0c606663 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f393.svg new file mode 100644 index 00000000..5ca8a61e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f3a4.svg new file mode 100644 index 00000000..91929e06 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f3a8.svg new file mode 100644 index 00000000..5c9448c2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f3eb.svg new file mode 100644 index 00000000..b9e6bd7e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f3ed.svg new file mode 100644 index 00000000..98518b07 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f4bb.svg new file mode 100644 index 00000000..83db71bd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f4bc.svg new file mode 100644 index 00000000..310edfec --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f527.svg new file mode 100644 index 00000000..dbe729a9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f52c.svg new file mode 100644 index 00000000..fcf6cdb2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f680.svg new file mode 100644 index 00000000..59e3fb53 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f692.svg new file mode 100644 index 00000000..11503259 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f91d-200d-1f9d1-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f91d-200d-1f9d1-1f3fb.svg new file mode 100644 index 00000000..95b71de9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f91d-200d-1f9d1-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f91d-200d-1f9d1-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f91d-200d-1f9d1-1f3fc.svg new file mode 100644 index 00000000..ccf18e15 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f91d-200d-1f9d1-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f91d-200d-1f9d1-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f91d-200d-1f9d1-1f3fd.svg new file mode 100644 index 00000000..bd3e7124 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f91d-200d-1f9d1-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f91d-200d-1f9d1-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f91d-200d-1f9d1-1f3fe.svg new file mode 100644 index 00000000..37b06f9b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f91d-200d-1f9d1-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f91d-200d-1f9d1-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f91d-200d-1f9d1-1f3ff.svg new file mode 100644 index 00000000..4f85ab9a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f91d-200d-1f9d1-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9af.svg new file mode 100644 index 00000000..7db282e8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9b0.svg new file mode 100644 index 00000000..2a950baf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9b1.svg new file mode 100644 index 00000000..e6547c13 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9b2.svg new file mode 100644 index 00000000..fe56d2a9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9b3.svg new file mode 100644 index 00000000..369b9415 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9bc.svg new file mode 100644 index 00000000..a7352ece --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9bd.svg new file mode 100644 index 00000000..baac4da8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-2695-fe0f.svg new file mode 100644 index 00000000..8361c3a0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-2696-fe0f.svg new file mode 100644 index 00000000..5c8816e3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-2708-fe0f.svg new file mode 100644 index 00000000..55592e38 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fd.svg new file mode 100644 index 00000000..892d2622 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f33e.svg new file mode 100644 index 00000000..c2cfa0a7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f373.svg new file mode 100644 index 00000000..1c9bbf3c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f37c.svg new file mode 100644 index 00000000..a4f6e769 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f384.svg new file mode 100644 index 00000000..fb94c66c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f393.svg new file mode 100644 index 00000000..fbf4897f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f3a4.svg new file mode 100644 index 00000000..756b24fb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f3a8.svg new file mode 100644 index 00000000..b3e5d45e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f3eb.svg new file mode 100644 index 00000000..c9769d99 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f3ed.svg new file mode 100644 index 00000000..891e38ae --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f4bb.svg new file mode 100644 index 00000000..fa7b724c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f4bc.svg new file mode 100644 index 00000000..ee31db06 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f527.svg new file mode 100644 index 00000000..e70a6168 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f52c.svg new file mode 100644 index 00000000..d9ca99fa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f680.svg new file mode 100644 index 00000000..f747a932 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f692.svg new file mode 100644 index 00000000..994939d5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f91d-200d-1f9d1-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f91d-200d-1f9d1-1f3fb.svg new file mode 100644 index 00000000..c00782bf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f91d-200d-1f9d1-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f91d-200d-1f9d1-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f91d-200d-1f9d1-1f3fc.svg new file mode 100644 index 00000000..581eac9f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f91d-200d-1f9d1-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f91d-200d-1f9d1-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f91d-200d-1f9d1-1f3fd.svg new file mode 100644 index 00000000..565c1cff --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f91d-200d-1f9d1-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f91d-200d-1f9d1-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f91d-200d-1f9d1-1f3fe.svg new file mode 100644 index 00000000..7bad5777 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f91d-200d-1f9d1-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f91d-200d-1f9d1-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f91d-200d-1f9d1-1f3ff.svg new file mode 100644 index 00000000..be44c06b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f91d-200d-1f9d1-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9af.svg new file mode 100644 index 00000000..bc64dc3d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9b0.svg new file mode 100644 index 00000000..4a29c3fd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9b1.svg new file mode 100644 index 00000000..a1824afc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9b2.svg new file mode 100644 index 00000000..9139c2fa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9b3.svg new file mode 100644 index 00000000..a5559283 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9bc.svg new file mode 100644 index 00000000..d83b937d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9bd.svg new file mode 100644 index 00000000..1f3215c1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-2695-fe0f.svg new file mode 100644 index 00000000..f0835140 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-2696-fe0f.svg new file mode 100644 index 00000000..fcf4bead --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-2708-fe0f.svg new file mode 100644 index 00000000..0f059a9c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3fe.svg new file mode 100644 index 00000000..ee05425f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f33e.svg new file mode 100644 index 00000000..6b9286b8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f373.svg new file mode 100644 index 00000000..bb79b4b8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f37c.svg new file mode 100644 index 00000000..4e75f50f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f384.svg new file mode 100644 index 00000000..52121d13 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f393.svg new file mode 100644 index 00000000..6d7689e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f3a4.svg new file mode 100644 index 00000000..3e4407fc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f3a8.svg new file mode 100644 index 00000000..499729b0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f3eb.svg new file mode 100644 index 00000000..b9ac5310 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f3ed.svg new file mode 100644 index 00000000..bc66d221 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f4bb.svg new file mode 100644 index 00000000..d79adc7e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f4bc.svg new file mode 100644 index 00000000..b08175e3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f527.svg new file mode 100644 index 00000000..015b39c3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f52c.svg new file mode 100644 index 00000000..ff1a170d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f680.svg new file mode 100644 index 00000000..5939ba5d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f692.svg new file mode 100644 index 00000000..c51348cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f91d-200d-1f9d1-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f91d-200d-1f9d1-1f3fb.svg new file mode 100644 index 00000000..a01b2c97 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f91d-200d-1f9d1-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f91d-200d-1f9d1-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f91d-200d-1f9d1-1f3fc.svg new file mode 100644 index 00000000..87d81811 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f91d-200d-1f9d1-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f91d-200d-1f9d1-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f91d-200d-1f9d1-1f3fd.svg new file mode 100644 index 00000000..0eb84d09 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f91d-200d-1f9d1-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f91d-200d-1f9d1-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f91d-200d-1f9d1-1f3fe.svg new file mode 100644 index 00000000..0526a3e0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f91d-200d-1f9d1-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f91d-200d-1f9d1-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f91d-200d-1f9d1-1f3ff.svg new file mode 100644 index 00000000..29dbea24 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f91d-200d-1f9d1-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9af.svg new file mode 100644 index 00000000..d46aa0a3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9b0.svg new file mode 100644 index 00000000..4e8b888f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9b1.svg new file mode 100644 index 00000000..e6a22f15 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9b2.svg new file mode 100644 index 00000000..a5e06b8a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9b3.svg new file mode 100644 index 00000000..a9abb979 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9bc.svg new file mode 100644 index 00000000..b82a5224 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9bd.svg new file mode 100644 index 00000000..ffa7e863 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-2695-fe0f.svg new file mode 100644 index 00000000..63a0b4bc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-2696-fe0f.svg new file mode 100644 index 00000000..10b9d96f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-2708-fe0f.svg new file mode 100644 index 00000000..0ba36868 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9d1-1f3ff.svg new file mode 100644 index 00000000..64832fee --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f33e.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f33e.svg new file mode 100644 index 00000000..56eba79e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f33e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f373.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f373.svg new file mode 100644 index 00000000..21a99bf5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f373.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f37c.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f37c.svg new file mode 100644 index 00000000..f2bf5294 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f37c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f384.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f384.svg new file mode 100644 index 00000000..78bde98e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f384.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f393.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f393.svg new file mode 100644 index 00000000..1befeaa6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f393.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f3a4.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f3a4.svg new file mode 100644 index 00000000..9b138a80 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f3a4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f3a8.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f3a8.svg new file mode 100644 index 00000000..6271635a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f3a8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f3eb.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f3eb.svg new file mode 100644 index 00000000..ec3858a5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f3eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f3ed.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f3ed.svg new file mode 100644 index 00000000..21c22e20 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f3ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f4bb.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f4bb.svg new file mode 100644 index 00000000..d89d8a0b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f4bb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f4bc.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f4bc.svg new file mode 100644 index 00000000..d88ae0d4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f4bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f527.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f527.svg new file mode 100644 index 00000000..489d5b3e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f527.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f52c.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f52c.svg new file mode 100644 index 00000000..6e760049 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f52c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f680.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f680.svg new file mode 100644 index 00000000..be96b03f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f680.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f692.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f692.svg new file mode 100644 index 00000000..58850013 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f91d-200d-1f9d1.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f91d-200d-1f9d1.svg new file mode 100644 index 00000000..6c3d407c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f91d-200d-1f9d1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f9af.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f9af.svg new file mode 100644 index 00000000..a43e2807 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f9af.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f9b0.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f9b0.svg new file mode 100644 index 00000000..682b5910 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f9b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f9b1.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f9b1.svg new file mode 100644 index 00000000..aa547994 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f9b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f9b2.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f9b2.svg new file mode 100644 index 00000000..e8732a59 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f9b2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f9b3.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f9b3.svg new file mode 100644 index 00000000..baaf5ffd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f9b3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f9bc.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f9bc.svg new file mode 100644 index 00000000..257d1e3b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f9bc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-1f9bd.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-1f9bd.svg new file mode 100644 index 00000000..e6acf984 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-1f9bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-2695-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-2695-fe0f.svg new file mode 100644 index 00000000..c33867ab --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-2695-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-2696-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-2696-fe0f.svg new file mode 100644 index 00000000..34d420d4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-2696-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1-200d-2708-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d1-200d-2708-fe0f.svg new file mode 100644 index 00000000..ab9e11bd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1-200d-2708-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d1.svg b/qortal-ui-core/emoji/svg/1f9d1.svg new file mode 100644 index 00000000..3c71659e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d2-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9d2-1f3fb.svg new file mode 100644 index 00000000..59fdd03f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d2-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d2-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9d2-1f3fc.svg new file mode 100644 index 00000000..0b0386dc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d2-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d2-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9d2-1f3fd.svg new file mode 100644 index 00000000..cba8e667 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d2-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d2-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9d2-1f3fe.svg new file mode 100644 index 00000000..62abe30a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d2-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d2-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9d2-1f3ff.svg new file mode 100644 index 00000000..180f8f36 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d2-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d2.svg b/qortal-ui-core/emoji/svg/1f9d2.svg new file mode 100644 index 00000000..23dce9f1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d3-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9d3-1f3fb.svg new file mode 100644 index 00000000..28b9a2d1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d3-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d3-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9d3-1f3fc.svg new file mode 100644 index 00000000..c484efd8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d3-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d3-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9d3-1f3fd.svg new file mode 100644 index 00000000..5010b969 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d3-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d3-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9d3-1f3fe.svg new file mode 100644 index 00000000..98df63c6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d3-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d3-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9d3-1f3ff.svg new file mode 100644 index 00000000..d4f781dc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d3-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d3.svg b/qortal-ui-core/emoji/svg/1f9d3.svg new file mode 100644 index 00000000..ad713bb0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d4-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9d4-1f3fb.svg new file mode 100644 index 00000000..f70cdfe7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d4-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d4-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9d4-1f3fc.svg new file mode 100644 index 00000000..5006795a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d4-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d4-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9d4-1f3fd.svg new file mode 100644 index 00000000..9caabe78 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d4-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d4-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9d4-1f3fe.svg new file mode 100644 index 00000000..6dd4b0a5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d4-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d4-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9d4-1f3ff.svg new file mode 100644 index 00000000..b994169b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d4-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d4.svg b/qortal-ui-core/emoji/svg/1f9d4.svg new file mode 100644 index 00000000..edabdc0c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d5-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9d5-1f3fb.svg new file mode 100644 index 00000000..e1db714f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d5-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d5-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9d5-1f3fc.svg new file mode 100644 index 00000000..ef64ff8e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d5-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d5-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9d5-1f3fd.svg new file mode 100644 index 00000000..c31d2fc3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d5-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d5-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9d5-1f3fe.svg new file mode 100644 index 00000000..4f346754 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d5-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d5-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9d5-1f3ff.svg new file mode 100644 index 00000000..2dcef9db --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d5-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d5.svg b/qortal-ui-core/emoji/svg/1f9d5.svg new file mode 100644 index 00000000..a650fee8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d6-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..98c29804 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d6-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..d3aff3dc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9d6-1f3fb.svg new file mode 100644 index 00000000..cf686c45 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d6-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..976146de --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d6-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..35f7e555 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9d6-1f3fc.svg new file mode 100644 index 00000000..1ab495c7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d6-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..b2975007 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d6-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..42772b46 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9d6-1f3fd.svg new file mode 100644 index 00000000..d2611e99 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d6-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..935ff329 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d6-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..4846f733 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9d6-1f3fe.svg new file mode 100644 index 00000000..bc36bf29 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d6-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..1c0862f7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d6-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..7512a609 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9d6-1f3ff.svg new file mode 100644 index 00000000..4402aab3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d6-200d-2640-fe0f.svg new file mode 100644 index 00000000..f1d0343e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d6-200d-2642-fe0f.svg new file mode 100644 index 00000000..3ecdeee7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d6.svg b/qortal-ui-core/emoji/svg/1f9d6.svg new file mode 100644 index 00000000..49744335 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d7-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..1aaa8a41 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d7-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..5d7450bd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9d7-1f3fb.svg new file mode 100644 index 00000000..357d5054 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d7-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..28347d7b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d7-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..a8fed146 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9d7-1f3fc.svg new file mode 100644 index 00000000..0475ced3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d7-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..6c665bf0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d7-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..8e7e2860 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9d7-1f3fd.svg new file mode 100644 index 00000000..a208c734 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d7-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..03ab0f09 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d7-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..fc16b859 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9d7-1f3fe.svg new file mode 100644 index 00000000..65169635 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d7-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..1253ee6c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d7-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..2a9524e2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9d7-1f3ff.svg new file mode 100644 index 00000000..4b64961e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d7-200d-2640-fe0f.svg new file mode 100644 index 00000000..c65c14a9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d7-200d-2642-fe0f.svg new file mode 100644 index 00000000..bb497099 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d7.svg b/qortal-ui-core/emoji/svg/1f9d7.svg new file mode 100644 index 00000000..9709f862 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d8-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..e51d2e43 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d8-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..ce17dc94 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9d8-1f3fb.svg new file mode 100644 index 00000000..39cbf7f7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d8-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..07972707 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d8-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..9e4c8d06 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9d8-1f3fc.svg new file mode 100644 index 00000000..3eaa3d88 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d8-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..010541a1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d8-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..6c3b34f5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9d8-1f3fd.svg new file mode 100644 index 00000000..6af0877b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d8-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..71bc5ad7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d8-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..c3629c6c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9d8-1f3fe.svg new file mode 100644 index 00000000..e189a9ea --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d8-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..5cc0fb7d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d8-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..33acb808 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9d8-1f3ff.svg new file mode 100644 index 00000000..b09ba9e9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d8-200d-2640-fe0f.svg new file mode 100644 index 00000000..8fcb70fb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d8-200d-2642-fe0f.svg new file mode 100644 index 00000000..e0c1f483 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d8.svg b/qortal-ui-core/emoji/svg/1f9d8.svg new file mode 100644 index 00000000..e6b30ed1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d9-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..cc9e856c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d9-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..7f07ddab --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9d9-1f3fb.svg new file mode 100644 index 00000000..9f5bd361 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d9-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..bc2fb4e8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d9-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..3b981e92 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9d9-1f3fc.svg new file mode 100644 index 00000000..9277d4bd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d9-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..bac7c44b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d9-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..936629d2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9d9-1f3fd.svg new file mode 100644 index 00000000..0bdb235b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d9-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..28105d8c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d9-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..f83e59ba --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9d9-1f3fe.svg new file mode 100644 index 00000000..de5dc071 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d9-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..25279175 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d9-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..91482a15 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9d9-1f3ff.svg new file mode 100644 index 00000000..0bd73e86 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d9-200d-2640-fe0f.svg new file mode 100644 index 00000000..d5b31e5e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9d9-200d-2642-fe0f.svg new file mode 100644 index 00000000..c747b344 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9d9.svg b/qortal-ui-core/emoji/svg/1f9d9.svg new file mode 100644 index 00000000..55370831 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9d9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9da-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..e75c0b20 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9da-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..c8f40156 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9da-1f3fb.svg new file mode 100644 index 00000000..d89d1554 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9da-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..3572c60d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9da-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..89375bde --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9da-1f3fc.svg new file mode 100644 index 00000000..427b84da --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9da-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..9af4964a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9da-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..a614bb1a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9da-1f3fd.svg new file mode 100644 index 00000000..108f96a9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9da-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..00d57b1e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9da-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..7c80a135 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9da-1f3fe.svg new file mode 100644 index 00000000..50d0f22c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9da-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..ce1e45dc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9da-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..4095948e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9da-1f3ff.svg new file mode 100644 index 00000000..68d77af8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9da-200d-2640-fe0f.svg new file mode 100644 index 00000000..7a60a49c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9da-200d-2642-fe0f.svg new file mode 100644 index 00000000..d5385361 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9da.svg b/qortal-ui-core/emoji/svg/1f9da.svg new file mode 100644 index 00000000..5c9ea362 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9da.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9db-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..68c9c959 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9db-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..6c790428 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9db-1f3fb.svg new file mode 100644 index 00000000..a341fe99 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9db-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..93acfc13 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9db-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..fe6e755e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9db-1f3fc.svg new file mode 100644 index 00000000..4fed8b22 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9db-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..5bf1eee4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9db-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..abcb2589 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9db-1f3fd.svg new file mode 100644 index 00000000..21b2a188 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9db-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..aa373a32 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9db-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..bd9e32b8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9db-1f3fe.svg new file mode 100644 index 00000000..e1154e59 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9db-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..443150ac --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9db-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..d611a42c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9db-1f3ff.svg new file mode 100644 index 00000000..a30ee929 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9db-200d-2640-fe0f.svg new file mode 100644 index 00000000..53d6dde1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9db-200d-2642-fe0f.svg new file mode 100644 index 00000000..1f104d13 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9db.svg b/qortal-ui-core/emoji/svg/1f9db.svg new file mode 100644 index 00000000..642dc3a9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9db.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dc-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..e211b06a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dc-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..4263e6a8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9dc-1f3fb.svg new file mode 100644 index 00000000..7529d0eb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dc-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..de8fa732 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dc-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..18637d96 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9dc-1f3fc.svg new file mode 100644 index 00000000..8d014d12 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dc-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..0ad162b3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dc-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..72797108 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9dc-1f3fd.svg new file mode 100644 index 00000000..fcd5e0ab --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dc-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..5f71af9d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dc-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..faeb2fa9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9dc-1f3fe.svg new file mode 100644 index 00000000..e9e20c6e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dc-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..f2932ede --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dc-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..2d28d8d3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9dc-1f3ff.svg new file mode 100644 index 00000000..a075dc9a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dc-200d-2640-fe0f.svg new file mode 100644 index 00000000..750f2433 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dc-200d-2642-fe0f.svg new file mode 100644 index 00000000..07111b5d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dc.svg b/qortal-ui-core/emoji/svg/1f9dc.svg new file mode 100644 index 00000000..52f120c4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dd-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..d561e2d6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dd-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..95c77d46 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-1f3fb.svg b/qortal-ui-core/emoji/svg/1f9dd-1f3fb.svg new file mode 100644 index 00000000..5646b908 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dd-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..e1d2b351 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dd-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..d65388c8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-1f3fc.svg b/qortal-ui-core/emoji/svg/1f9dd-1f3fc.svg new file mode 100644 index 00000000..42462486 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dd-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..a17e8888 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dd-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..9633b7df --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-1f3fd.svg b/qortal-ui-core/emoji/svg/1f9dd-1f3fd.svg new file mode 100644 index 00000000..f96868bf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dd-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..842e9a78 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dd-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..61d69acf --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-1f3fe.svg b/qortal-ui-core/emoji/svg/1f9dd-1f3fe.svg new file mode 100644 index 00000000..e127507a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dd-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..0f6c8c5f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dd-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..49faa092 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-1f3ff.svg b/qortal-ui-core/emoji/svg/1f9dd-1f3ff.svg new file mode 100644 index 00000000..47cf437e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dd-200d-2640-fe0f.svg new file mode 100644 index 00000000..f452ca75 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9dd-200d-2642-fe0f.svg new file mode 100644 index 00000000..f9c1e97a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9dd.svg b/qortal-ui-core/emoji/svg/1f9dd.svg new file mode 100644 index 00000000..3e82899f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9dd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9de-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9de-200d-2640-fe0f.svg new file mode 100644 index 00000000..9893e0ab --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9de-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9de-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9de-200d-2642-fe0f.svg new file mode 100644 index 00000000..af17a48e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9de-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9de.svg b/qortal-ui-core/emoji/svg/1f9de.svg new file mode 100644 index 00000000..95be289b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9de.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9df-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/1f9df-200d-2640-fe0f.svg new file mode 100644 index 00000000..cac9ccfc --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9df-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9df-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/1f9df-200d-2642-fe0f.svg new file mode 100644 index 00000000..21674c3b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9df-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9df.svg b/qortal-ui-core/emoji/svg/1f9df.svg new file mode 100644 index 00000000..596a02fd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9df.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9e0.svg b/qortal-ui-core/emoji/svg/1f9e0.svg new file mode 100644 index 00000000..653427da --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9e0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9e1.svg b/qortal-ui-core/emoji/svg/1f9e1.svg new file mode 100644 index 00000000..0e61b148 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9e1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9e2.svg b/qortal-ui-core/emoji/svg/1f9e2.svg new file mode 100644 index 00000000..c2dd6c6f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9e2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9e3.svg b/qortal-ui-core/emoji/svg/1f9e3.svg new file mode 100644 index 00000000..2c959f44 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9e4.svg b/qortal-ui-core/emoji/svg/1f9e4.svg new file mode 100644 index 00000000..1b028b2a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9e4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9e5.svg b/qortal-ui-core/emoji/svg/1f9e5.svg new file mode 100644 index 00000000..392af563 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9e5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9e6.svg b/qortal-ui-core/emoji/svg/1f9e6.svg new file mode 100644 index 00000000..44fc3108 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9e6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9e7.svg b/qortal-ui-core/emoji/svg/1f9e7.svg new file mode 100644 index 00000000..203e78de --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9e7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9e8.svg b/qortal-ui-core/emoji/svg/1f9e8.svg new file mode 100644 index 00000000..ff038203 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9e8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9e9.svg b/qortal-ui-core/emoji/svg/1f9e9.svg new file mode 100644 index 00000000..ae4bf566 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ea.svg b/qortal-ui-core/emoji/svg/1f9ea.svg new file mode 100644 index 00000000..8116cfa1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9eb.svg b/qortal-ui-core/emoji/svg/1f9eb.svg new file mode 100644 index 00000000..8fdeaf9e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ec.svg b/qortal-ui-core/emoji/svg/1f9ec.svg new file mode 100644 index 00000000..689cc3e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ed.svg b/qortal-ui-core/emoji/svg/1f9ed.svg new file mode 100644 index 00000000..fd3d583e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ee.svg b/qortal-ui-core/emoji/svg/1f9ee.svg new file mode 100644 index 00000000..c619bb0e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ee.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ef.svg b/qortal-ui-core/emoji/svg/1f9ef.svg new file mode 100644 index 00000000..e8b17ac6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ef.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9f0.svg b/qortal-ui-core/emoji/svg/1f9f0.svg new file mode 100644 index 00000000..ae065314 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9f1.svg b/qortal-ui-core/emoji/svg/1f9f1.svg new file mode 100644 index 00000000..c7f34821 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9f1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9f2.svg b/qortal-ui-core/emoji/svg/1f9f2.svg new file mode 100644 index 00000000..e81b4644 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9f3.svg b/qortal-ui-core/emoji/svg/1f9f3.svg new file mode 100644 index 00000000..7de25182 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9f4.svg b/qortal-ui-core/emoji/svg/1f9f4.svg new file mode 100644 index 00000000..2cb39a76 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9f5.svg b/qortal-ui-core/emoji/svg/1f9f5.svg new file mode 100644 index 00000000..3210fbeb --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9f5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9f6.svg b/qortal-ui-core/emoji/svg/1f9f6.svg new file mode 100644 index 00000000..f402fd2a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9f6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9f7.svg b/qortal-ui-core/emoji/svg/1f9f7.svg new file mode 100644 index 00000000..a37a0488 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9f8.svg b/qortal-ui-core/emoji/svg/1f9f8.svg new file mode 100644 index 00000000..87af73b4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9f9.svg b/qortal-ui-core/emoji/svg/1f9f9.svg new file mode 100644 index 00000000..2bcbda87 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9fa.svg b/qortal-ui-core/emoji/svg/1f9fa.svg new file mode 100644 index 00000000..947d9545 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9fb.svg b/qortal-ui-core/emoji/svg/1f9fb.svg new file mode 100644 index 00000000..e8f7252f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9fc.svg b/qortal-ui-core/emoji/svg/1f9fc.svg new file mode 100644 index 00000000..e5b1e02e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9fd.svg b/qortal-ui-core/emoji/svg/1f9fd.svg new file mode 100644 index 00000000..1c957516 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9fe.svg b/qortal-ui-core/emoji/svg/1f9fe.svg new file mode 100644 index 00000000..c6d288cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1f9ff.svg b/qortal-ui-core/emoji/svg/1f9ff.svg new file mode 100644 index 00000000..a45a528f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1f9ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa70.svg b/qortal-ui-core/emoji/svg/1fa70.svg new file mode 100644 index 00000000..a8df4c67 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa70.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa71.svg b/qortal-ui-core/emoji/svg/1fa71.svg new file mode 100644 index 00000000..df3eceba --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa71.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa72.svg b/qortal-ui-core/emoji/svg/1fa72.svg new file mode 100644 index 00000000..7486e6af --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa72.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa73.svg b/qortal-ui-core/emoji/svg/1fa73.svg new file mode 100644 index 00000000..03e70ca8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa73.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa74.svg b/qortal-ui-core/emoji/svg/1fa74.svg new file mode 100644 index 00000000..585265a4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa74.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa78.svg b/qortal-ui-core/emoji/svg/1fa78.svg new file mode 100644 index 00000000..2dc83a56 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa78.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa79.svg b/qortal-ui-core/emoji/svg/1fa79.svg new file mode 100644 index 00000000..41d5722a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa79.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa7a.svg b/qortal-ui-core/emoji/svg/1fa7a.svg new file mode 100644 index 00000000..848c72e6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa7a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa80.svg b/qortal-ui-core/emoji/svg/1fa80.svg new file mode 100644 index 00000000..fc9af9be --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa80.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa81.svg b/qortal-ui-core/emoji/svg/1fa81.svg new file mode 100644 index 00000000..fd8605e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa81.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa82.svg b/qortal-ui-core/emoji/svg/1fa82.svg new file mode 100644 index 00000000..acb16e26 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa82.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa83.svg b/qortal-ui-core/emoji/svg/1fa83.svg new file mode 100644 index 00000000..3de58a8f --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa83.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa84.svg b/qortal-ui-core/emoji/svg/1fa84.svg new file mode 100644 index 00000000..988c7988 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa84.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa85.svg b/qortal-ui-core/emoji/svg/1fa85.svg new file mode 100644 index 00000000..a6b0f602 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa85.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa86.svg b/qortal-ui-core/emoji/svg/1fa86.svg new file mode 100644 index 00000000..fca9a3c8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa86.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa90.svg b/qortal-ui-core/emoji/svg/1fa90.svg new file mode 100644 index 00000000..46a0c53c --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa90.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa91.svg b/qortal-ui-core/emoji/svg/1fa91.svg new file mode 100644 index 00000000..8db58019 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa91.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa92.svg b/qortal-ui-core/emoji/svg/1fa92.svg new file mode 100644 index 00000000..3b261c90 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa92.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa93.svg b/qortal-ui-core/emoji/svg/1fa93.svg new file mode 100644 index 00000000..f886dfae --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa93.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa94.svg b/qortal-ui-core/emoji/svg/1fa94.svg new file mode 100644 index 00000000..34c5f381 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa94.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa95.svg b/qortal-ui-core/emoji/svg/1fa95.svg new file mode 100644 index 00000000..da6e25d0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa95.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa96.svg b/qortal-ui-core/emoji/svg/1fa96.svg new file mode 100644 index 00000000..462cbf5e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa96.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa97.svg b/qortal-ui-core/emoji/svg/1fa97.svg new file mode 100644 index 00000000..c9c21ca2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa97.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa98.svg b/qortal-ui-core/emoji/svg/1fa98.svg new file mode 100644 index 00000000..fa316b12 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa98.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa99.svg b/qortal-ui-core/emoji/svg/1fa99.svg new file mode 100644 index 00000000..04944697 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa99.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa9a.svg b/qortal-ui-core/emoji/svg/1fa9a.svg new file mode 100644 index 00000000..f33a0482 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa9a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa9b.svg b/qortal-ui-core/emoji/svg/1fa9b.svg new file mode 100644 index 00000000..d0b988f6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa9b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa9c.svg b/qortal-ui-core/emoji/svg/1fa9c.svg new file mode 100644 index 00000000..cd3b979e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa9c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa9d.svg b/qortal-ui-core/emoji/svg/1fa9d.svg new file mode 100644 index 00000000..923a96de --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa9d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa9e.svg b/qortal-ui-core/emoji/svg/1fa9e.svg new file mode 100644 index 00000000..b263f10b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa9e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fa9f.svg b/qortal-ui-core/emoji/svg/1fa9f.svg new file mode 100644 index 00000000..8daaad66 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fa9f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1faa0.svg b/qortal-ui-core/emoji/svg/1faa0.svg new file mode 100644 index 00000000..f5422d96 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1faa0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1faa1.svg b/qortal-ui-core/emoji/svg/1faa1.svg new file mode 100644 index 00000000..a99cb160 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1faa1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1faa2.svg b/qortal-ui-core/emoji/svg/1faa2.svg new file mode 100644 index 00000000..fd6a64c1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1faa2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1faa3.svg b/qortal-ui-core/emoji/svg/1faa3.svg new file mode 100644 index 00000000..7be64da1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1faa3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1faa4.svg b/qortal-ui-core/emoji/svg/1faa4.svg new file mode 100644 index 00000000..a680fb70 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1faa4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1faa5.svg b/qortal-ui-core/emoji/svg/1faa5.svg new file mode 100644 index 00000000..9c9e6177 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1faa5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1faa6.svg b/qortal-ui-core/emoji/svg/1faa6.svg new file mode 100644 index 00000000..f4f3a89e --- /dev/null +++ b/qortal-ui-core/emoji/svg/1faa6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1faa7.svg b/qortal-ui-core/emoji/svg/1faa7.svg new file mode 100644 index 00000000..ac1646ba --- /dev/null +++ b/qortal-ui-core/emoji/svg/1faa7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1faa8.svg b/qortal-ui-core/emoji/svg/1faa8.svg new file mode 100644 index 00000000..361fc032 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1faa8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fab0.svg b/qortal-ui-core/emoji/svg/1fab0.svg new file mode 100644 index 00000000..4b13d7e7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fab0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fab1.svg b/qortal-ui-core/emoji/svg/1fab1.svg new file mode 100644 index 00000000..1bc9b9a9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fab1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fab2.svg b/qortal-ui-core/emoji/svg/1fab2.svg new file mode 100644 index 00000000..57fd4bfa --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fab2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fab3.svg b/qortal-ui-core/emoji/svg/1fab3.svg new file mode 100644 index 00000000..f8c8d787 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fab3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fab4.svg b/qortal-ui-core/emoji/svg/1fab4.svg new file mode 100644 index 00000000..92f1547b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fab4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fab5.svg b/qortal-ui-core/emoji/svg/1fab5.svg new file mode 100644 index 00000000..981dd2d1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fab5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fab6.svg b/qortal-ui-core/emoji/svg/1fab6.svg new file mode 100644 index 00000000..8e70d6cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fab6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fac0.svg b/qortal-ui-core/emoji/svg/1fac0.svg new file mode 100644 index 00000000..e6916d27 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fac0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fac1.svg b/qortal-ui-core/emoji/svg/1fac1.svg new file mode 100644 index 00000000..cfdf72f1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fac1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fac2.svg b/qortal-ui-core/emoji/svg/1fac2.svg new file mode 100644 index 00000000..5c0413cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fac2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fad0.svg b/qortal-ui-core/emoji/svg/1fad0.svg new file mode 100644 index 00000000..34e68d6b --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fad0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fad1.svg b/qortal-ui-core/emoji/svg/1fad1.svg new file mode 100644 index 00000000..b0d52427 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fad1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fad2.svg b/qortal-ui-core/emoji/svg/1fad2.svg new file mode 100644 index 00000000..b84ce6a1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fad2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fad3.svg b/qortal-ui-core/emoji/svg/1fad3.svg new file mode 100644 index 00000000..25c1842d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fad3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fad4.svg b/qortal-ui-core/emoji/svg/1fad4.svg new file mode 100644 index 00000000..34a6215a --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fad4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fad5.svg b/qortal-ui-core/emoji/svg/1fad5.svg new file mode 100644 index 00000000..1133788d --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fad5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/1fad6.svg b/qortal-ui-core/emoji/svg/1fad6.svg new file mode 100644 index 00000000..9e6894da --- /dev/null +++ b/qortal-ui-core/emoji/svg/1fad6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/203c.svg b/qortal-ui-core/emoji/svg/203c.svg new file mode 100644 index 00000000..d3579ee3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/203c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2049.svg b/qortal-ui-core/emoji/svg/2049.svg new file mode 100644 index 00000000..8cf99853 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2049.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2122.svg b/qortal-ui-core/emoji/svg/2122.svg new file mode 100644 index 00000000..1706c28b --- /dev/null +++ b/qortal-ui-core/emoji/svg/2122.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2139.svg b/qortal-ui-core/emoji/svg/2139.svg new file mode 100644 index 00000000..bc341553 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2139.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2194.svg b/qortal-ui-core/emoji/svg/2194.svg new file mode 100644 index 00000000..9884b428 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2194.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2195.svg b/qortal-ui-core/emoji/svg/2195.svg new file mode 100644 index 00000000..e7a52544 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2195.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2196.svg b/qortal-ui-core/emoji/svg/2196.svg new file mode 100644 index 00000000..a6889d1e --- /dev/null +++ b/qortal-ui-core/emoji/svg/2196.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2197.svg b/qortal-ui-core/emoji/svg/2197.svg new file mode 100644 index 00000000..62e4c0ff --- /dev/null +++ b/qortal-ui-core/emoji/svg/2197.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2198.svg b/qortal-ui-core/emoji/svg/2198.svg new file mode 100644 index 00000000..129dd629 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2198.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2199.svg b/qortal-ui-core/emoji/svg/2199.svg new file mode 100644 index 00000000..f327e40f --- /dev/null +++ b/qortal-ui-core/emoji/svg/2199.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/21a9.svg b/qortal-ui-core/emoji/svg/21a9.svg new file mode 100644 index 00000000..0a390043 --- /dev/null +++ b/qortal-ui-core/emoji/svg/21a9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/21aa.svg b/qortal-ui-core/emoji/svg/21aa.svg new file mode 100644 index 00000000..a9c586eb --- /dev/null +++ b/qortal-ui-core/emoji/svg/21aa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23-20e3.svg b/qortal-ui-core/emoji/svg/23-20e3.svg new file mode 100644 index 00000000..f2f10110 --- /dev/null +++ b/qortal-ui-core/emoji/svg/23-20e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/231a.svg b/qortal-ui-core/emoji/svg/231a.svg new file mode 100644 index 00000000..53e6f6ef --- /dev/null +++ b/qortal-ui-core/emoji/svg/231a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/231b.svg b/qortal-ui-core/emoji/svg/231b.svg new file mode 100644 index 00000000..ed66084f --- /dev/null +++ b/qortal-ui-core/emoji/svg/231b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2328.svg b/qortal-ui-core/emoji/svg/2328.svg new file mode 100644 index 00000000..c834ed64 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2328.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23cf.svg b/qortal-ui-core/emoji/svg/23cf.svg new file mode 100644 index 00000000..d53497c1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/23cf.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23e9.svg b/qortal-ui-core/emoji/svg/23e9.svg new file mode 100644 index 00000000..1ef719cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/23e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23ea.svg b/qortal-ui-core/emoji/svg/23ea.svg new file mode 100644 index 00000000..0510ac7b --- /dev/null +++ b/qortal-ui-core/emoji/svg/23ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23eb.svg b/qortal-ui-core/emoji/svg/23eb.svg new file mode 100644 index 00000000..a33e0f84 --- /dev/null +++ b/qortal-ui-core/emoji/svg/23eb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23ec.svg b/qortal-ui-core/emoji/svg/23ec.svg new file mode 100644 index 00000000..5846faec --- /dev/null +++ b/qortal-ui-core/emoji/svg/23ec.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23ed.svg b/qortal-ui-core/emoji/svg/23ed.svg new file mode 100644 index 00000000..6e66128d --- /dev/null +++ b/qortal-ui-core/emoji/svg/23ed.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23ee.svg b/qortal-ui-core/emoji/svg/23ee.svg new file mode 100644 index 00000000..889b1625 --- /dev/null +++ b/qortal-ui-core/emoji/svg/23ee.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23ef.svg b/qortal-ui-core/emoji/svg/23ef.svg new file mode 100644 index 00000000..69c3d2d1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/23ef.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23f0.svg b/qortal-ui-core/emoji/svg/23f0.svg new file mode 100644 index 00000000..ea9ad143 --- /dev/null +++ b/qortal-ui-core/emoji/svg/23f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23f1.svg b/qortal-ui-core/emoji/svg/23f1.svg new file mode 100644 index 00000000..599d2469 --- /dev/null +++ b/qortal-ui-core/emoji/svg/23f1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23f2.svg b/qortal-ui-core/emoji/svg/23f2.svg new file mode 100644 index 00000000..7cb6e02a --- /dev/null +++ b/qortal-ui-core/emoji/svg/23f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23f3.svg b/qortal-ui-core/emoji/svg/23f3.svg new file mode 100644 index 00000000..34915044 --- /dev/null +++ b/qortal-ui-core/emoji/svg/23f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23f8.svg b/qortal-ui-core/emoji/svg/23f8.svg new file mode 100644 index 00000000..9cb0ac8d --- /dev/null +++ b/qortal-ui-core/emoji/svg/23f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23f9.svg b/qortal-ui-core/emoji/svg/23f9.svg new file mode 100644 index 00000000..c38882ab --- /dev/null +++ b/qortal-ui-core/emoji/svg/23f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/23fa.svg b/qortal-ui-core/emoji/svg/23fa.svg new file mode 100644 index 00000000..e8dfcca3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/23fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/24c2.svg b/qortal-ui-core/emoji/svg/24c2.svg new file mode 100644 index 00000000..29a94297 --- /dev/null +++ b/qortal-ui-core/emoji/svg/24c2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/25aa.svg b/qortal-ui-core/emoji/svg/25aa.svg new file mode 100644 index 00000000..cb4f63bc --- /dev/null +++ b/qortal-ui-core/emoji/svg/25aa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/25ab.svg b/qortal-ui-core/emoji/svg/25ab.svg new file mode 100644 index 00000000..6d1f796a --- /dev/null +++ b/qortal-ui-core/emoji/svg/25ab.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/25b6.svg b/qortal-ui-core/emoji/svg/25b6.svg new file mode 100644 index 00000000..b373a4f7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/25b6.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/25c0.svg b/qortal-ui-core/emoji/svg/25c0.svg new file mode 100644 index 00000000..af74e9c2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/25c0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/25fb.svg b/qortal-ui-core/emoji/svg/25fb.svg new file mode 100644 index 00000000..eb40d149 --- /dev/null +++ b/qortal-ui-core/emoji/svg/25fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/25fc.svg b/qortal-ui-core/emoji/svg/25fc.svg new file mode 100644 index 00000000..b91ca805 --- /dev/null +++ b/qortal-ui-core/emoji/svg/25fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/25fd.svg b/qortal-ui-core/emoji/svg/25fd.svg new file mode 100644 index 00000000..6f737772 --- /dev/null +++ b/qortal-ui-core/emoji/svg/25fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/25fe.svg b/qortal-ui-core/emoji/svg/25fe.svg new file mode 100644 index 00000000..9c0abf0f --- /dev/null +++ b/qortal-ui-core/emoji/svg/25fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2600.svg b/qortal-ui-core/emoji/svg/2600.svg new file mode 100644 index 00000000..8602baef --- /dev/null +++ b/qortal-ui-core/emoji/svg/2600.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2601.svg b/qortal-ui-core/emoji/svg/2601.svg new file mode 100644 index 00000000..928baa60 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2601.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2602.svg b/qortal-ui-core/emoji/svg/2602.svg new file mode 100644 index 00000000..7c633302 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2602.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2603.svg b/qortal-ui-core/emoji/svg/2603.svg new file mode 100644 index 00000000..c02380e0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2603.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2604.svg b/qortal-ui-core/emoji/svg/2604.svg new file mode 100644 index 00000000..07df915c --- /dev/null +++ b/qortal-ui-core/emoji/svg/2604.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/260e.svg b/qortal-ui-core/emoji/svg/260e.svg new file mode 100644 index 00000000..e65124fa --- /dev/null +++ b/qortal-ui-core/emoji/svg/260e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2611.svg b/qortal-ui-core/emoji/svg/2611.svg new file mode 100644 index 00000000..904d0fc8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2611.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2614.svg b/qortal-ui-core/emoji/svg/2614.svg new file mode 100644 index 00000000..6240aa66 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2614.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2615.svg b/qortal-ui-core/emoji/svg/2615.svg new file mode 100644 index 00000000..bb68dd5e --- /dev/null +++ b/qortal-ui-core/emoji/svg/2615.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2618.svg b/qortal-ui-core/emoji/svg/2618.svg new file mode 100644 index 00000000..72eaf475 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2618.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/261d-1f3fb.svg b/qortal-ui-core/emoji/svg/261d-1f3fb.svg new file mode 100644 index 00000000..854b494b --- /dev/null +++ b/qortal-ui-core/emoji/svg/261d-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/261d-1f3fc.svg b/qortal-ui-core/emoji/svg/261d-1f3fc.svg new file mode 100644 index 00000000..76dac4ee --- /dev/null +++ b/qortal-ui-core/emoji/svg/261d-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/261d-1f3fd.svg b/qortal-ui-core/emoji/svg/261d-1f3fd.svg new file mode 100644 index 00000000..e03f60e1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/261d-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/261d-1f3fe.svg b/qortal-ui-core/emoji/svg/261d-1f3fe.svg new file mode 100644 index 00000000..a8394562 --- /dev/null +++ b/qortal-ui-core/emoji/svg/261d-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/261d-1f3ff.svg b/qortal-ui-core/emoji/svg/261d-1f3ff.svg new file mode 100644 index 00000000..85884955 --- /dev/null +++ b/qortal-ui-core/emoji/svg/261d-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/261d.svg b/qortal-ui-core/emoji/svg/261d.svg new file mode 100644 index 00000000..95d8ddd1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/261d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2620.svg b/qortal-ui-core/emoji/svg/2620.svg new file mode 100644 index 00000000..66f9862c --- /dev/null +++ b/qortal-ui-core/emoji/svg/2620.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2622.svg b/qortal-ui-core/emoji/svg/2622.svg new file mode 100644 index 00000000..2039db1b --- /dev/null +++ b/qortal-ui-core/emoji/svg/2622.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2623.svg b/qortal-ui-core/emoji/svg/2623.svg new file mode 100644 index 00000000..6e7d8584 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2623.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2626.svg b/qortal-ui-core/emoji/svg/2626.svg new file mode 100644 index 00000000..4d02f16e --- /dev/null +++ b/qortal-ui-core/emoji/svg/2626.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/262a.svg b/qortal-ui-core/emoji/svg/262a.svg new file mode 100644 index 00000000..678a1e8f --- /dev/null +++ b/qortal-ui-core/emoji/svg/262a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/262e.svg b/qortal-ui-core/emoji/svg/262e.svg new file mode 100644 index 00000000..a0be08a3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/262e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/262f.svg b/qortal-ui-core/emoji/svg/262f.svg new file mode 100644 index 00000000..e0aff80c --- /dev/null +++ b/qortal-ui-core/emoji/svg/262f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2638.svg b/qortal-ui-core/emoji/svg/2638.svg new file mode 100644 index 00000000..a00bf1d4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2638.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2639.svg b/qortal-ui-core/emoji/svg/2639.svg new file mode 100644 index 00000000..a2a49090 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2639.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/263a.svg b/qortal-ui-core/emoji/svg/263a.svg new file mode 100644 index 00000000..50201340 --- /dev/null +++ b/qortal-ui-core/emoji/svg/263a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2640.svg b/qortal-ui-core/emoji/svg/2640.svg new file mode 100644 index 00000000..db5291c3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2640.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2642.svg b/qortal-ui-core/emoji/svg/2642.svg new file mode 100644 index 00000000..29868a85 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2642.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2648.svg b/qortal-ui-core/emoji/svg/2648.svg new file mode 100644 index 00000000..0f00d2db --- /dev/null +++ b/qortal-ui-core/emoji/svg/2648.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2649.svg b/qortal-ui-core/emoji/svg/2649.svg new file mode 100644 index 00000000..6e9918a3 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2649.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/264a.svg b/qortal-ui-core/emoji/svg/264a.svg new file mode 100644 index 00000000..9f056423 --- /dev/null +++ b/qortal-ui-core/emoji/svg/264a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/264b.svg b/qortal-ui-core/emoji/svg/264b.svg new file mode 100644 index 00000000..c5c8b662 --- /dev/null +++ b/qortal-ui-core/emoji/svg/264b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/264c.svg b/qortal-ui-core/emoji/svg/264c.svg new file mode 100644 index 00000000..e9af63db --- /dev/null +++ b/qortal-ui-core/emoji/svg/264c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/264d.svg b/qortal-ui-core/emoji/svg/264d.svg new file mode 100644 index 00000000..98ad1a87 --- /dev/null +++ b/qortal-ui-core/emoji/svg/264d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/264e.svg b/qortal-ui-core/emoji/svg/264e.svg new file mode 100644 index 00000000..11583c19 --- /dev/null +++ b/qortal-ui-core/emoji/svg/264e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/264f.svg b/qortal-ui-core/emoji/svg/264f.svg new file mode 100644 index 00000000..ec1b93ae --- /dev/null +++ b/qortal-ui-core/emoji/svg/264f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2650.svg b/qortal-ui-core/emoji/svg/2650.svg new file mode 100644 index 00000000..df13efca --- /dev/null +++ b/qortal-ui-core/emoji/svg/2650.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2651.svg b/qortal-ui-core/emoji/svg/2651.svg new file mode 100644 index 00000000..f3ccf92c --- /dev/null +++ b/qortal-ui-core/emoji/svg/2651.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2652.svg b/qortal-ui-core/emoji/svg/2652.svg new file mode 100644 index 00000000..41e46232 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2652.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2653.svg b/qortal-ui-core/emoji/svg/2653.svg new file mode 100644 index 00000000..854032a8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2653.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/265f.svg b/qortal-ui-core/emoji/svg/265f.svg new file mode 100644 index 00000000..10c880c2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/265f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2660.svg b/qortal-ui-core/emoji/svg/2660.svg new file mode 100644 index 00000000..5f7b1091 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2660.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2663.svg b/qortal-ui-core/emoji/svg/2663.svg new file mode 100644 index 00000000..a9dce6f2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2663.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2665.svg b/qortal-ui-core/emoji/svg/2665.svg new file mode 100644 index 00000000..67f49c3d --- /dev/null +++ b/qortal-ui-core/emoji/svg/2665.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2666.svg b/qortal-ui-core/emoji/svg/2666.svg new file mode 100644 index 00000000..02f93aad --- /dev/null +++ b/qortal-ui-core/emoji/svg/2666.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2668.svg b/qortal-ui-core/emoji/svg/2668.svg new file mode 100644 index 00000000..4a87beaa --- /dev/null +++ b/qortal-ui-core/emoji/svg/2668.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/267b.svg b/qortal-ui-core/emoji/svg/267b.svg new file mode 100644 index 00000000..06352b9f --- /dev/null +++ b/qortal-ui-core/emoji/svg/267b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/267e.svg b/qortal-ui-core/emoji/svg/267e.svg new file mode 100644 index 00000000..03df2a6a --- /dev/null +++ b/qortal-ui-core/emoji/svg/267e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/267f.svg b/qortal-ui-core/emoji/svg/267f.svg new file mode 100644 index 00000000..b1d1c424 --- /dev/null +++ b/qortal-ui-core/emoji/svg/267f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2692.svg b/qortal-ui-core/emoji/svg/2692.svg new file mode 100644 index 00000000..3a8ff265 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2692.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2693.svg b/qortal-ui-core/emoji/svg/2693.svg new file mode 100644 index 00000000..09f3fe41 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2693.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2694.svg b/qortal-ui-core/emoji/svg/2694.svg new file mode 100644 index 00000000..325b85f1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2694.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2695.svg b/qortal-ui-core/emoji/svg/2695.svg new file mode 100644 index 00000000..add4c0e7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2695.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2696.svg b/qortal-ui-core/emoji/svg/2696.svg new file mode 100644 index 00000000..61af8441 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2696.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2697.svg b/qortal-ui-core/emoji/svg/2697.svg new file mode 100644 index 00000000..3fe8c15b --- /dev/null +++ b/qortal-ui-core/emoji/svg/2697.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2699.svg b/qortal-ui-core/emoji/svg/2699.svg new file mode 100644 index 00000000..635ca02f --- /dev/null +++ b/qortal-ui-core/emoji/svg/2699.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/269b.svg b/qortal-ui-core/emoji/svg/269b.svg new file mode 100644 index 00000000..385c18ce --- /dev/null +++ b/qortal-ui-core/emoji/svg/269b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/269c.svg b/qortal-ui-core/emoji/svg/269c.svg new file mode 100644 index 00000000..27be9c33 --- /dev/null +++ b/qortal-ui-core/emoji/svg/269c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26a0.svg b/qortal-ui-core/emoji/svg/26a0.svg new file mode 100644 index 00000000..b9ee2973 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26a0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26a1.svg b/qortal-ui-core/emoji/svg/26a1.svg new file mode 100644 index 00000000..9d9ae7d9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26a1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26a7.svg b/qortal-ui-core/emoji/svg/26a7.svg new file mode 100644 index 00000000..0d0b230b --- /dev/null +++ b/qortal-ui-core/emoji/svg/26a7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26aa.svg b/qortal-ui-core/emoji/svg/26aa.svg new file mode 100644 index 00000000..60b9bbc0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26aa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26ab.svg b/qortal-ui-core/emoji/svg/26ab.svg new file mode 100644 index 00000000..169b72cc --- /dev/null +++ b/qortal-ui-core/emoji/svg/26ab.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26b0.svg b/qortal-ui-core/emoji/svg/26b0.svg new file mode 100644 index 00000000..c1ea4d6e --- /dev/null +++ b/qortal-ui-core/emoji/svg/26b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26b1.svg b/qortal-ui-core/emoji/svg/26b1.svg new file mode 100644 index 00000000..830c81aa --- /dev/null +++ b/qortal-ui-core/emoji/svg/26b1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26bd.svg b/qortal-ui-core/emoji/svg/26bd.svg new file mode 100644 index 00000000..f24749cb --- /dev/null +++ b/qortal-ui-core/emoji/svg/26bd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26be.svg b/qortal-ui-core/emoji/svg/26be.svg new file mode 100644 index 00000000..210b8ef8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26be.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26c4.svg b/qortal-ui-core/emoji/svg/26c4.svg new file mode 100644 index 00000000..74caddf4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26c4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26c5.svg b/qortal-ui-core/emoji/svg/26c5.svg new file mode 100644 index 00000000..89d57dc5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26c5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26c8.svg b/qortal-ui-core/emoji/svg/26c8.svg new file mode 100644 index 00000000..878ba81b --- /dev/null +++ b/qortal-ui-core/emoji/svg/26c8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26ce.svg b/qortal-ui-core/emoji/svg/26ce.svg new file mode 100644 index 00000000..4abec026 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26ce.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26cf.svg b/qortal-ui-core/emoji/svg/26cf.svg new file mode 100644 index 00000000..ac8ac017 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26cf.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26d1.svg b/qortal-ui-core/emoji/svg/26d1.svg new file mode 100644 index 00000000..e8457ae2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26d1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26d3.svg b/qortal-ui-core/emoji/svg/26d3.svg new file mode 100644 index 00000000..a7b213e8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26d3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26d4.svg b/qortal-ui-core/emoji/svg/26d4.svg new file mode 100644 index 00000000..fcab3011 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26d4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26e9.svg b/qortal-ui-core/emoji/svg/26e9.svg new file mode 100644 index 00000000..395048eb --- /dev/null +++ b/qortal-ui-core/emoji/svg/26e9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26ea.svg b/qortal-ui-core/emoji/svg/26ea.svg new file mode 100644 index 00000000..79b8ce50 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26ea.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f0.svg b/qortal-ui-core/emoji/svg/26f0.svg new file mode 100644 index 00000000..ba331d13 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f1.svg b/qortal-ui-core/emoji/svg/26f1.svg new file mode 100644 index 00000000..589f3850 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f2.svg b/qortal-ui-core/emoji/svg/26f2.svg new file mode 100644 index 00000000..659c2285 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f2.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f3.svg b/qortal-ui-core/emoji/svg/26f3.svg new file mode 100644 index 00000000..c4f8916c --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f4.svg b/qortal-ui-core/emoji/svg/26f4.svg new file mode 100644 index 00000000..70b35429 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f4.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f5.svg b/qortal-ui-core/emoji/svg/26f5.svg new file mode 100644 index 00000000..c76c0ded --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f5.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f7-1f3fb.svg b/qortal-ui-core/emoji/svg/26f7-1f3fb.svg new file mode 100644 index 00000000..e62b3406 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f7-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f7-1f3fc.svg b/qortal-ui-core/emoji/svg/26f7-1f3fc.svg new file mode 100644 index 00000000..38dac4b1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f7-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f7-1f3fd.svg b/qortal-ui-core/emoji/svg/26f7-1f3fd.svg new file mode 100644 index 00000000..88013381 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f7-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f7-1f3fe.svg b/qortal-ui-core/emoji/svg/26f7-1f3fe.svg new file mode 100644 index 00000000..cb4c3011 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f7-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f7-1f3ff.svg b/qortal-ui-core/emoji/svg/26f7-1f3ff.svg new file mode 100644 index 00000000..4184e4a4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f7-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f7.svg b/qortal-ui-core/emoji/svg/26f7.svg new file mode 100644 index 00000000..ade6f21b --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f7.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f8.svg b/qortal-ui-core/emoji/svg/26f8.svg new file mode 100644 index 00000000..022e86e7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f8.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-1f3fb-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/26f9-1f3fb-200d-2640-fe0f.svg new file mode 100644 index 00000000..8a00ebc8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-1f3fb-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-1f3fb-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/26f9-1f3fb-200d-2642-fe0f.svg new file mode 100644 index 00000000..78a8b5d4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-1f3fb-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-1f3fb.svg b/qortal-ui-core/emoji/svg/26f9-1f3fb.svg new file mode 100644 index 00000000..836b94b8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-1f3fc-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/26f9-1f3fc-200d-2640-fe0f.svg new file mode 100644 index 00000000..8bcada01 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-1f3fc-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-1f3fc-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/26f9-1f3fc-200d-2642-fe0f.svg new file mode 100644 index 00000000..fb2b1e1b --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-1f3fc-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-1f3fc.svg b/qortal-ui-core/emoji/svg/26f9-1f3fc.svg new file mode 100644 index 00000000..0c3662e1 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-1f3fd-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/26f9-1f3fd-200d-2640-fe0f.svg new file mode 100644 index 00000000..edb6001b --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-1f3fd-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-1f3fd-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/26f9-1f3fd-200d-2642-fe0f.svg new file mode 100644 index 00000000..9282cee9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-1f3fd-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-1f3fd.svg b/qortal-ui-core/emoji/svg/26f9-1f3fd.svg new file mode 100644 index 00000000..ee2eb378 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-1f3fe-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/26f9-1f3fe-200d-2640-fe0f.svg new file mode 100644 index 00000000..5eee2813 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-1f3fe-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-1f3fe-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/26f9-1f3fe-200d-2642-fe0f.svg new file mode 100644 index 00000000..d618e5a4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-1f3fe-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-1f3fe.svg b/qortal-ui-core/emoji/svg/26f9-1f3fe.svg new file mode 100644 index 00000000..f6687c66 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-1f3ff-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/26f9-1f3ff-200d-2640-fe0f.svg new file mode 100644 index 00000000..52dcb9be --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-1f3ff-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-1f3ff-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/26f9-1f3ff-200d-2642-fe0f.svg new file mode 100644 index 00000000..c174ef8b --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-1f3ff-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-1f3ff.svg b/qortal-ui-core/emoji/svg/26f9-1f3ff.svg new file mode 100644 index 00000000..435b37b8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-fe0f-200d-2640-fe0f.svg b/qortal-ui-core/emoji/svg/26f9-fe0f-200d-2640-fe0f.svg new file mode 100644 index 00000000..f25f03db --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-fe0f-200d-2640-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9-fe0f-200d-2642-fe0f.svg b/qortal-ui-core/emoji/svg/26f9-fe0f-200d-2642-fe0f.svg new file mode 100644 index 00000000..ee014e40 --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9-fe0f-200d-2642-fe0f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26f9.svg b/qortal-ui-core/emoji/svg/26f9.svg new file mode 100644 index 00000000..e772c2cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/26f9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26fa.svg b/qortal-ui-core/emoji/svg/26fa.svg new file mode 100644 index 00000000..72c5cbdc --- /dev/null +++ b/qortal-ui-core/emoji/svg/26fa.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/26fd.svg b/qortal-ui-core/emoji/svg/26fd.svg new file mode 100644 index 00000000..0081947d --- /dev/null +++ b/qortal-ui-core/emoji/svg/26fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2702.svg b/qortal-ui-core/emoji/svg/2702.svg new file mode 100644 index 00000000..e5d3ac1f --- /dev/null +++ b/qortal-ui-core/emoji/svg/2702.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2705.svg b/qortal-ui-core/emoji/svg/2705.svg new file mode 100644 index 00000000..9817a091 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2705.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2708.svg b/qortal-ui-core/emoji/svg/2708.svg new file mode 100644 index 00000000..ebce3afb --- /dev/null +++ b/qortal-ui-core/emoji/svg/2708.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2709.svg b/qortal-ui-core/emoji/svg/2709.svg new file mode 100644 index 00000000..d880c420 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2709.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270a-1f3fb.svg b/qortal-ui-core/emoji/svg/270a-1f3fb.svg new file mode 100644 index 00000000..1929efb8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/270a-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270a-1f3fc.svg b/qortal-ui-core/emoji/svg/270a-1f3fc.svg new file mode 100644 index 00000000..09dc7d3b --- /dev/null +++ b/qortal-ui-core/emoji/svg/270a-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270a-1f3fd.svg b/qortal-ui-core/emoji/svg/270a-1f3fd.svg new file mode 100644 index 00000000..329832da --- /dev/null +++ b/qortal-ui-core/emoji/svg/270a-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270a-1f3fe.svg b/qortal-ui-core/emoji/svg/270a-1f3fe.svg new file mode 100644 index 00000000..b4bcfc5c --- /dev/null +++ b/qortal-ui-core/emoji/svg/270a-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270a-1f3ff.svg b/qortal-ui-core/emoji/svg/270a-1f3ff.svg new file mode 100644 index 00000000..e7dd06eb --- /dev/null +++ b/qortal-ui-core/emoji/svg/270a-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270a.svg b/qortal-ui-core/emoji/svg/270a.svg new file mode 100644 index 00000000..99910432 --- /dev/null +++ b/qortal-ui-core/emoji/svg/270a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270b-1f3fb.svg b/qortal-ui-core/emoji/svg/270b-1f3fb.svg new file mode 100644 index 00000000..5b64565d --- /dev/null +++ b/qortal-ui-core/emoji/svg/270b-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270b-1f3fc.svg b/qortal-ui-core/emoji/svg/270b-1f3fc.svg new file mode 100644 index 00000000..3f69cc70 --- /dev/null +++ b/qortal-ui-core/emoji/svg/270b-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270b-1f3fd.svg b/qortal-ui-core/emoji/svg/270b-1f3fd.svg new file mode 100644 index 00000000..02f74174 --- /dev/null +++ b/qortal-ui-core/emoji/svg/270b-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270b-1f3fe.svg b/qortal-ui-core/emoji/svg/270b-1f3fe.svg new file mode 100644 index 00000000..ed89dbac --- /dev/null +++ b/qortal-ui-core/emoji/svg/270b-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270b-1f3ff.svg b/qortal-ui-core/emoji/svg/270b-1f3ff.svg new file mode 100644 index 00000000..74072202 --- /dev/null +++ b/qortal-ui-core/emoji/svg/270b-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270b.svg b/qortal-ui-core/emoji/svg/270b.svg new file mode 100644 index 00000000..31576f16 --- /dev/null +++ b/qortal-ui-core/emoji/svg/270b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270c-1f3fb.svg b/qortal-ui-core/emoji/svg/270c-1f3fb.svg new file mode 100644 index 00000000..a95327ab --- /dev/null +++ b/qortal-ui-core/emoji/svg/270c-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270c-1f3fc.svg b/qortal-ui-core/emoji/svg/270c-1f3fc.svg new file mode 100644 index 00000000..d748f209 --- /dev/null +++ b/qortal-ui-core/emoji/svg/270c-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270c-1f3fd.svg b/qortal-ui-core/emoji/svg/270c-1f3fd.svg new file mode 100644 index 00000000..f93272ac --- /dev/null +++ b/qortal-ui-core/emoji/svg/270c-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270c-1f3fe.svg b/qortal-ui-core/emoji/svg/270c-1f3fe.svg new file mode 100644 index 00000000..aca5302c --- /dev/null +++ b/qortal-ui-core/emoji/svg/270c-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270c-1f3ff.svg b/qortal-ui-core/emoji/svg/270c-1f3ff.svg new file mode 100644 index 00000000..3fa97429 --- /dev/null +++ b/qortal-ui-core/emoji/svg/270c-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270c.svg b/qortal-ui-core/emoji/svg/270c.svg new file mode 100644 index 00000000..730545f5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/270c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270d-1f3fb.svg b/qortal-ui-core/emoji/svg/270d-1f3fb.svg new file mode 100644 index 00000000..91eaf47d --- /dev/null +++ b/qortal-ui-core/emoji/svg/270d-1f3fb.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270d-1f3fc.svg b/qortal-ui-core/emoji/svg/270d-1f3fc.svg new file mode 100644 index 00000000..b404d7fc --- /dev/null +++ b/qortal-ui-core/emoji/svg/270d-1f3fc.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270d-1f3fd.svg b/qortal-ui-core/emoji/svg/270d-1f3fd.svg new file mode 100644 index 00000000..a1cbd763 --- /dev/null +++ b/qortal-ui-core/emoji/svg/270d-1f3fd.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270d-1f3fe.svg b/qortal-ui-core/emoji/svg/270d-1f3fe.svg new file mode 100644 index 00000000..20b99225 --- /dev/null +++ b/qortal-ui-core/emoji/svg/270d-1f3fe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270d-1f3ff.svg b/qortal-ui-core/emoji/svg/270d-1f3ff.svg new file mode 100644 index 00000000..ef0383f0 --- /dev/null +++ b/qortal-ui-core/emoji/svg/270d-1f3ff.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270d.svg b/qortal-ui-core/emoji/svg/270d.svg new file mode 100644 index 00000000..f1385847 --- /dev/null +++ b/qortal-ui-core/emoji/svg/270d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/270f.svg b/qortal-ui-core/emoji/svg/270f.svg new file mode 100644 index 00000000..a9b69e1b --- /dev/null +++ b/qortal-ui-core/emoji/svg/270f.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2712.svg b/qortal-ui-core/emoji/svg/2712.svg new file mode 100644 index 00000000..8eaec690 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2712.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2714.svg b/qortal-ui-core/emoji/svg/2714.svg new file mode 100644 index 00000000..17972389 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2714.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2716.svg b/qortal-ui-core/emoji/svg/2716.svg new file mode 100644 index 00000000..d1023730 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2716.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/271d.svg b/qortal-ui-core/emoji/svg/271d.svg new file mode 100644 index 00000000..270b812e --- /dev/null +++ b/qortal-ui-core/emoji/svg/271d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2721.svg b/qortal-ui-core/emoji/svg/2721.svg new file mode 100644 index 00000000..bdf63ac5 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2721.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2728.svg b/qortal-ui-core/emoji/svg/2728.svg new file mode 100644 index 00000000..347ad12a --- /dev/null +++ b/qortal-ui-core/emoji/svg/2728.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2733.svg b/qortal-ui-core/emoji/svg/2733.svg new file mode 100644 index 00000000..0aac14f2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2733.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2734.svg b/qortal-ui-core/emoji/svg/2734.svg new file mode 100644 index 00000000..17ed8198 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2734.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2744.svg b/qortal-ui-core/emoji/svg/2744.svg new file mode 100644 index 00000000..258c161b --- /dev/null +++ b/qortal-ui-core/emoji/svg/2744.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2747.svg b/qortal-ui-core/emoji/svg/2747.svg new file mode 100644 index 00000000..61e19972 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2747.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/274c.svg b/qortal-ui-core/emoji/svg/274c.svg new file mode 100644 index 00000000..4d76e24b --- /dev/null +++ b/qortal-ui-core/emoji/svg/274c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/274e.svg b/qortal-ui-core/emoji/svg/274e.svg new file mode 100644 index 00000000..814a6e44 --- /dev/null +++ b/qortal-ui-core/emoji/svg/274e.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2753.svg b/qortal-ui-core/emoji/svg/2753.svg new file mode 100644 index 00000000..d76931bc --- /dev/null +++ b/qortal-ui-core/emoji/svg/2753.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2754.svg b/qortal-ui-core/emoji/svg/2754.svg new file mode 100644 index 00000000..ab6b64bf --- /dev/null +++ b/qortal-ui-core/emoji/svg/2754.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2755.svg b/qortal-ui-core/emoji/svg/2755.svg new file mode 100644 index 00000000..40881c53 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2755.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2757.svg b/qortal-ui-core/emoji/svg/2757.svg new file mode 100644 index 00000000..e730a083 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2757.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2763.svg b/qortal-ui-core/emoji/svg/2763.svg new file mode 100644 index 00000000..b78e8783 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2763.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2764.svg b/qortal-ui-core/emoji/svg/2764.svg new file mode 100644 index 00000000..7eb5c591 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2764.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2795.svg b/qortal-ui-core/emoji/svg/2795.svg new file mode 100644 index 00000000..5d55ec2d --- /dev/null +++ b/qortal-ui-core/emoji/svg/2795.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2796.svg b/qortal-ui-core/emoji/svg/2796.svg new file mode 100644 index 00000000..589c0127 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2796.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2797.svg b/qortal-ui-core/emoji/svg/2797.svg new file mode 100644 index 00000000..6b8a7c17 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2797.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/27a1.svg b/qortal-ui-core/emoji/svg/27a1.svg new file mode 100644 index 00000000..55d2d628 --- /dev/null +++ b/qortal-ui-core/emoji/svg/27a1.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/27b0.svg b/qortal-ui-core/emoji/svg/27b0.svg new file mode 100644 index 00000000..33abaa91 --- /dev/null +++ b/qortal-ui-core/emoji/svg/27b0.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/27bf.svg b/qortal-ui-core/emoji/svg/27bf.svg new file mode 100644 index 00000000..0d7b5fac --- /dev/null +++ b/qortal-ui-core/emoji/svg/27bf.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2934.svg b/qortal-ui-core/emoji/svg/2934.svg new file mode 100644 index 00000000..7c2e6753 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2934.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2935.svg b/qortal-ui-core/emoji/svg/2935.svg new file mode 100644 index 00000000..e06163b8 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2935.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2a-20e3.svg b/qortal-ui-core/emoji/svg/2a-20e3.svg new file mode 100644 index 00000000..d9c53c99 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2a-20e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2b05.svg b/qortal-ui-core/emoji/svg/2b05.svg new file mode 100644 index 00000000..6ac3f634 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2b05.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2b06.svg b/qortal-ui-core/emoji/svg/2b06.svg new file mode 100644 index 00000000..080ca199 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2b06.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2b07.svg b/qortal-ui-core/emoji/svg/2b07.svg new file mode 100644 index 00000000..ed33773f --- /dev/null +++ b/qortal-ui-core/emoji/svg/2b07.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2b1b.svg b/qortal-ui-core/emoji/svg/2b1b.svg new file mode 100644 index 00000000..42b60e34 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2b1b.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2b1c.svg b/qortal-ui-core/emoji/svg/2b1c.svg new file mode 100644 index 00000000..a40e12e2 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2b1c.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2b50.svg b/qortal-ui-core/emoji/svg/2b50.svg new file mode 100644 index 00000000..760ad08d --- /dev/null +++ b/qortal-ui-core/emoji/svg/2b50.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/2b55.svg b/qortal-ui-core/emoji/svg/2b55.svg new file mode 100644 index 00000000..deb4cf11 --- /dev/null +++ b/qortal-ui-core/emoji/svg/2b55.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/30-20e3.svg b/qortal-ui-core/emoji/svg/30-20e3.svg new file mode 100644 index 00000000..8794b3a9 --- /dev/null +++ b/qortal-ui-core/emoji/svg/30-20e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/3030.svg b/qortal-ui-core/emoji/svg/3030.svg new file mode 100644 index 00000000..8ea11410 --- /dev/null +++ b/qortal-ui-core/emoji/svg/3030.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/303d.svg b/qortal-ui-core/emoji/svg/303d.svg new file mode 100644 index 00000000..e2c5c495 --- /dev/null +++ b/qortal-ui-core/emoji/svg/303d.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/31-20e3.svg b/qortal-ui-core/emoji/svg/31-20e3.svg new file mode 100644 index 00000000..38197ad6 --- /dev/null +++ b/qortal-ui-core/emoji/svg/31-20e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/32-20e3.svg b/qortal-ui-core/emoji/svg/32-20e3.svg new file mode 100644 index 00000000..8d81b8cd --- /dev/null +++ b/qortal-ui-core/emoji/svg/32-20e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/3297.svg b/qortal-ui-core/emoji/svg/3297.svg new file mode 100644 index 00000000..7adbcf19 --- /dev/null +++ b/qortal-ui-core/emoji/svg/3297.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/3299.svg b/qortal-ui-core/emoji/svg/3299.svg new file mode 100644 index 00000000..d1a79337 --- /dev/null +++ b/qortal-ui-core/emoji/svg/3299.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/33-20e3.svg b/qortal-ui-core/emoji/svg/33-20e3.svg new file mode 100644 index 00000000..95db6d28 --- /dev/null +++ b/qortal-ui-core/emoji/svg/33-20e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/34-20e3.svg b/qortal-ui-core/emoji/svg/34-20e3.svg new file mode 100644 index 00000000..b1004f31 --- /dev/null +++ b/qortal-ui-core/emoji/svg/34-20e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/35-20e3.svg b/qortal-ui-core/emoji/svg/35-20e3.svg new file mode 100644 index 00000000..be3b0627 --- /dev/null +++ b/qortal-ui-core/emoji/svg/35-20e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/36-20e3.svg b/qortal-ui-core/emoji/svg/36-20e3.svg new file mode 100644 index 00000000..c28896e4 --- /dev/null +++ b/qortal-ui-core/emoji/svg/36-20e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/37-20e3.svg b/qortal-ui-core/emoji/svg/37-20e3.svg new file mode 100644 index 00000000..2da4206e --- /dev/null +++ b/qortal-ui-core/emoji/svg/37-20e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/38-20e3.svg b/qortal-ui-core/emoji/svg/38-20e3.svg new file mode 100644 index 00000000..b9122653 --- /dev/null +++ b/qortal-ui-core/emoji/svg/38-20e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/39-20e3.svg b/qortal-ui-core/emoji/svg/39-20e3.svg new file mode 100644 index 00000000..6936cfb7 --- /dev/null +++ b/qortal-ui-core/emoji/svg/39-20e3.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/a9.svg b/qortal-ui-core/emoji/svg/a9.svg new file mode 100644 index 00000000..afe4fedd --- /dev/null +++ b/qortal-ui-core/emoji/svg/a9.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/ae.svg b/qortal-ui-core/emoji/svg/ae.svg new file mode 100644 index 00000000..bd51781e --- /dev/null +++ b/qortal-ui-core/emoji/svg/ae.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/emoji/svg/e50a.svg b/qortal-ui-core/emoji/svg/e50a.svg new file mode 100644 index 00000000..4fb53894 --- /dev/null +++ b/qortal-ui-core/emoji/svg/e50a.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/qortal-ui-core/exports/element-components.js b/qortal-ui-core/exports/element-components.js new file mode 100644 index 00000000..c6e47b8e --- /dev/null +++ b/qortal-ui-core/exports/element-components.js @@ -0,0 +1,11 @@ +export * from '../components/main-app.js' +export * from '../styles/app-styles.js' +export * from '../styles/app-theme.js' +export * from '../components/app-view.js' +export * from '../components/show-plugin.js' +export * from '../components/sidenav-menu.js' +export * from '../components/wallet-profile.js' +export * from '../components/app-info.js' +export * from '../components/login-view/login-view.js' +export * from '../components/login-view/create-account-section.js' +export * from '../components/login-view/login-section.js' diff --git a/qortal-ui-core/exports/functional-components.js b/qortal-ui-core/exports/functional-components.js new file mode 100644 index 00000000..0501f0d7 --- /dev/null +++ b/qortal-ui-core/exports/functional-components.js @@ -0,0 +1,3 @@ +export * from '../components' +export * from '../components' +export * from '../components' diff --git a/qortal-ui-core/font/MaterialIcons-Regular.ttf b/qortal-ui-core/font/MaterialIcons-Regular.ttf new file mode 100644 index 00000000..7015564a Binary files /dev/null and b/qortal-ui-core/font/MaterialIcons-Regular.ttf differ diff --git a/qortal-ui-core/font/MaterialIcons-Regular.woff b/qortal-ui-core/font/MaterialIcons-Regular.woff new file mode 100644 index 00000000..b648a3ee Binary files /dev/null and b/qortal-ui-core/font/MaterialIcons-Regular.woff differ diff --git a/qortal-ui-core/font/MaterialIcons-Regular.woff2 b/qortal-ui-core/font/MaterialIcons-Regular.woff2 new file mode 100644 index 00000000..9fa21125 Binary files /dev/null and b/qortal-ui-core/font/MaterialIcons-Regular.woff2 differ diff --git a/qortal-ui-core/font/material-icons.css b/qortal-ui-core/font/material-icons.css new file mode 100644 index 00000000..2270c09d --- /dev/null +++ b/qortal-ui-core/font/material-icons.css @@ -0,0 +1,36 @@ +@font-face { + font-family: 'Material Icons'; + font-style: normal; + font-weight: 400; + src: url(MaterialIcons-Regular.eot); /* For IE6-8 */ + src: local('Material Icons'), + local('MaterialIcons-Regular'), + url(MaterialIcons-Regular.woff2) format('woff2'), + url(MaterialIcons-Regular.woff) format('woff'), + url(MaterialIcons-Regular.ttf) format('truetype'); +} + +.material-icons { + font-family: 'Material Icons'; + font-weight: normal; + font-style: normal; + font-size: 24px; /* Preferred icon size */ + display: inline-block; + line-height: 1; + text-transform: none; + letter-spacing: normal; + word-wrap: normal; + white-space: nowrap; + direction: ltr; + + /* Support for all WebKit browsers. */ + -webkit-font-smoothing: antialiased; + /* Support for Safari and Chrome. */ + text-rendering: optimizeLegibility; + + /* Support for Firefox. */ + -moz-osx-font-smoothing: grayscale; + + /* Support for IE. */ + font-feature-settings: 'liga'; +} diff --git a/qortal-ui-core/lang/english.json b/qortal-ui-core/lang/english.json new file mode 100644 index 00000000..2038d832 --- /dev/null +++ b/qortal-ui-core/lang/english.json @@ -0,0 +1,3 @@ +{ + "welcome": "Welcome" +} \ No newline at end of file diff --git a/qortal-ui-core/memory-pow/memory-pow.wasm b/qortal-ui-core/memory-pow/memory-pow.wasm new file mode 100644 index 00000000..01ef4d95 Binary files /dev/null and b/qortal-ui-core/memory-pow/memory-pow.wasm differ diff --git a/qortal-ui-core/memory-pow/memory-pow.wasm.full b/qortal-ui-core/memory-pow/memory-pow.wasm.full new file mode 100644 index 00000000..073b179c Binary files /dev/null and b/qortal-ui-core/memory-pow/memory-pow.wasm.full differ diff --git a/qortal-ui-core/memory-pow/memory-pow.wasm.map b/qortal-ui-core/memory-pow/memory-pow.wasm.map new file mode 100644 index 00000000..70848672 --- /dev/null +++ b/qortal-ui-core/memory-pow/memory-pow.wasm.map @@ -0,0 +1 @@ +{"version":3,"names":[],"sources":[],"sourcesContent":[],"mappings":""} \ No newline at end of file diff --git a/qortal-ui-core/package.json b/qortal-ui-core/package.json new file mode 100644 index 00000000..30637ec9 --- /dev/null +++ b/qortal-ui-core/package.json @@ -0,0 +1,80 @@ +{ + "name": "qortal-ui-core", + "version": "2.1.1", + "description": "QORTAL-UI Core", + "keywords": [ + "QORT", + "QORTAL", + "DECENTRALIZED" + ], + "homepage": "https://qortal.org", + "main": "ui-core.js", + "repository": { + "type": "git", + "url": "https://github.com/Qortal/UI.git", + "directory": "qortal-ui-core" + }, + "author": "QORTAL ", + "license": "GPL-3.0", + "dependencies": { + "@hapi/hapi": "^20.2.1", + "@hapi/inert": "^6.0.4", + "sass": "^1.44.0" + }, + "devDependencies": { + "@babel/core": "^7.16.0", + "@material/mwc-button": "^0.18.0", + "@material/mwc-checkbox": "^0.18.0", + "@material/mwc-dialog": "^0.18.0", + "@material/mwc-drawer": "^0.18.0", + "@material/mwc-fab": "^0.18.0", + "@material/mwc-formfield": "^0.18.0", + "@material/mwc-icon": "^0.18.0", + "@material/mwc-icon-button": "^0.18.0", + "@material/mwc-list": "^0.18.0", + "@material/mwc-select": "^0.18.0", + "@material/mwc-snackbar": "^0.18.0", + "@material/mwc-textfield": "^0.18.0", + "@polymer/app-layout": "^3.1.0", + "@polymer/iron-collapse": "^3.0.1", + "@polymer/iron-flex-layout": "^3.0.1", + "@polymer/iron-icons": "^3.0.1", + "@polymer/iron-pages": "^3.0.1", + "@polymer/paper-checkbox": "^3.1.0", + "@polymer/paper-dialog": "^3.0.1", + "@polymer/paper-dropdown-menu": "^3.1.0", + "@polymer/paper-icon-button": "^3.0.2", + "@polymer/paper-input": "^3.2.0", + "@polymer/paper-item": "^3.0.1", + "@polymer/paper-listbox": "^3.0.1", + "@polymer/paper-progress": "^3.0.1", + "@polymer/paper-ripple": "^3.0.2", + "@polymer/paper-spinner": "^3.0.2", + "@polymer/paper-toast": "^3.0.1", + "@rollup/plugin-alias": "^3.1.8", + "@rollup/plugin-babel": "^5.3.0", + "@rollup/plugin-commonjs": "^21.0.1", + "@rollup/plugin-node-resolve": "^13.0.6", + "@rollup/plugin-replace": "^3.0.0", + "@vaadin/vaadin-app-layout": "^2.2.0", + "asmcrypto.js": "^2.3.2", + "bcryptjs": "^2.4.3", + "epml": "^0.3.3", + "file-saver": "^2.0.5", + "lit-element": "^2.4.0", + "postcss": "^8.4.4", + "pwa-helpers": "^0.9.1", + "random-sentence-generator": "^0.0.8", + "redux": "^4.1.2", + "redux-thunk": "^2.4.1", + "rollup": "^2.60.2", + "rollup-plugin-node-globals": "^1.4.0", + "rollup-plugin-postcss": "^4.0.2", + "rollup-plugin-progress": "^1.1.2", + "rollup-plugin-scss": "^3.0.0", + "rollup-plugin-terser": "^7.0.2" + }, + "engines": { + "node": ">=14.17.0" + } +} diff --git a/qortal-ui-core/public/index.html b/qortal-ui-core/public/index.html new file mode 100644 index 00000000..e304314a --- /dev/null +++ b/qortal-ui-core/public/index.html @@ -0,0 +1,133 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Qortal + + + + + + + +
+ + + + + +
+ + + + + + diff --git a/qortal-ui-core/server/ServerFactory.js b/qortal-ui-core/server/ServerFactory.js new file mode 100644 index 00000000..e4d2c5be --- /dev/null +++ b/qortal-ui-core/server/ServerFactory.js @@ -0,0 +1,34 @@ +const Path = require('path') +const Hapi = require('@hapi/hapi') +const Inert = require('@hapi/inert') + +function serverFactory(routes, address, port, tls) { + this.server = new Hapi.Server({ + routes: { + files: { + relativeTo: Path.join(__dirname, '../') + } + }, + address: address, + port: port, + tls: tls + }) + + this.startServer = async () => { + try { + await this.server.register([Inert]) + + this.server.route(routes) + + await this.server.start() + + delete this.startServer + return this.server + } catch (e) { + console.error(e) + throw e + } + } +} + +module.exports = serverFactory diff --git a/qortal-ui-core/server/routes/createCommonRoutes.js b/qortal-ui-core/server/routes/createCommonRoutes.js new file mode 100644 index 00000000..cb459551 --- /dev/null +++ b/qortal-ui-core/server/routes/createCommonRoutes.js @@ -0,0 +1,94 @@ +const path = require('path') + +const routesOptions = { + security: { + hsts: { + maxAge: 15768000, + includeSubDomains: true, + preload: true + }, + xframe: 'sameorigin' + } +} + +const createRoutes = config => [ + + { + method: 'GET', + path: '/img/{param*}', + handler: { + directory: { + path: config.build.options.imgDir, + redirectToSlash: true, + index: true + } + }, + options: routesOptions + }, + { + method: 'GET', + path: '/font/{param*}', + handler: { + directory: { + path: path.join(__dirname, '../../font'), + redirectToSlash: true, + index: true + } + }, + options: routesOptions + }, + { + method: 'GET', + path: '/sound/{param*}', + handler: { + directory: { + path: path.join(__dirname, '../../sound/'), + redirectToSlash: true, + index: true + } + }, + options: routesOptions + }, + { + method: 'GET', + path: '/emoji/{param*}', + handler: { + directory: { + path: path.join(__dirname, '../../emoji/'), + redirectToSlash: true, + index: true + } + }, + options: routesOptions + }, + { + method: 'GET', + path: '/memory-pow/{param*}', + handler: { + directory: { + path: path.join(__dirname, '../../memory-pow/'), + redirectToSlash: true, + index: true + } + }, + options: routesOptions + }, + { + method: 'GET', + path: '/getConfig', + handler: (request, h) => { + const response = { + config: { + ...config + } + } + + delete response.config.user.tls + delete response.config.build + return JSON.stringify(response) + }, + options: routesOptions + } +] + +module.exports = createRoutes diff --git a/qortal-ui-core/server/routes/createPrimaryRoutes.js b/qortal-ui-core/server/routes/createPrimaryRoutes.js new file mode 100644 index 00000000..ef398aae --- /dev/null +++ b/qortal-ui-core/server/routes/createPrimaryRoutes.js @@ -0,0 +1,141 @@ +const path = require('path') + +const createCommonRoutes = require('./createCommonRoutes.js') + +const createPrimaryRoutes = (config, plugins) => { + const routes = createCommonRoutes(config) + + let myPlugins = plugins + + const pluginFolders = {} + + const routesOptions = { + security: { + hsts: { + maxAge: 15768000, + includeSubDomains: true, + preload: true + }, + xframe: 'sameorigin' + } + } + + plugins.reduce((obj, plugin) => { + obj[plugin.name] = plugin.folder + return obj + }, pluginFolders) + + + routes.push( + { + method: 'GET', + path: '/', + handler: (request, reply) => { + return reply.redirect('/app') + }, + options: routesOptions + }, + { + method: 'GET', + path: '/{path*}', + handler: (request, h) => { + const filePath = path.join(__dirname, '../../public/index.html') + const response = h.file(filePath, { + confine: true + }) + response.header('Access-Control-Allow-Origin', request.info.host) + return response + }, + options: routesOptions + }, + { + method: 'GET', + path: '/getPlugins', + handler: (request, h) => { + return { plugins: myPlugins.map(p => p.name) } + }, + options: routesOptions + }, + { + method: 'GET', + path: '/build/{param*}', + handler: { + directory: { + path: config.build.options.outputDir, + redirectToSlash: true, + index: true + } + }, + options: routesOptions + }, + { + method: 'GET', + path: '/src/{param*}', + handler: { + directory: { + path: path.join(__dirname, '../../src'), + redirectToSlash: true, + index: true + } + }, + options: routesOptions + }, + { + method: 'GET', + path: '/plugin/{path*}', + handler: (request, h) => { + + const plugin = request.params.path.split('/')[0] + const filePath = path.join(pluginFolders[plugin], '../', request.params.path) + + const response = h.file(filePath, { + confine: false + }) + response.header('Access-Control-Allow-Origin', request.info.host) + return response + }, + options: routesOptions + }, + { + method: 'GET', + path: '/plugin/404', + handler: (request, h) => { + const response = h.file(path.join(config.server.primary.page404)) + response.header('Access-Control-Allow-Origin', request.info.host) + return response + }, + options: routesOptions + }, + { + method: 'GET', + path: '/qortal-components/plugin-mainjs-loader.html', + handler: (request, h) => { + const response = h.file(path.join(__dirname, '../../src/plugins/plugin-mainjs-loader.html'), { + confine: false + }) + response.header('Access-Control-Allow-Origin', request.info.host) + return response + }, + options: routesOptions + }, + { + method: 'GET', + path: '/qortal-components/plugin-mainjs-loader.js', + handler: (request, h) => { + const file = path.join(config.build.options.outputDir, '/plugins/plugin-mainjs-loader.js') + + const response = h.file(file, { + confine: false + }) + response.header('Access-Control-Allow-Origin', request.info.host) + return response + }, + options: routesOptions + }, + + ) + + return routes +} + +module.exports = createPrimaryRoutes diff --git a/qortal-ui-core/server/server.js b/qortal-ui-core/server/server.js new file mode 100644 index 00000000..5ccf2618 --- /dev/null +++ b/qortal-ui-core/server/server.js @@ -0,0 +1,24 @@ +const ServerFactory = require('./ServerFactory.js') + +const createPrimaryRoutes = require('./routes/createPrimaryRoutes.js') + +const createServer = (config, plugins) => { + this.start = async function () { + const primaryServer = new ServerFactory(createPrimaryRoutes(config, plugins), config.user.server.primary.host, config.user.server.primary.port, config.user.tls.enabled ? config.user.tls.options : void 0) + primaryServer.startServer() + .then(server => { + console.log(`Qortal UI Server started at ${server.info.uri} and listening on ${server.info.address}`) + }) + .catch(e => { + console.error(e) + }) + } + return this +} + + +const serverExports = { + createServer +} + +module.exports = serverExports diff --git a/qortal-ui-core/sound/blockAlert.ogg b/qortal-ui-core/sound/blockAlert.ogg new file mode 100644 index 00000000..8e056f23 Binary files /dev/null and b/qortal-ui-core/sound/blockAlert.ogg differ diff --git a/qortal-ui-core/sound/messageAlert.ogg b/qortal-ui-core/sound/messageAlert.ogg new file mode 100644 index 00000000..1fb421df Binary files /dev/null and b/qortal-ui-core/sound/messageAlert.ogg differ diff --git a/qortal-ui-core/sound/newmessage.ogg b/qortal-ui-core/sound/newmessage.ogg new file mode 100644 index 00000000..5f42dcc8 Binary files /dev/null and b/qortal-ui-core/sound/newmessage.ogg differ diff --git a/qortal-ui-core/src/__src.js b/qortal-ui-core/src/__src.js new file mode 100644 index 00000000..90bf7ad2 --- /dev/null +++ b/qortal-ui-core/src/__src.js @@ -0,0 +1,57 @@ +// import { store } from './store' +// import * as api from 'qortal-ui-crypto' + +// const createTransaction = api.createTransaction +// const processTransaction = api.processTransaction +// const signChatTransaction = api.signChatTransaction + +// let _reference = new Uint8Array(64); +// window.crypto.getRandomValues(_reference); +// let reference = window.parent.Base58.encode(_reference) + +// let tmstp = Date.now() + +// const params = { +// timestamp: tmstp, +// groupID: 0, +// lastReference: reference, +// proofOfWorkNonce: 0 +// } + +// const _computePow = async (chatBytes) => { + +// const chatBytesHash = new window.parent.Sha256().process(chatBytes).finish().result + +// const hashPtr = window.parent.sbrk(32, window.parent.heap); +// const hashAry = new Uint8Array(window.parent.memory.buffer, hashPtr, 32); +// hashAry.set(chatBytesHash); + +// const difficulty = 15 + +// const workBufferLength = 8 * 1024 * 1024; +// const workBufferPtr = window.parent.sbrk(workBufferLength, window.parent.heap); + +// let nonce = window.parent.computePow(hashPtr, workBufferPtr, workBufferLength, difficulty) + +// return nonce; +// } + +// export const send = async () => { +// let response +// try { +// const tx = createTransaction(19, store.getState().app.wallet._addresses[0].keyPair, params) + +// const computedNonce = await _computePow(tx.chatBytes) + +// const signedChatBytes = signChatTransaction(tx.chatBytes, computedNonce, store.getState().app.wallet._addresses[store.getState().app.selectedAddress.nonce].keyPair) + +// const res = await processTransaction(signedChatBytes) + +// response = res +// } catch (e) { +// console.error(e) +// console.error(e.message) +// response = false +// } +// return response +// }; diff --git a/qortal-ui-core/src/components/app-info.js b/qortal-ui-core/src/components/app-info.js new file mode 100644 index 00000000..83981f94 --- /dev/null +++ b/qortal-ui-core/src/components/app-info.js @@ -0,0 +1,149 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../store.js' +import { doPageUrl } from '../redux/app/app-actions.js' + +import '@material/mwc-icon' +import '@material/mwc-button' + +class AppInfo extends connect(store)(LitElement) { + static get properties() { + return { + blockInfo: { type: Object }, + nodeStatus: { type: Object }, + nodeInfo: { type: Object }, + nodeConfig: { type: Object }, + pageUrl: { type: String } + } + } + + static get styles() { + return [ + css` + * { + --mdc-theme-primary: rgb(3, 169, 244); + --paper-input-container-focus-color: var(--mdc-theme-primary); + } + .normal { + --mdc-theme-primary: rgb(3, 169, 244); + } + + .normal-button { + --mdc-theme-primary: rgb(3, 169, 244); + --mdc-theme-on-primary: white; + } + + mwc-button.normal-button { + --mdc-theme-primary: rgb(3, 169, 244); + --mdc-theme-on-primary: white; + } + .test-net { + --mdc-theme-primary: black; + } + + .test-net-button { + --mdc-theme-primary: black; + --mdc-theme-on-primary: white; + } + + mwc-button.test-net-button { + --mdc-theme-primary: black; + --mdc-theme-on-primary: white; + } + #profileInMenu { + flex: 0 0 100px; + padding:12px; + border-top: 1px solid #eee; + /* position: fixed; + top: 102vh; + left: 0; */ + /* margin-top: 2.5rem; */ + } + .info { + margin: 0; + font-size: 14px; + font-weight:100; + display: inline-block; + width:100%; + padding-bottom:8px; + } + .blue { + color: #03a9f4; + margin: 0; + font-size: 14px; + font-weight:200; + display: inline; + } + .black { + color: black; + margin: 0; + font-size: 14px; + font-weight:200; + display: inline; + } + ` + ] + } + + constructor() { + super() + this.blockInfo = {} + this.nodeInfo = {} + this.nodeStatus = {} + this.pageUrl = '' + } + + render() { + return html` +
+ Block Height: ${this.blockInfo.height ? this.blockInfo.height : ''} ${this._renderStatus()} + UI Version: v${this.nodeConfig.version ? this.nodeConfig.version : ''} + Core Version: ${this.nodeInfo.buildVersion ? this.nodeInfo.buildVersion : ''} + +
+ ` + } + + firstUpdated() { + // ... + } + + _renderStatus() { + if (this.nodeStatus.isMintingPossible === true && this.nodeStatus.isSynchronizing === true) { + this.cssStatus = 'blue' + return '(Minting)' + } else if (this.nodeStatus.isMintingPossible === true && this.nodeStatus.isSynchronizing === false) { + this.cssStatus = 'blue' + return '(Minting)' + } else if (this.nodeStatus.isMintingPossible === false && this.nodeStatus.isSynchronizing === true) { + this.cssStatus = 'black' + return `(Synchronizing... ${this.nodeStatus.syncPercent !== undefined ? this.nodeStatus.syncPercent + '%' : ''})` + } else if (this.nodeStatus.isMintingPossible === false && this.nodeStatus.isSynchronizing === false) { + this.cssStatus = 'black' + return '' + } else { + return '' + } + } + + gotoPage(url) { + const myLink = this.shadowRoot.querySelector('#pageLink') + myLink.href = url + myLink.click() + store.dispatch(doPageUrl('')) + } + + stateChanged(state) { + this.blockInfo = state.app.blockInfo + this.nodeStatus = state.app.nodeStatus + this.nodeInfo = state.app.nodeInfo + this.nodeConfig = state.app.nodeConfig + + this.pageUrl = state.app.pageUrl + if (this.pageUrl.length > 5) { + this.gotoPage(this.pageUrl) + } + } +} + +window.customElements.define('app-info', AppInfo) diff --git a/qortal-ui-core/src/components/app-view.js b/qortal-ui-core/src/components/app-view.js new file mode 100644 index 00000000..169fa9dc --- /dev/null +++ b/qortal-ui-core/src/components/app-view.js @@ -0,0 +1,142 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../store.js' + +import '@polymer/paper-icon-button/paper-icon-button.js' +import '@polymer/iron-icons/iron-icons.js' + +import './wallet-profile.js' +import './app-info.js' +import './sidenav-menu.js' +import './show-plugin.js' + +import '@material/mwc-drawer' + +import '@polymer/app-layout/app-layout.js' +import '@polymer/paper-ripple' + +import './settings-view/user-settings.js' + +class AppView extends connect(store)(LitElement) { + static get properties() { + return { + config: { type: Object } + } + } + + static get styles() { + return [ + css` + :host { + --app-drawer-width: 260px; + } + + app-drawer-layout:not([narrow]) [drawer-toggle]:not(sidenav-menu) { + display: none; + } + + app-drawer { + box-shadow: var(--shadow-2); + background: var(--mdc-theme-surface); + } + app-header { + box-shadow: var(--shadow-2); + } + app-toolbar { + background: var(--mdc-theme-surface); + color: var(--mdc-theme-on-surface); + } + + #sideBar { + height: 100vh; + display: flex; + flex-direction: column; + } + .sideBarMenu{ + overflow-y: auto; + flex: 1 1; + } + #sideBar::-webkit-scrollbar { + width: 7px; + background-color: transparent; + } + + #sideBar::-webkit-scrollbar-track { + background-color: transparent; + } + + #sideBar::-webkit-scrollbar-thumb { + background-color: #333; + border-radius: 6px; + border: 3px solid #333; + } + ` + ] + } + + render() { + return html` + + + + + + + + + + + + + + + +
+ + + +
+ +
+ this.openSettings()} title="Settings" > +
+
+
+ + + +
+
+ + ` + } + + constructor() { + super() + + } + + firstUpdated() { + // + } + + stateChanged(state) { + this.config = state.config + } + + openSettings() { + + const settingsDialog = document.getElementById('main-app').shadowRoot.querySelector('app-view').shadowRoot.querySelector('user-settings') + settingsDialog.openSettings() + } +} + +window.customElements.define('app-view', AppView) diff --git a/qortal-ui-core/src/components/base.js b/qortal-ui-core/src/components/base.js new file mode 100644 index 00000000..4f3a5528 --- /dev/null +++ b/qortal-ui-core/src/components/base.js @@ -0,0 +1,32 @@ +/* Just a copy paste for setting up elements :) */ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../store.js' + +class MyElement extends connect(store)(LitElement) { + static get properties () { + return { + + } + } + + static get styles () { + return css` + + ` + } + + render () { + return html` + + ` + } + + stateChanged (state) { + // this.loggedIn = state.app.loggedIn + } +} + +window.customElements.define('my-element', MyElement) diff --git a/qortal-ui-core/src/components/login-view/create-account-section.js b/qortal-ui-core/src/components/login-view/create-account-section.js new file mode 100644 index 00000000..546162c7 --- /dev/null +++ b/qortal-ui-core/src/components/login-view/create-account-section.js @@ -0,0 +1,510 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../../store.js' + +// import { send } from '../../__src.js' + +import { createWallet } from '../../../../qortal-ui-crypto/api/createWallet.js' + +import FileSaver from 'file-saver' + +import { doLogin, doLogout, doSelectAddress } from '../../redux/app/app-actions.js' +import { doStoreWallet } from '../../redux/user/user-actions.js' + +import snackbar from '../../functional-components/snackbar.js' + +import '@material/mwc-button' +import '@material/mwc-checkbox' +import '@material/mwc-icon' + +import '@polymer/iron-pages' +import '@polymer/paper-input/paper-input-container.js' +import '@polymer/paper-input/paper-input.js' + +import 'random-sentence-generator' + +import ripple from '../../functional-components/loading-ripple.js' + +let lastPassword = '' + +class CreateAccountSection extends connect(store)(LitElement) { + static get properties() { + return { + nextHidden: { type: Boolean, notify: true }, + nextDisabled: { type: Boolean, notify: true }, + nextText: { type: String, notify: true }, + backHidden: { type: Boolean, notify: true }, + backDisabled: { type: Boolean, notify: true }, + backText: { type: String, notify: true }, + hideNav: { type: Boolean, notify: true }, + + selectedPage: { type: String }, + error: { type: Boolean }, + errorMessage: { type: String }, + nextButtonText: { type: String }, + saveAccount: { type: Boolean }, + createAccountLoading: { type: Boolean }, + showSeedphrase: { type: Boolean }, + _wallet: { type: Object }, + _pass: { type: String }, + _name: { type: String }, + isDownloadedBackup: { type: Boolean } + } + } + + static get styles() { + return [ + css` + + ` + ] + } + + constructor() { + super() + this.nextText = 'Next' + this.backText = 'Back' + this.nextDisabled = false + this._pass = '' + this._name = '' + this.selectedPage = 'info' + this.nextButtonText = 'Next' + this.saveAccount = true + this.showSeedphrase = false + this.isDownloadedBackup = false + this.createAccountLoading = false + const welcomeMessage = 'Welcome to Qortal' + this.welcomeMessage = welcomeMessage + + this.pages = { + info: { + next: e => { + this.error = false + this.errorMessage = '' + this.nextButtonText = 'Create' + this.selectPage('password') + this.updateNext() + }, + back: () => { + this.navigate('welcome') + } + }, + password: { + next: e => { + // Create account and login :) + this.createAccountLoading = true + const nameInput = this.shadowRoot.getElementById('nameInput').value + const password = this.shadowRoot.getElementById('password').value + + if (password === '') { + snackbar.add({ + labelText: 'Please enter a Password!', + dismiss: true + }) + return + } + + if (password.length < 8 && lastPassword !== password) { + snackbar.add({ + labelText: 'Your password is less than 8 characters! This is not recommended. You can continue to ignore this warning.', + dismiss: true + }) + lastPassword = password + return + } + + if (this.saveAccount === true && nameInput === '') { + snackbar.add({ + labelText: 'Please enter a Name!', + dismiss: true + }) + return + } + + this._name = nameInput + this._pass = password + + let seedObj = {} + const seedPhrase = this.shadowRoot.getElementById('randSentence').parsedString + seedObj = { seedPhrase: seedPhrase } + + ripple.welcomeMessage = welcomeMessage + ripple.open({ + x: e.clientX, + y: e.clientY + }) + .then(() => createWallet('phrase', seedObj, status => { + ripple.loadingMessage = status + })) + .then(wallet => { + this._wallet = wallet + + return ripple.fade() + }) + .then(() => { + this.selectPage('backup') + this.updateNext() + }) + .catch(e => { + snackbar.add({ + labelText: e, + dismiss: true + }) + console.error('== Error == \n', e) + store.dispatch(doLogout()) + ripple.close() + }) + }, + back: () => { + this.selectPage('info') + this.updateNext() + } + }, + backup: { + next: e => { + if (!this.isDownloadedBackup) { + snackbar.add({ + labelText: 'Please Download Your Wallet BackUp file!', + dismiss: true + }) + } else { + if (this.saveAccount) { + ripple.welcomeMessage = 'Preparing Your Account' + ripple.open({ + x: e.clientX, + y: e.clientY + }) + .then(() => { + store.dispatch(doStoreWallet(this._wallet, this._pass, this._name, () => { + ripple.loadingMessage = 'Loading, Please wait...' + })) + .then(() => { + store.dispatch(doLogin(this._wallet)) + store.dispatch(doSelectAddress(this._wallet.addresses[0])) + this.cleanup() + return ripple.fade() + }) + .catch(err => console.error(err)) + }).catch(err => { + console.error(err) + }) + } else { + store.dispatch(doLogin(this._wallet)) + store.dispatch(doSelectAddress(this._wallet.addresses[0])) + this.cleanup() + } + } + }, + back: () => { + this.navigate('welcome') + } + } + } + this.pageIndexes = { + info: 0, + password: 1, + backup: 2 + } + + this.nextEnabled = false + this.prevEnabled = false + } + + cleanup() { + this.shadowRoot.getElementById('randSentence').generate() + this.shadowRoot.getElementById('nameInput').value = '' + this.shadowRoot.getElementById('password').value = '' + this.showSeedphrase = false + this.selectPage('info') + this.error = false + this.errorMessage = '' + this.nextButtonText = 'Next' + this.createAccountLoading = false + this.saveAccount = true + this.isDownloadedBackup = false + this._wallet = '' + this._pass = '' + this._name = '' + } + + render() { + return html` + + +
+ +
+
+
+

Create account

+

+ Welcome to QORT, you will find it to be similar to that of an RPG game, + you, as a minter on the QORT network (if you choose to become one) will have the chance to level your account up, + giving you both more of the QORT block reward and also larger influence over the network in terms of voting on decisions for the platform. +

+

+ Create your QORT account by clicking Next below. + A ‘seedphrase’ will be randomly generated and this is used as your private key generator for your blockchain account in QORT. + ONLY show your seedphrase if you are an ADVANCED USER. And when you do, Please be careful and make sure it is safely and securely stored. + This is extremely important information for your QORT account. +

+ +
+
+ +
+ + this.shadowRoot.getElementById('randSentence').generate()} + > +
+
+
+ + { this.showSeedphrase = !e.target.checked; this.updateNext() }} ?checked=${this.showSeedphrase}> +
+
+ +
+
+

Save in browser

+

Your account is now ready to be created. It will be saved in this browser. If you do not want your new account to be saved in your browser, you can uncheck the box below. + You will still be able to login with your new account(after logging out), using your wallet backup file that you MUST download once you create your account.

+
+ perm_identity + +
+
+ vpn_key + +
+
+ + { this.saveAccount = !e.target.checked }} ?checked=${this.saveAccount}> +
+
+
+ +
+
+

Download Wallet BackUp File

+

Your account is now created${this.saveAccount ? ' and will be saved in this browser.' : '.'}

+

+ This file is the ONLY way to access your account on a system that doesn't have it saved to the app/browser. BE SURE TO BACKUP THIS FILE IN MULTIPLE PLACES. The file is encrypted very securely and decrypted with your local password you created in the previous step. You can save it anywhere securely, but be sure to do that in multiple locations. +

+
+
+ Download Wallet BackUp File + this.downloadBackup(this._wallet)} style="dispay:inline;"> + cloud_download  Save + +
+
+
+ + { this.isDownloadedBackup = !e.target.checked; this.updateNext() }} ?checked=${this.isDownloadedBackup}> +
+
+
+
+
+ ` + } + + _pageChange(newPage, oldPage) { + if (!this.shadowRoot.querySelector('#createAccountPages') || !newPage) { + return + } + const pages = this.shadowRoot.querySelector('#createAccountPages').children + // Run the animation on the newly selected page + const newIndex = this.pageIndexes[newPage] + if (!pages[newIndex].className.includes('animated')) { + pages[newIndex].className += ' animated' + } + + if (typeof oldPage !== 'undefined') { + const oldIndex = this.pageIndexes[oldPage] + // Stop the animation of hidden pages + pages[oldIndex].classList.remove('animated') + } + } + + selectPage(newPage) { + const oldPage = this.selectedPage + this.selectedPage = newPage + this._pageChange(newPage, oldPage) + } + + updateNext() { + if (this.selectedPage === 'info') { + this.nextText = 'Next' + this.nextDisabled = false + } else if (this.selectedPage === 'password') { + this.nextDisabled = false + this.nextText = 'Create Account' + } else if (this.selectedPage === 'backup') { + this.nextDisabled = !this.isDownloadedBackup + this.backHidden = true + this.nextText = 'Continue' + } + + this.updatedProperty() + } + + back(e) { + this.pages[this.selectedPage].back(e) + } + + next(e) { + this.pages[this.selectedPage].next(e) + } + + updatedProperty() { + this.dispatchEvent(new CustomEvent('updatedProperty', { + detail: {}, + bubbles: true, + composed: true + })) + } + + navigate(page) { + this.dispatchEvent(new CustomEvent('navigate', { + detail: { page }, + bubbles: true, + composed: true + })) + } + + stateChanged(state) { + // this.loggedIn = state.app.loggedIn + } + + createAccount() { + + } + + async downloadBackup(wallet) { + const state = store.getState() + const data = await wallet.generateSaveWalletData(this._pass, state.config.crypto.kdfThreads, () => { }) + const dataString = JSON.stringify(data) + + const blob = new Blob([dataString], { type: 'text/plain;charset=utf-8' }) + FileSaver.saveAs(blob, `qortal_backup_${wallet.addresses[0].address}.json`) + } +} + +window.customElements.define('create-account-section', CreateAccountSection) diff --git a/qortal-ui-core/src/components/login-view/loading-ripple_old.js b/qortal-ui-core/src/components/login-view/loading-ripple_old.js new file mode 100644 index 00000000..91eefc74 --- /dev/null +++ b/qortal-ui-core/src/components/login-view/loading-ripple_old.js @@ -0,0 +1,202 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../../store.js' + +const TRANSITION_EVENT_NAMES = ['transitionend', 'webkitTransitionEnd', 'oTransitionEnd', 'MSTransitionEnd'] + +class LoadingRipple extends connect(store)(LitElement) { + static get properties () { + return { + welcomeMessage: { + type: String, + attribute: 'welcome-message', + reflectToAttribute: true + }, + loadingMessage: { + type: String, + attribute: 'loading-message', + reflectToAttribute: true + } + } + } + + constructor () { + super() + this.welcomeMessage = '' + this.loadingMessage = '' + } + + static get styles () { + return css` + * { + --paper-spinner-color: var(--mdc-theme-secondary); + } + + ` + } + + render () { + return html` + +
+
+
+
+
+

${this.welcomeMessage}

+ +

${this.loadingMessage}

+
+
+
+
+ ` + } + + firstUpdated () { + this._rippleWrapper = this.shadowRoot.getElementById('rippleWrapper') + this._ripple = this.shadowRoot.getElementById('ripple') + this._rippleContentWrapper = this.shadowRoot.getElementById('rippleContentWrapper') + } + + // duh + open (origin) { + this._rippleWrapper.style.top = origin.y + 'px' + this._rippleWrapper.style.left = origin.x + 'px' + this._rippleContentWrapper.style.marginTop = -origin.y + 'px' + this._rippleContentWrapper.style.marginLeft = -origin.x + 'px' + + return new Promise((resolve, reject) => { + this._ripple.classList.add('activating') + let isOpened = false + const doneOpeningEvent = () => { + if (isOpened) return + // Clear events + TRANSITION_EVENT_NAMES.forEach(name => this._ripple.removeEventListener(name, doneOpeningEvent)) + this._ripple.classList.add('activating-done') + isOpened = true + resolve() + } + TRANSITION_EVENT_NAMES.forEach(name => this._ripple.addEventListener(name, doneOpeningEvent)) + }) + } + + // Fades out + fade () { + return new Promise((resolve, reject) => { + // CAN'T FADE OUT CAUSE THE STUPID THING GETS KILLED CAUSE OF STATE.APP.LOGGEEDIN + // let rippleClosed = false + this._ripple.classList.remove('activating') + this._ripple.classList.remove('activating-done') + this._ripple.classList.remove('disabling') + resolve() + // this._ripple.classList.add('disabling') + // const rippleFadedEvent = () => { + // console.log('ripple closed event') + // if (rippleClosed) return + // rippleClosed = true + // // Reset the ripple + // TRANSITION_EVENT_NAMES.forEach(name => this._ripple.removeEventListener(name, rippleFadedEvent)) + // this._ripple.classList.remove('activating') + // this._ripple.classList.remove('activating-done') + // this._ripple.classList.remove('disabling') + // this.rippleIsOpen = false + // resolve() + // } + // console.log('==============================================================================================================================================') + // TRANSITION_EVENT_NAMES.forEach(name => this._ripple.addEventListener(name, rippleFadedEvent)) + }) + } + + // un-ripples... + close () { + return new Promise((resolve, reject) => { + let rippleClosed = false + this._ripple.classList.add('error') + this._ripple.classList.remove('activating') + this._ripple.classList.remove('activating-done') + const rippleClosedEvent = () => { + if (rippleClosed) return + rippleClosed = true + TRANSITION_EVENT_NAMES.forEach(name => this._ripple.removeEventListener(name, rippleClosedEvent)) + // Reset the ripple + this._ripple.classList.remove('error') + this.rippleIsOpen = false + resolve() + } + TRANSITION_EVENT_NAMES.forEach(name => this._ripple.addEventListener(name, rippleClosedEvent)) + }) + } + + stateChanged (state) { + // this.loggedIn = state.app.loggedIn + } +} + +window.customElements.define('loading-ripple', LoadingRipple) diff --git a/qortal-ui-core/src/components/login-view/login-section.js b/qortal-ui-core/src/components/login-view/login-section.js new file mode 100644 index 00000000..617b48c1 --- /dev/null +++ b/qortal-ui-core/src/components/login-view/login-section.js @@ -0,0 +1,608 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../../store.js' + +import '@material/mwc-button' +import '@material/mwc-checkbox' +import '@material/mwc-textfield' +import '@material/mwc-icon' +import '@material/mwc-dialog' +import '@material/mwc-formfield' + +import '@polymer/iron-pages' +import '@polymer/paper-input/paper-input-container.js' +import '@polymer/paper-input/paper-input.js' +import '@polymer/paper-ripple' +import '@polymer/iron-collapse' +import '@polymer/paper-spinner/paper-spinner-lite.js' + +import { doLogin, doSelectAddress } from '../../redux/app/app-actions.js' +import { doStoreWallet, doRemoveWallet } from '../../redux/user/user-actions.js' + +import { createWallet } from '../../../../qortal-ui-crypto/api/createWallet.js' + +import snackbar from '../../functional-components/snackbar.js' +import '../../custom-elements/frag-file-input.js' + +import ripple from '../../functional-components/loading-ripple.js' + +class LoginSection extends connect(store)(LitElement) { + static get properties() { + return { + nextHidden: { type: Boolean, notify: true }, + nextDisabled: { type: Boolean, notify: true }, + nextText: { type: String, notify: true }, + backHidden: { type: Boolean, notify: true }, + backDisabled: { type: Boolean, notify: true }, + backText: { type: String, notify: true }, + hideNav: { type: Boolean, notify: true }, + + loginFunction: { type: Object }, + selectedWallet: { type: Object }, + selectedPage: { type: String }, + wallets: { type: Object }, + loginErrorMessage: { type: String }, + hasStoredWallets: { type: Boolean }, + saveInBrowser: { type: Boolean }, + backedUpWalletJSON: { type: Object }, + backedUpSeedLoading: { type: Boolean } + } + } + + static get styles() { + return [ + css` + + ` + ] + } + + constructor() { + super() + this.nextHidden = true + this.backText = 'Back' + + this.backedUpSeedLoading = false + this.hasStoredWallets = Object.keys(store.getState().user.storedWallets).length > 0 + this.selectedPage = this.hasStoredWallets ? 'storedWallet' : 'loginOptions' + this.selectedWallet = {} + this.loginErrorMessage = '' + this.saveInBrowser = false + + this.loginOptions = [ + { + page: 'phrase', + linkText: 'Seedphrase', + icon: 'short_text' + }, + { + page: 'storedWallet', + linkText: 'Saved account', + icon: 'save' + }, + { + page: 'seed', + linkText: 'Qortal address seed', + icon: 'clear_all' + }, + { + page: 'backedUpSeed', + linkText: 'Qortal wallet backup', + icon: 'insert_drive_file' + } + ] + + this.showPasswordCheckboxPages = ['seed', 'phrase', 'V1Seed', 'unlockBackedUpSeed'] + } + + render() { + return html` + + +
+
+ +
+

How would you like to login?

+ ${this.loginOptions.map(({ page, linkText, icon }) => html` + + `)} +
+ +
+
+

Your accounts

+

Click your account to login with it

+
+
+ ${(Object.entries(this.wallets || {}).length < 1) ? html` +

You need to create or save an account before you can log in!

+ ` : ''} + ${Object.entries(this.wallets || {}).map(wallet => html` +
+
this.selectWallet(wallet[1])}> + +
+ +

Name${wallet[1].name || "No saved name"}

+

Address${wallet[1].address0}

+
+
+ this.removeWallet(wallet[1].address0)} icon="clear"> +
+ `)} +
+
+ +
+
+
+ +
+
+
+ +
+
+
+ +
+
+
+ +
+
+ account_circle +
+ ${this.selectedWallet.address0} +
+
+ +
+ ${!this.backedUpSeedLoading ? html` +

Upload your qortal backup

+ + ` : html` + + `} +
+ +
+

Decrypt backup

+
+ +
+ +
+ +
+
+ +
+ this.keyupEnter(e, e => this.emitNext(e))}> +
+
+ +
+ ${this.loginErrorMessage} +
+ ${this.showPasswordCheckboxPages.includes(this.selectedPage) ? html` +
+

+ + { this.saveInBrowser = !e.target.checked }} ?checked="${this.saveInBrowser}"> +

+
+ ` : ''} +
+
+ + ` + } + + firstUpdated() { + this.loadingRipple = ripple + + const pages = this.shadowRoot.querySelector('#loginPages') + pages.addEventListener('selected-item-changed', () => { + if (!pages.selectedItem) { + // ... + } else { + this.updateNext() + this.shadowRoot.querySelector('#nameInput').value = '' + this.shadowRoot.querySelector('#password').value = '' + this.loginErrorMessage = '' + } + }) + } + + selectWallet(wallet) { + this.selectedWallet = wallet + this.selectedPage = 'unlockStored' + } + + removeWallet(walletAddress){ + if(window.confirm('Are you sure you want to remove this wallet from saved wallets?')) { + delete store.getState().user.storedWallets[walletAddress] + this.wallets=store.getState().user.storedWallets + store.dispatch( + doRemoveWallet(walletAddress) + )//.catch(err => console.error(err)) + this.cleanup() + } + } + + stateChanged(state) { + this.loggedIn = state.app.loggedIn + this.wallets = state.user.storedWallets + this.hasStoredWallets = this.wallets.length > 0 + } + + keyupEnter(e, action) { + if (e.keyCode === 13) { + e.preventDefault() + action(e) + } + } + + emitNext(e) { + this.dispatchEvent(new CustomEvent('next', { + detail: {} + })) + } + + loadBackup(file) { + let error = '' + let pf + this.selectedPage = 'unlockBackedUpSeed' + + try { + pf = JSON.parse(file) + } catch (e) { + this.loginErrorMessage = 'Backup must be valid JSON' + } + + try { + const requiredFields = ['address0', 'salt', 'iv', 'version', 'encryptedSeed', 'mac', 'kdfThreads'] + for (const field of requiredFields) { + if (!(field in pf)) throw new Error(field + ' not found in JSON') + } + } catch (e) { + error = e + } + + if (error !== '') { + snackbar.add({ + labelText: error + }) + this.selectedPage = 'backedUpSeed' + return + } + this.backedUpWalletJSON = pf + } + + showName(selectedPage) { + return ( + this.saveInBrowser && [ + 'unlockBackedUpSeed', + 'seed', + 'phrase' + ].includes(selectedPage) + ) || + ( + [ + '' + ].includes(selectedPage) + ) + } + + showPassword(selectedPage) { + let willBeShown= ( + this.saveInBrowser && [ + 'unlockBackedUpSeed', + 'seed', + 'phrase' + ].includes(selectedPage) + ) || (['unlockBackedUpSeed','unlockStored'].includes(selectedPage)) + + if(willBeShown)//if the password will be displayed lt's give it focus + this.shadowRoot.getElementById('password').focus() + + return willBeShown + } + + get walletSources() { + return { + seed: () => { + const seed = this.shadowRoot.querySelector('#v1SeedInput').value + const name = this.shadowRoot.getElementById('nameInput').value + const password = this.shadowRoot.getElementById('password').value + return { + seed, + password, + name + } + }, + storedWallet: () => { + const wallet = this.selectedWallet + const password = this.shadowRoot.getElementById('password').value + return { + wallet, + password + } + }, + phrase: () => { + const seedPhrase = this.shadowRoot.querySelector('#existingSeedPhraseInput').value + if (seedPhrase == "") { + throw new Error('Please enter a seedphrase') + return + } + const name = this.shadowRoot.getElementById('nameInput').value + const password = this.shadowRoot.getElementById('password').value + return { + seedPhrase, + name, + password + } + }, + backedUpSeed: () => { + const wallet = this.backedUpWalletJSON + const name = this.shadowRoot.getElementById('nameInput').value + const password = this.shadowRoot.getElementById('password').value + return { + password, + wallet, + name + } + } + } + } + + loginOptionIsSelected(type) { + return this.loginOptions.map(op => op.page).includes(type) + } + + login(e) { + let type = this.selectedPage === 'unlockStored' ? 'storedWallet' : this.selectedPage + type = type === 'unlockBackedUpSeed' ? 'backedUpSeed' : type + + if (!this.loginOptionIsSelected(type)) { + throw new Error('Login option not selected page') + } + + // First decrypt... + this.loadingRipple.welcomeMessage = 'Preparing Your Account' + this.loadingRipple.open({ + x: e.clientX, + y: e.clientY + }) + .then(() => { + const source = this.walletSources[type]() + return createWallet(type, source, status => { + this.loadingRipple.loadingMessage = status + }) + .then(wallet => { + store.dispatch(doLogin(wallet)) + store.dispatch(doSelectAddress(wallet.addresses[0])) + this.navigate('show-address') + const storedWallets = store.getState().user.storedWallets + const storedWalletAddress = storedWallets[wallet.addresses[0].address] + + if (!storedWalletAddress) { + if (this.saveInBrowser && type !== 'storedWallet') { + store.dispatch(doStoreWallet(wallet, source.password, source.name, () => { + + ripple.loadingMessage = status + })).catch(err => console.error(err)) + } + } + this.cleanup() + return this.loadingRipple.fade() + }) + }) + .catch(e => { + this.loginErrorMessage = e + console.error(e) + return this.loadingRipple.close() + }) + } + + back() { + if (['seed', 'phrase', 'storedWallet', 'backedUpSeed'].includes(this.selectedPage)) { + this.selectedPage = 'loginOptions' + } else if (this.selectedPage === 'loginOptions') { + this.navigate('welcome') + } else if (this.selectedPage === 'unlockStored') { + this.selectedPage = 'storedWallet' + } else if (this.selectedPage === 'unlockBackedUpSeed') { + this.selectedPage = 'backedUpSeed' + } + } + + next(e) { + this.login(e) + } + + // clicks next for parent + clickNext() { + + } + + updateNext() { + if (['phrase', 'seed', 'unlockStored', 'unlockBackedUpSeed'].includes(this.selectedPage)) { + this.nextText = 'Login' + this.nextHidden = false + // Should enable/disable the next button based on whether or not password are inputted + } else if (['storedWallet', 'loginOptions', 'backedUpSeed'].includes(this.selectedPage)) { + this.nextHidden = true + this.nextText = 'Next' + } + + this.updatedProperty() + } + + updatedProperty() { + this.dispatchEvent(new CustomEvent('updatedProperty', { + detail: {}, + bubbles: true, + composed: true + })) + } + + navigate(page) { + this.dispatchEvent(new CustomEvent('navigate', { + detail: { page }, + bubbles: true, + composed: true + })) + } + + cleanup() { + this.wallet = {} + this.shadowRoot.querySelector('#nameInput').value = '' + this.shadowRoot.querySelector('#password').value = '' + this.hasStoredWallets = Object.keys(store.getState().user.storedWallets).length > 0 + this.selectedPage = this.hasStoredWallets ? 'storedWallet' : 'loginOptions' + } +} + +window.customElements.define('login-section', LoginSection) diff --git a/qortal-ui-core/src/components/login-view/login-view.js b/qortal-ui-core/src/components/login-view/login-view.js new file mode 100644 index 00000000..4428e661 --- /dev/null +++ b/qortal-ui-core/src/components/login-view/login-view.js @@ -0,0 +1,296 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../../store.js' +import { stateAwait } from '../../stateAwait.js' + +import '@material/mwc-button' +import '@material/mwc-icon' +import '@material/mwc-fab' +import '@polymer/iron-pages' +import '@polymer/paper-icon-button/paper-icon-button.js' +import './welcome-page.js' +import './create-account-section.js' +import './login-section.js' + +import settings from '../../functional-components/settings-page.js' + +window.reduxStore = store + +const animationDuration = 0.7 // Seconds + +class LoginView extends connect(store)(LitElement) { + static get properties() { + return { + loggedIn: { type: Boolean }, + selectedPage: { type: String }, + pages: { type: Object }, + rippleIsOpen: { type: Boolean }, + config: { type: Object }, + rippleLoadingMessage: { type: String }, + selectedPageElement: {} + } + } + + static get styles() { + return [ + css` + + ` + ] + } + + getPreSelectedPage() { + + return 'welcome' + } + + constructor() { + super() + this.selectedPage = this.getPreSelectedPage() + this.selectedPageElement = {} + this.rippleIsOpen = false + this.pages = { + welcome: 0, + 'create-account': 1, + login: 2 + } + this.rippleLoadingMessage = 'Getting information' + } + + firstUpdated() { + + stateAwait(state => { + return 'primary' in state.config.styles.theme.colors + }).catch(e => console.error(e)) + + const loginContainerPages = this.shadowRoot.querySelector('#loginContainerPages') + const loginCard = this.shadowRoot.querySelector('#login-card') + const navigate = e => { + this.selectPage(e.detail.page) + } + const updatedProperty = e => { + // ... + const selectedPageElement = this.selectedPageElement + this.selectedPageElement = {} + setTimeout(() => { this.selectedPageElement = selectedPageElement }, 1) // Yuck + } + loginContainerPages.addEventListener('selected-item-changed', () => { + + if (!loginContainerPages.selectedItem) { + + if (this.selectedPageElement.removeEventListener) { + this.selectedPageElement.removeEventListener('navigate', navigate) + this.selectedPageElement.removeEventListener('updatedProperty', updatedProperty) + } + this.selectedPageElement = {} + loginCard.classList.remove('animated') + loginCard.className += ' animated' + } else { + setTimeout(() => { + + this.selectedPageElement = loginContainerPages.selectedItem + + this.selectedPageElement.addEventListener('navigate', navigate) + this.selectedPageElement.addEventListener('updatedProperty', updatedProperty) + setTimeout(() => loginCard.classList.remove('animated'), animationDuration * 1000) + }, 1) + } + }) + } + + render() { + return html` + + + + ` + } + + selectPage(newPage) { + this.selectedPage = newPage + } + + stateChanged(state) { + if (this.loggedIn && !state.app.loggedIn) this.cleanup() + this.loggedIn = state.app.loggedIn + this.config = state.config + } + + cleanup() { + this.selectedPage = 'welcome' + } +} + +window.customElements.define('login-view', LoginView) diff --git a/qortal-ui-core/src/components/login-view/particle-config.js b/qortal-ui-core/src/components/login-view/particle-config.js new file mode 100644 index 00000000..4f1b3b5c --- /dev/null +++ b/qortal-ui-core/src/components/login-view/particle-config.js @@ -0,0 +1,76 @@ +export default config => { + // console.log(config) + // console.log('=====================================') + return { + particles: { + number: { + value: 38, + density: { enable: true, value_area: 1104.8066982851817 } + }, + // color: { value: '#64ffda' }, + color: { value: config.styles.theme.colors.primary }, + shape: { + type: 'polygon', + // stroke: { width: 0, color: '#64ffda' }, + stroke: { width: 0, color: config.styles.theme.colors.primary }, + polygon: { nb_sides: 6 } + }, + opacity: { + value: 0.5, + random: true, + anim: { + enable: true, + speed: 0.1, + opacity_min: 0, + sync: true + } + }, + size: { + value: 10, + random: true, + anim: { enable: true, speed: 6, size_min: 1, sync: false } + }, + line_linked: { + enable: true, + distance: 150, + // color: '#64ffda', + color: config.styles.theme.colors.primary, + opacity: 0.2, + width: 0 + }, + move: { + enable: true, + // enable: false, + speed: 4, + direction: 'none', + random: true, + straight: false, + out_mode: 'bounce', + bounce: false, + attract: { enable: false, rotateX: 600, rotateY: 1200 } + } + }, + interactivity: { + detect_on: 'canvas', + events: { + onhover: { enable: true, mode: 'bubble' }, + onclick: { enable: true, mode: 'repulse' }, + resize: true + }, + modes: { + grab: { distance: 250, line_linked: { opacity: 1 } }, + bubble: { + distance: 100, + size: 15, + duration: 0.6, + opacity: 0.05, + speed: 6 + }, + repulse: { distance: 100, duration: 0.4 }, + push: { particles_nb: 1 }, + remove: { particles_nb: 2 } + } + }, + retina_detect: true + } +} diff --git a/qortal-ui-core/src/components/login-view/particle.js b/qortal-ui-core/src/components/login-view/particle.js new file mode 100644 index 00000000..c743719e --- /dev/null +++ b/qortal-ui-core/src/components/login-view/particle.js @@ -0,0 +1,1324 @@ +/* ----------------------------------------------- +/* Author : Vincent Garreau - vincentgarreau.com +/* MIT license: http://opensource.org/licenses/MIT +/* Demo / Generator : vincentgarreau.com/particles.js +/* GitHub : github.com/VincentGarreau/particles.js +/* How to use? : Check the GitHub README +/* v2.0.0 +/* ----------------------------------------------- */ + +var pJS = function (tag_id, params) { + // var canvas_el = document.querySelector('#' + tag_id + ' > .particles-js-canvas-el'); + var canvas_el = tag_id.querySelector('.particles-js-canvas-el') + + /* particles.js variables with default values */ + this.pJS = { + canvas: { + el: canvas_el, + w: canvas_el.offsetWidth, + h: canvas_el.offsetHeight + }, + particles: { + number: { + value: 400, + density: { + enable: true, + value_area: 800 + } + }, + color: { + value: '#fff' + }, + shape: { + type: 'circle', + stroke: { + width: 0, + color: '#ff0000' + }, + polygon: { + nb_sides: 5 + }, + image: { + src: '', + width: 100, + height: 100 + } + }, + opacity: { + value: 1, + random: false, + anim: { + enable: false, + speed: 2, + opacity_min: 0, + sync: false + } + }, + size: { + value: 20, + random: false, + anim: { + enable: false, + speed: 20, + size_min: 0, + sync: false + } + }, + line_linked: { + enable: true, + distance: 100, + color: '#fff', + opacity: 1, + width: 1 + }, + move: { + enable: true, + speed: 2, + direction: 'none', + random: false, + straight: false, + out_mode: 'out', + bounce: false, + attract: { + enable: false, + rotateX: 3000, + rotateY: 3000 + } + }, + array: [] + }, + interactivity: { + detect_on: 'canvas', + events: { + onhover: { + enable: true, + mode: 'grab' + }, + onclick: { + enable: true, + mode: 'push' + }, + resize: true + }, + modes: { + grab: { + distance: 100, + line_linked: { + opacity: 1 + } + }, + bubble: { + distance: 200, + size: 80, + duration: 0.4 + }, + repulse: { + distance: 200, + duration: 0.4 + }, + push: { + particles_nb: 4 + }, + remove: { + particles_nb: 2 + } + }, + mouse: {} + }, + retina_detect: false, + fn: { + interact: {}, + modes: {}, + vendors: {} + }, + tmp: {} + } + + var pJS = this.pJS + + /* params settings */ + if (params) { + Object.deepExtend(pJS, params) + // console.log(pJS) + } + // console.log(Object.freeze(pJS)) + pJS.tmp.obj = { + size_value: pJS.particles.size.value, + size_anim_speed: pJS.particles.size.anim.speed, + move_speed: pJS.particles.move.speed, + line_linked_distance: pJS.particles.line_linked.distance, + line_linked_width: pJS.particles.line_linked.width, + mode_grab_distance: pJS.interactivity.modes.grab.distance, + mode_bubble_distance: pJS.interactivity.modes.bubble.distance, + mode_bubble_size: pJS.interactivity.modes.bubble.size, + mode_repulse_distance: pJS.interactivity.modes.repulse.distance + } + + pJS.fn.retinaInit = function () { + if (pJS.retina_detect && window.devicePixelRatio > 1) { + pJS.canvas.pxratio = window.devicePixelRatio + pJS.tmp.retina = true + } else { + pJS.canvas.pxratio = 1 + pJS.tmp.retina = false + } + + pJS.canvas.w = pJS.canvas.el.offsetWidth * pJS.canvas.pxratio + pJS.canvas.h = pJS.canvas.el.offsetHeight * pJS.canvas.pxratio + + pJS.particles.size.value = pJS.tmp.obj.size_value * pJS.canvas.pxratio + pJS.particles.size.anim.speed = pJS.tmp.obj.size_anim_speed * pJS.canvas.pxratio + pJS.particles.move.speed = pJS.tmp.obj.move_speed * pJS.canvas.pxratio + pJS.particles.line_linked.distance = pJS.tmp.obj.line_linked_distance * pJS.canvas.pxratio + pJS.interactivity.modes.grab.distance = pJS.tmp.obj.mode_grab_distance * pJS.canvas.pxratio + pJS.interactivity.modes.bubble.distance = pJS.tmp.obj.mode_bubble_distance * pJS.canvas.pxratio + pJS.particles.line_linked.width = pJS.tmp.obj.line_linked_width * pJS.canvas.pxratio + pJS.interactivity.modes.bubble.size = pJS.tmp.obj.mode_bubble_size * pJS.canvas.pxratio + pJS.interactivity.modes.repulse.distance = pJS.tmp.obj.mode_repulse_distance * pJS.canvas.pxratio + } + + /* ---------- pJS functions - canvas ------------ */ + + pJS.fn.canvasInit = function () { + pJS.canvas.ctx = pJS.canvas.el.getContext('2d') + } + + pJS.fn.canvasSize = function () { + pJS.canvas.el.width = pJS.canvas.w + pJS.canvas.el.height = pJS.canvas.h + + if (pJS && pJS.interactivity.events.resize) { + window.addEventListener('resize', function () { + pJS.canvas.w = pJS.canvas.el.offsetWidth + pJS.canvas.h = pJS.canvas.el.offsetHeight + + /* resize canvas */ + if (pJS.tmp.retina) { + pJS.canvas.w *= pJS.canvas.pxratio + pJS.canvas.h *= pJS.canvas.pxratio + } + + pJS.canvas.el.width = pJS.canvas.w + pJS.canvas.el.height = pJS.canvas.h + + /* repaint canvas on anim disabled */ + if (!pJS.particles.move.enable) { + pJS.fn.particlesEmpty() + pJS.fn.particlesCreate() + pJS.fn.particlesDraw() + pJS.fn.vendors.densityAutoParticles() + } + + /* density particles enabled */ + pJS.fn.vendors.densityAutoParticles() + }) + } + } + + pJS.fn.canvasPaint = function () { + pJS.canvas.ctx.fillRect(0, 0, pJS.canvas.w, pJS.canvas.h) + } + + pJS.fn.canvasClear = function () { + pJS.canvas.ctx.clearRect(0, 0, pJS.canvas.w, pJS.canvas.h) + } + + /* --------- pJS functions - particles ----------- */ + + pJS.fn.particle = function (color, opacity, position) { + /* size */ + this.radius = (pJS.particles.size.random ? Math.random() : 1) * pJS.particles.size.value + if (pJS.particles.size.anim.enable) { + this.size_status = false + this.vs = pJS.particles.size.anim.speed / 100 + if (!pJS.particles.size.anim.sync) { + this.vs = this.vs * Math.random() + } + } + + /* position */ + this.x = position ? position.x : Math.random() * pJS.canvas.w + this.y = position ? position.y : Math.random() * pJS.canvas.h + + /* check position - into the canvas */ + if (this.x > pJS.canvas.w - this.radius * 2) this.x = this.x - this.radius + else if (this.x < this.radius * 2) this.x = this.x + this.radius + if (this.y > pJS.canvas.h - this.radius * 2) this.y = this.y - this.radius + else if (this.y < this.radius * 2) this.y = this.y + this.radius + + /* check position - avoid overlap */ + if (pJS.particles.move.bounce) { + pJS.fn.vendors.checkOverlap(this, position) + } + + /* color */ + this.color = {} + if (typeof (color.value) === 'object') { + if (color.value instanceof Array) { + var color_selected = color.value[Math.floor(Math.random() * pJS.particles.color.value.length)] + this.color.rgb = hexToRgb(color_selected) + } else { + if (color.value.r != undefined && color.value.g != undefined && color.value.b != undefined) { + this.color.rgb = { + r: color.value.r, + g: color.value.g, + b: color.value.b + } + } + if (color.value.h != undefined && color.value.s != undefined && color.value.l != undefined) { + this.color.hsl = { + h: color.value.h, + s: color.value.s, + l: color.value.l + } + } + } + } else if (color.value == 'random') { + this.color.rgb = { + r: (Math.floor(Math.random() * (255 - 0 + 1)) + 0), + g: (Math.floor(Math.random() * (255 - 0 + 1)) + 0), + b: (Math.floor(Math.random() * (255 - 0 + 1)) + 0) + } + } else if (typeof (color.value) === 'string') { + this.color = color + this.color.rgb = hexToRgb(this.color.value) + } + + /* opacity */ + this.opacity = (pJS.particles.opacity.random ? Math.random() : 1) * pJS.particles.opacity.value + if (pJS.particles.opacity.anim.enable) { + this.opacity_status = false + this.vo = pJS.particles.opacity.anim.speed / 100 + if (!pJS.particles.opacity.anim.sync) { + this.vo = this.vo * Math.random() + } + } + + /* animation - velocity for speed */ + var velbase = {} + switch (pJS.particles.move.direction) { + case 'top': + velbase = { x: 0, y: -1 } + break + case 'top-right': + velbase = { x: 0.5, y: -0.5 } + break + case 'right': + velbase = { x: 1, y: -0 } + break + case 'bottom-right': + velbase = { x: 0.5, y: 0.5 } + break + case 'bottom': + velbase = { x: 0, y: 1 } + break + case 'bottom-left': + velbase = { x: -0.5, y: 1 } + break + case 'left': + velbase = { x: -1, y: 0 } + break + case 'top-left': + velbase = { x: -0.5, y: -0.5 } + break + default: + velbase = { x: 0, y: 0 } + break + } + + if (pJS.particles.move.straight) { + this.vx = velbase.x + this.vy = velbase.y + if (pJS.particles.move.random) { + this.vx = this.vx * (Math.random()) + this.vy = this.vy * (Math.random()) + } + } else { + this.vx = velbase.x + Math.random() - 0.5 + this.vy = velbase.y + Math.random() - 0.5 + } + + this.vx_i = this.vx + this.vy_i = this.vy + + /* if shape is image */ + + var shape_type = pJS.particles.shape.type + if (typeof (shape_type) === 'object') { + if (shape_type instanceof Array) { + var shape_selected = shape_type[Math.floor(Math.random() * shape_type.length)] + this.shape = shape_selected + } + } else { + this.shape = shape_type + } + + if (this.shape == 'image') { + var sh = pJS.particles.shape + this.img = { + src: sh.image.src, + ratio: sh.image.width / sh.image.height + } + if (!this.img.ratio) this.img.ratio = 1 + if (pJS.tmp.img_type == 'svg' && pJS.tmp.source_svg != undefined) { + pJS.fn.vendors.createSvgImg(this) + if (pJS.tmp.pushing) { + this.img.loaded = false + } + } + } + } + + pJS.fn.particle.prototype.draw = function () { + var p = this + + if (p.radius_bubble != undefined) { + var radius = p.radius_bubble + } else { + var radius = p.radius + } + + if (p.opacity_bubble != undefined) { + var opacity = p.opacity_bubble + } else { + var opacity = p.opacity + } + + if (p.color.rgb) { + var color_value = 'rgba(' + p.color.rgb.r + ',' + p.color.rgb.g + ',' + p.color.rgb.b + ',' + opacity + ')' + } else { + var color_value = 'hsla(' + p.color.hsl.h + ',' + p.color.hsl.s + '%,' + p.color.hsl.l + '%,' + opacity + ')' + } + + pJS.canvas.ctx.fillStyle = color_value + pJS.canvas.ctx.beginPath() + + switch (p.shape) { + case 'circle': + pJS.canvas.ctx.arc(p.x, p.y, radius, 0, Math.PI * 2, false) + break + + case 'edge': + pJS.canvas.ctx.rect(p.x - radius, p.y - radius, radius * 2, radius * 2) + break + + case 'triangle': + pJS.fn.vendors.drawShape(pJS.canvas.ctx, p.x - radius, p.y + radius / 1.66, radius * 2, 3, 2) + break + + case 'polygon': + pJS.fn.vendors.drawShape( + pJS.canvas.ctx, + p.x - radius / (pJS.particles.shape.polygon.nb_sides / 3.5), // startX + p.y - radius / (2.66 / 3.5), // startY + radius * 2.66 / (pJS.particles.shape.polygon.nb_sides / 3), // sideLength + pJS.particles.shape.polygon.nb_sides, // sideCountNumerator + 1 // sideCountDenominator + ) + break + + case 'star': + pJS.fn.vendors.drawShape( + pJS.canvas.ctx, + p.x - radius * 2 / (pJS.particles.shape.polygon.nb_sides / 4), // startX + p.y - radius / (2 * 2.66 / 3.5), // startY + radius * 2 * 2.66 / (pJS.particles.shape.polygon.nb_sides / 3), // sideLength + pJS.particles.shape.polygon.nb_sides, // sideCountNumerator + 2 // sideCountDenominator + ) + break + + case 'image': + + function draw() { + pJS.canvas.ctx.drawImage( + img_obj, + p.x - radius, + p.y - radius, + radius * 2, + radius * 2 / p.img.ratio + ) + } + + if (pJS.tmp.img_type == 'svg') { + var img_obj = p.img.obj + } else { + var img_obj = pJS.tmp.img_obj + } + + if (img_obj) { + draw() + } + + break + } + + pJS.canvas.ctx.closePath() + + if (pJS.particles.shape.stroke.width > 0) { + pJS.canvas.ctx.strokeStyle = pJS.particles.shape.stroke.color + pJS.canvas.ctx.lineWidth = pJS.particles.shape.stroke.width + pJS.canvas.ctx.stroke() + } + + pJS.canvas.ctx.fill() + } + + pJS.fn.particlesCreate = function () { + for (var i = 0; i < pJS.particles.number.value; i++) { + pJS.particles.array.push(new pJS.fn.particle(pJS.particles.color, pJS.particles.opacity.value)) + } + } + + pJS.fn.particlesUpdate = function () { + for (var i = 0; i < pJS.particles.array.length; i++) { + /* the particle */ + var p = pJS.particles.array[i] + + /* move the particle */ + if (pJS.particles.move.enable) { + var ms = pJS.particles.move.speed / 2 + p.x += p.vx * ms + p.y += p.vy * ms + } + + /* change opacity status */ + if (pJS.particles.opacity.anim.enable) { + if (p.opacity_status == true) { + if (p.opacity >= pJS.particles.opacity.value) p.opacity_status = false + p.opacity += p.vo + } else { + if (p.opacity <= pJS.particles.opacity.anim.opacity_min) p.opacity_status = true + p.opacity -= p.vo + } + if (p.opacity < 0) p.opacity = 0 + } + + /* change size */ + if (pJS.particles.size.anim.enable) { + if (p.size_status == true) { + if (p.radius >= pJS.particles.size.value) p.size_status = false + p.radius += p.vs + } else { + if (p.radius <= pJS.particles.size.anim.size_min) p.size_status = true + p.radius -= p.vs + } + if (p.radius < 0) p.radius = 0 + } + + /* change particle position if it is out of canvas */ + if (pJS.particles.move.out_mode == 'bounce') { + var new_pos = { + x_left: p.radius, + x_right: pJS.canvas.w, + y_top: p.radius, + y_bottom: pJS.canvas.h + } + } else { + var new_pos = { + x_left: -p.radius, + x_right: pJS.canvas.w + p.radius, + y_top: -p.radius, + y_bottom: pJS.canvas.h + p.radius + } + } + + if (p.x - p.radius > pJS.canvas.w) { + p.x = new_pos.x_left + p.y = Math.random() * pJS.canvas.h + } else if (p.x + p.radius < 0) { + p.x = new_pos.x_right + p.y = Math.random() * pJS.canvas.h + } + if (p.y - p.radius > pJS.canvas.h) { + p.y = new_pos.y_top + p.x = Math.random() * pJS.canvas.w + } else if (p.y + p.radius < 0) { + p.y = new_pos.y_bottom + p.x = Math.random() * pJS.canvas.w + } + + /* out of canvas modes */ + switch (pJS.particles.move.out_mode) { + case 'bounce': + if (p.x + p.radius > pJS.canvas.w) p.vx = -p.vx + else if (p.x - p.radius < 0) p.vx = -p.vx + if (p.y + p.radius > pJS.canvas.h) p.vy = -p.vy + else if (p.y - p.radius < 0) p.vy = -p.vy + break + } + + /* events */ + if (isInArray('grab', pJS.interactivity.events.onhover.mode)) { + pJS.fn.modes.grabParticle(p) + } + + if (isInArray('bubble', pJS.interactivity.events.onhover.mode) || isInArray('bubble', pJS.interactivity.events.onclick.mode)) { + pJS.fn.modes.bubbleParticle(p) + } + + if (isInArray('repulse', pJS.interactivity.events.onhover.mode) || isInArray('repulse', pJS.interactivity.events.onclick.mode)) { + pJS.fn.modes.repulseParticle(p) + } + + /* interaction auto between particles */ + if (pJS.particles.line_linked.enable || pJS.particles.move.attract.enable) { + for (var j = i + 1; j < pJS.particles.array.length; j++) { + var p2 = pJS.particles.array[j] + + /* link particles */ + if (pJS.particles.line_linked.enable) { + pJS.fn.interact.linkParticles(p, p2) + } + + /* attract particles */ + if (pJS.particles.move.attract.enable) { + pJS.fn.interact.attractParticles(p, p2) + } + + /* bounce particles */ + if (pJS.particles.move.bounce) { + pJS.fn.interact.bounceParticles(p, p2) + } + } + } + } + } + + pJS.fn.particlesDraw = function () { + /* clear canvas */ + pJS.canvas.ctx.clearRect(0, 0, pJS.canvas.w, pJS.canvas.h) + + /* update each particles param */ + pJS.fn.particlesUpdate() + + /* draw each particle */ + for (var i = 0; i < pJS.particles.array.length; i++) { + var p = pJS.particles.array[i] + p.draw() + } + } + + pJS.fn.particlesEmpty = function () { + pJS.particles.array = [] + } + + pJS.fn.particlesRefresh = function () { + /* init all */ + cancelRequestAnimFrame(pJS.fn.checkAnimFrame) + cancelRequestAnimFrame(pJS.fn.drawAnimFrame) + pJS.tmp.source_svg = undefined + pJS.tmp.img_obj = undefined + pJS.tmp.count_svg = 0 + pJS.fn.particlesEmpty() + pJS.fn.canvasClear() + + /* restart */ + pJS.fn.vendors.start() + } + + /* ---------- pJS functions - particles interaction ------------ */ + + pJS.fn.interact.linkParticles = function (p1, p2) { + var dx = p1.x - p2.x + var dy = p1.y - p2.y + var dist = Math.sqrt(dx * dx + dy * dy) + + /* draw a line between p1 and p2 if the distance between them is under the config distance */ + if (dist <= pJS.particles.line_linked.distance) { + var opacity_line = pJS.particles.line_linked.opacity - (dist / (1 / pJS.particles.line_linked.opacity)) / pJS.particles.line_linked.distance + + if (opacity_line > 0) { + /* style */ + var color_line = pJS.particles.line_linked.color_rgb_line + pJS.canvas.ctx.strokeStyle = 'rgba(' + color_line.r + ',' + color_line.g + ',' + color_line.b + ',' + opacity_line + ')' + pJS.canvas.ctx.lineWidth = pJS.particles.line_linked.width + // pJS.canvas.ctx.lineCap = 'round'; /* performance issue */ + + /* path */ + pJS.canvas.ctx.beginPath() + pJS.canvas.ctx.moveTo(p1.x, p1.y) + pJS.canvas.ctx.lineTo(p2.x, p2.y) + pJS.canvas.ctx.stroke() + pJS.canvas.ctx.closePath() + } + } + } + + pJS.fn.interact.attractParticles = function (p1, p2) { + /* condensed particles */ + var dx = p1.x - p2.x + var dy = p1.y - p2.y + var dist = Math.sqrt(dx * dx + dy * dy) + + if (dist <= pJS.particles.line_linked.distance) { + var ax = dx / (pJS.particles.move.attract.rotateX * 1000) + var ay = dy / (pJS.particles.move.attract.rotateY * 1000) + + p1.vx -= ax + p1.vy -= ay + + p2.vx += ax + p2.vy += ay + } + } + + pJS.fn.interact.bounceParticles = function (p1, p2) { + var dx = p1.x - p2.x + var dy = p1.y - p2.y + var dist = Math.sqrt(dx * dx + dy * dy) + var dist_p = p1.radius + p2.radius + + if (dist <= dist_p) { + p1.vx = -p1.vx + p1.vy = -p1.vy + + p2.vx = -p2.vx + p2.vy = -p2.vy + } + } + + /* ---------- pJS functions - modes events ------------ */ + + pJS.fn.modes.pushParticles = function (nb, pos) { + pJS.tmp.pushing = true + + for (var i = 0; i < nb; i++) { + pJS.particles.array.push( + new pJS.fn.particle( + pJS.particles.color, + pJS.particles.opacity.value, + { + x: pos ? pos.pos_x : Math.random() * pJS.canvas.w, + y: pos ? pos.pos_y : Math.random() * pJS.canvas.h + } + ) + ) + if (i == nb - 1) { + if (!pJS.particles.move.enable) { + pJS.fn.particlesDraw() + } + pJS.tmp.pushing = false + } + } + } + + pJS.fn.modes.removeParticles = function (nb) { + pJS.particles.array.splice(0, nb) + if (!pJS.particles.move.enable) { + pJS.fn.particlesDraw() + } + } + + pJS.fn.modes.bubbleParticle = function (p) { + /* on hover event */ + if (pJS.interactivity.events.onhover.enable && isInArray('bubble', pJS.interactivity.events.onhover.mode)) { + var dx_mouse = p.x - pJS.interactivity.mouse.pos_x + var dy_mouse = p.y - pJS.interactivity.mouse.pos_y + var dist_mouse = Math.sqrt(dx_mouse * dx_mouse + dy_mouse * dy_mouse) + var ratio = 1 - dist_mouse / pJS.interactivity.modes.bubble.distance + + function init() { + p.opacity_bubble = p.opacity + p.radius_bubble = p.radius + } + + /* mousemove - check ratio */ + if (dist_mouse <= pJS.interactivity.modes.bubble.distance) { + if (ratio >= 0 && pJS.interactivity.status == 'mousemove') { + /* size */ + if (pJS.interactivity.modes.bubble.size != pJS.particles.size.value) { + if (pJS.interactivity.modes.bubble.size > pJS.particles.size.value) { + var size = p.radius + (pJS.interactivity.modes.bubble.size * ratio) + if (size >= 0) { + p.radius_bubble = size + } + } else { + var dif = p.radius - pJS.interactivity.modes.bubble.size + var size = p.radius - (dif * ratio) + if (size > 0) { + p.radius_bubble = size + } else { + p.radius_bubble = 0 + } + } + } + + /* opacity */ + if (pJS.interactivity.modes.bubble.opacity != pJS.particles.opacity.value) { + if (pJS.interactivity.modes.bubble.opacity > pJS.particles.opacity.value) { + var opacity = pJS.interactivity.modes.bubble.opacity * ratio + if (opacity > p.opacity && opacity <= pJS.interactivity.modes.bubble.opacity) { + p.opacity_bubble = opacity + } + } else { + var opacity = p.opacity - (pJS.particles.opacity.value - pJS.interactivity.modes.bubble.opacity) * ratio + if (opacity < p.opacity && opacity >= pJS.interactivity.modes.bubble.opacity) { + p.opacity_bubble = opacity + } + } + } + } + } else { + init() + } + + /* mouseleave */ + if (pJS.interactivity.status == 'mouseleave') { + init() + } + } + + /* on click event */ + else if (pJS.interactivity.events.onclick.enable && isInArray('bubble', pJS.interactivity.events.onclick.mode)) { + if (pJS.tmp.bubble_clicking) { + var dx_mouse = p.x - pJS.interactivity.mouse.click_pos_x + var dy_mouse = p.y - pJS.interactivity.mouse.click_pos_y + var dist_mouse = Math.sqrt(dx_mouse * dx_mouse + dy_mouse * dy_mouse) + var time_spent = (new Date().getTime() - pJS.interactivity.mouse.click_time) / 1000 + + if (time_spent > pJS.interactivity.modes.bubble.duration) { + pJS.tmp.bubble_duration_end = true + } + + if (time_spent > pJS.interactivity.modes.bubble.duration * 2) { + pJS.tmp.bubble_clicking = false + pJS.tmp.bubble_duration_end = false + } + } + + function process(bubble_param, particles_param, p_obj_bubble, p_obj, id) { + if (bubble_param != particles_param) { + if (!pJS.tmp.bubble_duration_end) { + if (dist_mouse <= pJS.interactivity.modes.bubble.distance) { + if (p_obj_bubble != undefined) var obj = p_obj_bubble + else var obj = p_obj + if (obj != bubble_param) { + var value = p_obj - (time_spent * (p_obj - bubble_param) / pJS.interactivity.modes.bubble.duration) + if (id == 'size') p.radius_bubble = value + if (id == 'opacity') p.opacity_bubble = value + } + } else { + if (id == 'size') p.radius_bubble = undefined + if (id == 'opacity') p.opacity_bubble = undefined + } + } else { + if (p_obj_bubble != undefined) { + var value_tmp = p_obj - (time_spent * (p_obj - bubble_param) / pJS.interactivity.modes.bubble.duration) + var dif = bubble_param - value_tmp + value = bubble_param + dif + if (id == 'size') p.radius_bubble = value + if (id == 'opacity') p.opacity_bubble = value + } + } + } + } + + if (pJS.tmp.bubble_clicking) { + /* size */ + process(pJS.interactivity.modes.bubble.size, pJS.particles.size.value, p.radius_bubble, p.radius, 'size') + /* opacity */ + process(pJS.interactivity.modes.bubble.opacity, pJS.particles.opacity.value, p.opacity_bubble, p.opacity, 'opacity') + } + } + } + + pJS.fn.modes.repulseParticle = function (p) { + if (pJS.interactivity.events.onhover.enable && isInArray('repulse', pJS.interactivity.events.onhover.mode) && pJS.interactivity.status == 'mousemove') { + var dx_mouse = p.x - pJS.interactivity.mouse.pos_x + var dy_mouse = p.y - pJS.interactivity.mouse.pos_y + var dist_mouse = Math.sqrt(dx_mouse * dx_mouse + dy_mouse * dy_mouse) + + var normVec = { x: dx_mouse / dist_mouse, y: dy_mouse / dist_mouse } + var repulseRadius = pJS.interactivity.modes.repulse.distance + var velocity = 100 + var repulseFactor = clamp((1 / repulseRadius) * (-1 * Math.pow(dist_mouse / repulseRadius, 2) + 1) * repulseRadius * velocity, 0, 50) + + var pos = { + x: p.x + normVec.x * repulseFactor, + y: p.y + normVec.y * repulseFactor + } + + if (pJS.particles.move.out_mode == 'bounce') { + if (pos.x - p.radius > 0 && pos.x + p.radius < pJS.canvas.w) p.x = pos.x + if (pos.y - p.radius > 0 && pos.y + p.radius < pJS.canvas.h) p.y = pos.y + } else { + p.x = pos.x + p.y = pos.y + } + } else if (pJS.interactivity.events.onclick.enable && isInArray('repulse', pJS.interactivity.events.onclick.mode)) { + if (!pJS.tmp.repulse_finish) { + pJS.tmp.repulse_count++ + if (pJS.tmp.repulse_count == pJS.particles.array.length) { + pJS.tmp.repulse_finish = true + } + } + + if (pJS.tmp.repulse_clicking) { + var repulseRadius = Math.pow(pJS.interactivity.modes.repulse.distance / 6, 3) + + var dx = pJS.interactivity.mouse.click_pos_x - p.x + var dy = pJS.interactivity.mouse.click_pos_y - p.y + var d = dx * dx + dy * dy + + var force = -repulseRadius / d * 1 + + function process() { + var f = Math.atan2(dy, dx) + p.vx = force * Math.cos(f) + p.vy = force * Math.sin(f) + + if (pJS.particles.move.out_mode == 'bounce') { + var pos = { + x: p.x + p.vx, + y: p.y + p.vy + } + if (pos.x + p.radius > pJS.canvas.w) p.vx = -p.vx + else if (pos.x - p.radius < 0) p.vx = -p.vx + if (pos.y + p.radius > pJS.canvas.h) p.vy = -p.vy + else if (pos.y - p.radius < 0) p.vy = -p.vy + } + } + + // default + if (d <= repulseRadius) { + process() + } + } else { + if (pJS.tmp.repulse_clicking == false) { + p.vx = p.vx_i + p.vy = p.vy_i + } + } + } + } + + pJS.fn.modes.grabParticle = function (p) { + if (pJS.interactivity.events.onhover.enable && pJS.interactivity.status == 'mousemove') { + var dx_mouse = p.x - pJS.interactivity.mouse.pos_x + var dy_mouse = p.y - pJS.interactivity.mouse.pos_y + var dist_mouse = Math.sqrt(dx_mouse * dx_mouse + dy_mouse * dy_mouse) + + /* draw a line between the cursor and the particle if the distance between them is under the config distance */ + if (dist_mouse <= pJS.interactivity.modes.grab.distance) { + var opacity_line = pJS.interactivity.modes.grab.line_linked.opacity - (dist_mouse / (1 / pJS.interactivity.modes.grab.line_linked.opacity)) / pJS.interactivity.modes.grab.distance + + if (opacity_line > 0) { + /* style */ + var color_line = pJS.particles.line_linked.color_rgb_line + pJS.canvas.ctx.strokeStyle = 'rgba(' + color_line.r + ',' + color_line.g + ',' + color_line.b + ',' + opacity_line + ')' + pJS.canvas.ctx.lineWidth = pJS.particles.line_linked.width + // pJS.canvas.ctx.lineCap = 'round'; /* performance issue */ + + /* path */ + pJS.canvas.ctx.beginPath() + pJS.canvas.ctx.moveTo(p.x, p.y) + pJS.canvas.ctx.lineTo(pJS.interactivity.mouse.pos_x, pJS.interactivity.mouse.pos_y) + pJS.canvas.ctx.stroke() + pJS.canvas.ctx.closePath() + } + } + } + } + + /* ---------- pJS functions - vendors ------------ */ + + pJS.fn.vendors.eventsListeners = function () { + /* events target element */ + if (pJS.interactivity.detect_on == 'window') { + pJS.interactivity.el = window + } else { + pJS.interactivity.el = pJS.canvas.el + } + + /* detect mouse pos - on hover / click event */ + if (pJS.interactivity.events.onhover.enable || pJS.interactivity.events.onclick.enable) { + /* el on mousemove */ + pJS.interactivity.el.addEventListener('mousemove', function (e) { + if (pJS.interactivity.el == window) { + var pos_x = e.clientX + var pos_y = e.clientY + } else { + var pos_x = e.offsetX || e.clientX + var pos_y = e.offsetY || e.clientY + } + + pJS.interactivity.mouse.pos_x = pos_x + pJS.interactivity.mouse.pos_y = pos_y + + if (pJS.tmp.retina) { + pJS.interactivity.mouse.pos_x *= pJS.canvas.pxratio + pJS.interactivity.mouse.pos_y *= pJS.canvas.pxratio + } + + pJS.interactivity.status = 'mousemove' + }) + + /* el on onmouseleave */ + pJS.interactivity.el.addEventListener('mouseleave', function (e) { + pJS.interactivity.mouse.pos_x = null + pJS.interactivity.mouse.pos_y = null + pJS.interactivity.status = 'mouseleave' + }) + } + + /* on click event */ + if (pJS.interactivity.events.onclick.enable) { + pJS.interactivity.el.addEventListener('click', function () { + pJS.interactivity.mouse.click_pos_x = pJS.interactivity.mouse.pos_x + pJS.interactivity.mouse.click_pos_y = pJS.interactivity.mouse.pos_y + pJS.interactivity.mouse.click_time = new Date().getTime() + + if (pJS.interactivity.events.onclick.enable) { + switch (pJS.interactivity.events.onclick.mode) { + case 'push': + if (pJS.particles.move.enable) { + pJS.fn.modes.pushParticles(pJS.interactivity.modes.push.particles_nb, pJS.interactivity.mouse) + } else { + if (pJS.interactivity.modes.push.particles_nb == 1) { + pJS.fn.modes.pushParticles(pJS.interactivity.modes.push.particles_nb, pJS.interactivity.mouse) + } else if (pJS.interactivity.modes.push.particles_nb > 1) { + pJS.fn.modes.pushParticles(pJS.interactivity.modes.push.particles_nb) + } + } + break + + case 'remove': + pJS.fn.modes.removeParticles(pJS.interactivity.modes.remove.particles_nb) + break + + case 'bubble': + pJS.tmp.bubble_clicking = true + break + + case 'repulse': + pJS.tmp.repulse_clicking = true + pJS.tmp.repulse_count = 0 + pJS.tmp.repulse_finish = false + setTimeout(function () { + pJS.tmp.repulse_clicking = false + }, pJS.interactivity.modes.repulse.duration * 1000) + break + } + } + }) + } + } + + pJS.fn.vendors.densityAutoParticles = function () { + if (pJS.particles.number.density.enable) { + /* calc area */ + var area = pJS.canvas.el.width * pJS.canvas.el.height / 1000 + if (pJS.tmp.retina) { + area = area / (pJS.canvas.pxratio * 2) + } + + /* calc number of particles based on density area */ + var nb_particles = area * pJS.particles.number.value / pJS.particles.number.density.value_area + + /* add or remove X particles */ + var missing_particles = pJS.particles.array.length - nb_particles + if (missing_particles < 0) pJS.fn.modes.pushParticles(Math.abs(missing_particles)) + else pJS.fn.modes.removeParticles(missing_particles) + } + } + + pJS.fn.vendors.checkOverlap = function (p1, position) { + for (var i = 0; i < pJS.particles.array.length; i++) { + var p2 = pJS.particles.array[i] + + var dx = p1.x - p2.x + var dy = p1.y - p2.y + var dist = Math.sqrt(dx * dx + dy * dy) + + if (dist <= p1.radius + p2.radius) { + p1.x = position ? position.x : Math.random() * pJS.canvas.w + p1.y = position ? position.y : Math.random() * pJS.canvas.h + pJS.fn.vendors.checkOverlap(p1) + } + } + } + + pJS.fn.vendors.createSvgImg = function (p) { + /* set color to svg element */ + var svgXml = pJS.tmp.source_svg + var rgbHex = /#([0-9A-F]{3,6})/gi + var coloredSvgXml = svgXml.replace(rgbHex, function (m, r, g, b) { + if (p.color.rgb) { + var color_value = 'rgba(' + p.color.rgb.r + ',' + p.color.rgb.g + ',' + p.color.rgb.b + ',' + p.opacity + ')' + } else { + var color_value = 'hsla(' + p.color.hsl.h + ',' + p.color.hsl.s + '%,' + p.color.hsl.l + '%,' + p.opacity + ')' + } + return color_value + }) + + /* prepare to create img with colored svg */ + var svg = new Blob([coloredSvgXml], { type: 'image/svg+xml;charset=utf-8' }) + var DOMURL = window.URL || window.webkitURL || window + var url = DOMURL.createObjectURL(svg) + + /* create particle img obj */ + var img = new Image() + img.addEventListener('load', function () { + p.img.obj = img + p.img.loaded = true + DOMURL.revokeObjectURL(url) + pJS.tmp.count_svg++ + }) + img.src = url + } + + pJS.fn.vendors.destroypJS = function () { + cancelAnimationFrame(pJS.fn.drawAnimFrame) + canvas_el.remove() + pJSDom = null + } + + pJS.fn.vendors.drawShape = function (c, startX, startY, sideLength, sideCountNumerator, sideCountDenominator) { + // By Programming Thomas - https://programmingthomas.wordpress.com/2013/04/03/n-sided-shapes/ + var sideCount = sideCountNumerator * sideCountDenominator + var decimalSides = sideCountNumerator / sideCountDenominator + var interiorAngleDegrees = (180 * (decimalSides - 2)) / decimalSides + var interiorAngle = Math.PI - Math.PI * interiorAngleDegrees / 180 // convert to radians + c.save() + c.beginPath() + c.translate(startX, startY) + c.moveTo(0, 0) + for (var i = 0; i < sideCount; i++) { + c.lineTo(sideLength, 0) + c.translate(sideLength, 0) + c.rotate(interiorAngle) + } + // c.stroke(); + c.fill() + c.restore() + } + + pJS.fn.vendors.exportImg = function () { + window.open(pJS.canvas.el.toDataURL('image/png'), '_blank') + } + + pJS.fn.vendors.loadImg = function (type) { + pJS.tmp.img_error = undefined + + if (pJS.particles.shape.image.src != '') { + if (type == 'svg') { + var xhr = new XMLHttpRequest() + xhr.open('GET', pJS.particles.shape.image.src) + xhr.onreadystatechange = function (data) { + if (xhr.readyState == 4) { + if (xhr.status == 200) { + pJS.tmp.source_svg = data.currentTarget.response + pJS.fn.vendors.checkBeforeDraw() + } else { + console.log('Error pJS - Image not found') + pJS.tmp.img_error = true + } + } + } + xhr.send() + } else { + var img = new Image() + img.addEventListener('load', function () { + pJS.tmp.img_obj = img + pJS.fn.vendors.checkBeforeDraw() + }) + img.src = pJS.particles.shape.image.src + } + } else { + console.log('Error pJS - No image.src') + pJS.tmp.img_error = true + } + } + + pJS.fn.vendors.draw = function () { + if (pJS.particles.shape.type == 'image') { + if (pJS.tmp.img_type == 'svg') { + if (pJS.tmp.count_svg >= pJS.particles.number.value) { + pJS.fn.particlesDraw() + if (!pJS.particles.move.enable) cancelRequestAnimFrame(pJS.fn.drawAnimFrame) + else pJS.fn.drawAnimFrame = requestAnimFrame(pJS.fn.vendors.draw) + } else { + + if (!pJS.tmp.img_error) pJS.fn.drawAnimFrame = requestAnimFrame(pJS.fn.vendors.draw) + } + } else { + if (pJS.tmp.img_obj != undefined) { + pJS.fn.particlesDraw() + if (!pJS.particles.move.enable) cancelRequestAnimFrame(pJS.fn.drawAnimFrame) + else pJS.fn.drawAnimFrame = requestAnimFrame(pJS.fn.vendors.draw) + } else { + if (!pJS.tmp.img_error) pJS.fn.drawAnimFrame = requestAnimFrame(pJS.fn.vendors.draw) + } + } + } else { + pJS.fn.particlesDraw() + if (!pJS.particles.move.enable) cancelRequestAnimFrame(pJS.fn.drawAnimFrame) + else pJS.fn.drawAnimFrame = requestAnimFrame(pJS.fn.vendors.draw) + } + } + + pJS.fn.vendors.checkBeforeDraw = function () { + + if (pJS.particles.shape.type == 'image') { + if (pJS.tmp.img_type == 'svg' && pJS.tmp.source_svg == undefined) { + pJS.tmp.checkAnimFrame = requestAnimFrame(check) + } else { + + cancelRequestAnimFrame(pJS.tmp.checkAnimFrame) + if (!pJS.tmp.img_error) { + pJS.fn.vendors.init() + pJS.fn.vendors.draw() + } + } + } else { + pJS.fn.vendors.init() + pJS.fn.vendors.draw() + } + } + + pJS.fn.vendors.init = function () { + /* init canvas + particles */ + pJS.fn.retinaInit() + pJS.fn.canvasInit() + pJS.fn.canvasSize() + pJS.fn.canvasPaint() + pJS.fn.particlesCreate() + pJS.fn.vendors.densityAutoParticles() + + /* particles.line_linked - convert hex colors to rgb */ + pJS.particles.line_linked.color_rgb_line = hexToRgb(pJS.particles.line_linked.color) + } + + pJS.fn.vendors.start = function () { + if (isInArray('image', pJS.particles.shape.type)) { + pJS.tmp.img_type = pJS.particles.shape.image.src.substr(pJS.particles.shape.image.src.length - 3) + pJS.fn.vendors.loadImg(pJS.tmp.img_type) + } else { + pJS.fn.vendors.checkBeforeDraw() + } + } + + /* ---------- pJS - start ------------ */ + + pJS.fn.vendors.eventsListeners() + + pJS.fn.vendors.start() +} + +const checkKeys = (storeObj, newObj) => { + for (const key in newObj) { + + if (typeof newObj[key] === 'object') { + storeObj[key] = checkKeys(storeObj[key], newObj[key]) + } else { + storeObj[key] = newObj[key] + } + } + return storeObj +} + +Object.deepExtend = function (destination, source) { + checkKeys(destination, source) +} + +window.requestAnimFrame = (function () { + return window.requestAnimationFrame || + window.webkitRequestAnimationFrame || + window.mozRequestAnimationFrame || + window.oRequestAnimationFrame || + window.msRequestAnimationFrame || + function (callback) { + window.setTimeout(callback, 1000 / 60) + } +})() + +window.cancelRequestAnimFrame = (function () { + return window.cancelAnimationFrame || + window.webkitCancelRequestAnimationFrame || + window.mozCancelRequestAnimationFrame || + window.oCancelRequestAnimationFrame || + window.msCancelRequestAnimationFrame || + clearTimeout +})() + +function hexToRgb(hex) { + // By Tim Down - http://stackoverflow.com/a/5624139/3493650 + // Expand shorthand form (e.g. "03F") to full form (e.g. "0033FF") + var shorthandRegex = /^#?([a-f\d])([a-f\d])([a-f\d])$/i + hex = hex.replace(shorthandRegex, function (m, r, g, b) { + return r + r + g + g + b + b + }) + var result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex) + return result ? { + r: parseInt(result[1], 16), + g: parseInt(result[2], 16), + b: parseInt(result[3], 16) + } : null +}; + +function clamp(number, min, max) { + return Math.min(Math.max(number, min), max) +}; + +function isInArray(value, array) { + return array.indexOf(value) > -1 +} + +/* ---------- particles.js functions - start ------------ */ + +window.pJSDom = [] + +window.particlesJS = function (tag_id, params) { + + if (!tag_id) { + tag_id = docuemnt.getElementById('particles-js') + } + + /* pJS elements */ + var pJS_tag = tag_id + var pJS_canvas_class = 'particles-js-canvas-el' + var exist_canvas = pJS_tag.getElementsByClassName(pJS_canvas_class) + + /* remove canvas if exists into the pJS target tag */ + if (exist_canvas.length) { + while (exist_canvas.length > 0) { + pJS_tag.removeChild(exist_canvas[0]) + } + } + + /* create canvas element */ + var canvas_el = document.createElement('canvas') + canvas_el.className = pJS_canvas_class + + /* set size canvas */ + canvas_el.style.width = '100%' + canvas_el.style.height = '100%' + + /* append canvas */ + var canvas = tag_id.appendChild(canvas_el) + + /* launch particle.js */ + if (canvas != null) { + pJSDom.push(new pJS(tag_id, params)) + } +} + +window.particlesJS.load = function (tag_id, path_config_json, callback) { + /* load json config */ + var xhr = new XMLHttpRequest() + xhr.open('GET', path_config_json) + xhr.onreadystatechange = function (data) { + if (xhr.readyState == 4) { + if (xhr.status == 200) { + var params = JSON.parse(data.currentTarget.response) + window.particlesJS(tag_id, params) + if (callback) callback() + } else { + console.log('Error pJS - XMLHttpRequest status: ' + xhr.status) + console.log('Error pJS - File config not found') + } + } + } + xhr.send() +} diff --git a/qortal-ui-core/src/components/login-view/welcome-page.js b/qortal-ui-core/src/components/login-view/welcome-page.js new file mode 100644 index 00000000..85d485b2 --- /dev/null +++ b/qortal-ui-core/src/components/login-view/welcome-page.js @@ -0,0 +1,78 @@ +import { LitElement, html, css } from 'lit-element' + +import '@material/mwc-button' + +class WelcomePage extends LitElement { + static get properties() { + return { + nextHidden: { type: Boolean, notify: true }, + nextEnabled: { type: Boolean, notify: true }, + nextText: { type: String, notify: true }, + backHidden: { type: Boolean, notify: true }, + backDisabled: { type: Boolean, notify: true }, + backText: { type: String, notify: true }, + hideNav: { type: Boolean, notify: true } + } + } + + static get styles() { + return [ + css` + mwc-button { + margin: 6px; + width: 90%; + max-width:90vw; + margin: 4px; + } + .welcome-page { + padding: 12px 0; + } + ` + ] + } + + constructor() { + super() + this.hideNav = true + this.nextText = '' + const welcomeMessage = 'Welcome to Qortal'; + this.welcomeMessage = welcomeMessage + } + + firstUpdate() { + // ... + } + + render() { + return html` + +
+ + this.navigate('login')} outlined style="border-top:0; border-bottom:0;">Login + this.navigate('create-account')} outlined style="border-top:0; border-bottom:0;">Create account +
+ ` + } + + back() { } + + next() { } + + navigate(page) { + this.dispatchEvent(new CustomEvent('navigate', { + detail: { page }, + bubbles: true, + composed: true + })) + } +} + +window.customElements.define('welcome-page', WelcomePage) diff --git a/qortal-ui-core/src/components/main-app.js b/qortal-ui-core/src/components/main-app.js new file mode 100644 index 00000000..704a68d7 --- /dev/null +++ b/qortal-ui-core/src/components/main-app.js @@ -0,0 +1,120 @@ +import { LitElement, html } from 'lit-element' +import { installRouter } from 'pwa-helpers/router.js' +import { connect } from 'pwa-helpers' +import { store } from '../store.js' +import { doNavigate } from '../redux/app/app-actions.js' +import '../plugins/streams.js' + +import { loadPlugins } from '../plugins/load-plugins.js' + +import '../styles/app-styles.js' +import './login-view/login-view.js' +import './app-view.js' + +import copyTextMenu from '../functional-components/copy-text-menu.js' +// import pasteMenu from '../functional-components/paste-menu.js'; +import framePasteMenu from '../functional-components/frame-paste-menu.js'; + +installRouter((location) => store.dispatch(doNavigate(location))) + +class MainApp extends connect(store)(LitElement) { + static get properties() { + return { + name: { type: String }, + loggedIn: { type: Boolean } + } + } + + static get styles() { + return [] + } + + render() { + + return html`${this.renderViews(this.loggedIn)}` + } + + /** + * Dynamic renderViews method to introduce conditional rendering of views based on user's logged in state. + * @param {Boolean} isLoggedIn + */ + + renderViews(isLoggedIn) { + if (isLoggedIn) { + + return html` + + ` + } else { + + return html` + + ` + } + } + + stateChanged(state) { + + this.loggedIn = state.app.loggedIn + + if (this.loggedIn === true && this.initial === 0) { + + this.initial = this.initial + 1 + this._loadPlugins() + } + + document.title = state.config.coin.name + } + + _loadPlugins() { + + loadPlugins() + } + + connectedCallback() { + super.connectedCallback() + this.initial = 0 + + window.addEventListener('contextmenu', (event) => { + event.preventDefault(); + this._textMenu(event); + }) + + window.addEventListener('click', () => { + copyTextMenu.close() + framePasteMenu.close() + }) + + window.onkeyup = (e) => { + if (e.keyCode === 27) { + copyTextMenu.close() + framePasteMenu.close() + } + } + } + + _textMenu(event) { + const getSelectedText = () => { + var text = '' + if (typeof window.getSelection !== 'undefined') { + text = window.getSelection().toString() + } else if (typeof this.shadowRoot.selection !== 'undefined' && this.shadowRoot.selection.type == 'Text') { + text = this.shadowRoot.selection.createRange().text + } + return text + } + + const checkSelectedTextAndShowMenu = () => { + const selectedText = getSelectedText() + if (selectedText && typeof selectedText === 'string') { + + const textMenuObject = { selectedText, eventObject: event } + copyTextMenu.open(textMenuObject) + } + } + + checkSelectedTextAndShowMenu() + } +} + +window.customElements.define('main-app', MainApp) diff --git a/qortal-ui-core/src/components/settings-view/account-view.js b/qortal-ui-core/src/components/settings-view/account-view.js new file mode 100644 index 00000000..edc567bc --- /dev/null +++ b/qortal-ui-core/src/components/settings-view/account-view.js @@ -0,0 +1,95 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../../store.js' + +class AccountView extends connect(store)(LitElement) { + + static get styles() { + return css` + + .sub-main { + position: relative; + text-align: center; + } + + .center-box { + position: relative; + top: 45%; + left: 50%; + transform: translate(-50%, 0%); + text-align: center; + } + + .img-icon { + font-size: 150px; + display: block; + } + + .content-box { + border: 1px solid #a1a1a1; + padding: 10px 25px; + text-align: left; + display: inline-block; + /* min-width: 350px; */ + } + + .title { + font-weight: 600; + font-size: 15px; + display: block; + line-height: 32px; + opacity: 0.66; + } + + .value { + font-size: 16px; + display: inline-block; + } + + .start-chat { + display: inline-flex; + flex-direction: column; + justify-content: center; + align-content: center; + border: none; + border-radius: 20px; + padding-left: 25px; + padding-right: 25px; + color: white; + background: #6a6c75; + width: 50%; + font-size: 17px; + cursor: pointer; + height: 50px; + margin-top: 1rem; + text-transform: uppercase; + text-decoration: none; + transition: all .2s; + position: relative; + } + ` + } + + render() { + return html` +
+
+ account_circle +
+ Address: + ${store.getState().app.selectedAddress.address} +
+ Public Key: + ${store.getState().app.selectedAddress.base58PublicKey} +
+
+
+ ` + } + + stateChanged(state) { + // ... + } +} + +window.customElements.define('account-view', AccountView) diff --git a/qortal-ui-core/src/components/settings-view/notifications-view.js b/qortal-ui-core/src/components/settings-view/notifications-view.js new file mode 100644 index 00000000..bfaa7289 --- /dev/null +++ b/qortal-ui-core/src/components/settings-view/notifications-view.js @@ -0,0 +1,157 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../../store.js' + +import { doSetQChatNotificationConfig } from '../../redux/user/user-actions.js' + +import '@material/mwc-checkbox' + + +class NotificationsView extends connect(store)(LitElement) { + static get properties() { + return { + notificationConfig: { type: Object }, + q_chatConfig: { type: Object }, + blockConfig: { type: Object } + } + } + + constructor() { + super() + this.notificationConfig = {} + this.q_chatConfig = {} + this.blockConfig = {} + } + + static get styles() { + return css` + .sub-main { + position: relative; + text-align: center; + } + + .notification-box { + display: block; + position: relative; + top: 45%; + left: 50%; + transform: translate(-50%, 0%); + text-align: center; + } + + @media(min-width: 1150px) { + .notification-box { + display: grid; + grid-template-columns: 1fr 1fr; + grid-gap: 30px; + } + } + + .content-box { + border: 1px solid #a1a1a1; + padding: 10px 25px; + text-align: left; + display: inline-block; + min-width: 350px; + min-height: 150px; + margin: 20px 0; + } + + h4 { + margin-bottom: 0; + } + + mwc-checkbox::shadow .mdc-checkbox::after, mwc-checkbox::shadow .mdc-checkbox::before { + background-color:var(--mdc-theme-primary) + } + + label:hover { + cursor: pointer; + } + + .title { + font-weight: 600; + font-size: 15px; + display: block; + line-height: 32px; + opacity: 0.66; + } + + .value { + font-size: 16px; + display: inline-block; + } + ` + } + + render() { + return html` +
+
+
+

Q-Chat Notifications

+ +
+ this.setQChatNotificationConfig({ type: 'PLAY_SOUND', value: e.target.checked })} ?checked=${this.q_chatConfig.playSound}> + +
+ +
+ this.setQChatNotificationConfig({ type: 'SHOW_NOTIFICATION', value: e.target.checked })} ?checked=${this.q_chatConfig.showNotification}> + +
+
+
+

Block Notifications ("Coming Soon...")

+ +
+ + +
+ +
+ + +
+
+
+
+ ` + } + + stateChanged(state) { + + this.notificationConfig = state.user.notifications + this.q_chatConfig = this.notificationConfig.q_chat + this.blockConfig = this.notificationConfig.block + } + + setQChatNotificationConfig(valueObject) { + + if (valueObject.type === 'PLAY_SOUND') { + + let data = { + playSound: !valueObject.value, + showNotification: this.q_chatConfig.showNotification + } + store.dispatch(doSetQChatNotificationConfig(data)) + } if (valueObject.type === 'SHOW_NOTIFICATION') { + + let data = { + playSound: this.q_chatConfig.playSound, + showNotification: !valueObject.value + } + store.dispatch(doSetQChatNotificationConfig(data)) + } + } + + +} + +window.customElements.define('notifications-view', NotificationsView) diff --git a/qortal-ui-core/src/components/settings-view/security-view.js b/qortal-ui-core/src/components/settings-view/security-view.js new file mode 100644 index 00000000..55dc1c4f --- /dev/null +++ b/qortal-ui-core/src/components/settings-view/security-view.js @@ -0,0 +1,84 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../../store.js' + +import '@material/mwc-textfield' + +import FileSaver from 'file-saver' + +class SecurityView extends connect(store)(LitElement) { + static get properties() { + return { + + } + } + + static get styles() { + return css` + .center-box { + position: relative; + top: 45%; + left: 50%; + transform: translate(-50%, 0%); + text-align: center; + } + + .q-button { + display: inline-flex; + flex-direction: column; + justify-content: center; + align-content: center; + border: none; + border-radius: 20px; + padding-left: 25px; + padding-right: 25px; + color: white; + background: #6a6c75; + width: 50%; + font-size: 17px; + cursor: pointer; + height: 50px; + margin-top: 1rem; + text-transform: uppercase; + text-decoration: none; + transition: all .2s; + position: relative; + } + ` + } + + render() { + return html` +
+
+

+ Please choose a password to encrypt your backup with (this can be the same as the one you logged in with, or different) +

+
+ +
this.downloadBackup()} class="q-button"> Download BackUp File
+
+
+
+ ` + } + + stateChanged(state) { + // ... + } + + async downloadBackup() { + const state = store.getState() + const password = this.shadowRoot.getElementById('downloadBackupPassword').value + + console.log(password); + + const data = await state.app.wallet.generateSaveWalletData(password, state.config.crypto.kdfThreads, () => { }) + const dataString = JSON.stringify(data) + + const blob = new Blob([dataString], { type: 'text/plain;charset=utf-8' }) + FileSaver.saveAs(blob, `qortal_backup_${state.app.selectedAddress.address}.json`) + } +} + +window.customElements.define('security-view', SecurityView) diff --git a/qortal-ui-core/src/components/settings-view/user-settings.js b/qortal-ui-core/src/components/settings-view/user-settings.js new file mode 100644 index 00000000..2bd9d092 --- /dev/null +++ b/qortal-ui-core/src/components/settings-view/user-settings.js @@ -0,0 +1,312 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../../store.js' + +import '@polymer/paper-dialog/paper-dialog.js' +import '@material/mwc-button' + +// Settings View +import './account-view.js' +import './security-view.js' +import './notifications-view.js' + +import { doLogout } from '../../redux/app/app-actions.js' + +class UserSettings extends connect(store)(LitElement) { + static get properties() { + return { + loggedIn: { type: Boolean }, + pages: { type: Array }, + selectedView: { type: Object } + } + } + + static get styles() { + return css` + + :host { + margin: 0; + width: 100%; + max-width: 100vw; + height: 100%; + max-height: 100vh; + background-color: #fff; + color: #333333; + line-height: 1.6; + } + + .decline { + --mdc-theme-primary: var(--mdc-theme-error) + } + + paper-dialog.userSettings { + width: 100%; + max-width: 100vw; + height: 100%; + max-height: 100vh; + background-color: #fff; + color: #333333; + line-height: 1.6; + overflow-y: auto; + } + + .actions { + display:flex; + justify-content: space-between; + padding: 0 4em; + margin: 15px 0 -2px 0; + } + + .close-icon { + font-size: 36px; + } + + .close-icon:hover { + cursor: pointer; + opacity: .6; + } + + .buttons { + text-align:right; + } + + .container { + max-width: 90vw; + margin-left: auto; + margin-right: auto; + margin-top: 20px; + padding: .6em; + } + + ul { + list-style: none; + padding: 0; + margin-bottom: 0; + } + + .leftBar { + background-color: #fff; + color: #333333; + border: 1px solid #a1a1a1; + padding: 20px 0 0 0; + border-radius: 5px; + } + + .leftBar img { + margin: 0 auto; + width: 75%; + height: 75%; + text-align: center; + } + + .leftBar .slug { + text-align: center; + margin-top: 20px; + color: #333333; + font-size: 16px; + font-weight: 600; + margin-bottom: 7px; + } + + + .leftBar ul li { + border-bottom: 1px solid #DDD; + } + + .leftBar ul li:last-child { + border-bottom: none; + } + + .leftBar ul li a { + color: #333333; + font-size: 16px; + font-weight: 400; + text-decoration: none; + padding: .9em; + display: block; + } + + .leftBar ul li a i { + margin-right: 8px; + font-size: 16px; + } + + .leftBar ul li a:hover { + background-color: #f6f6f6; + color: #515151; + } + + .leftBar ul li:active { + border-bottom: none; + } + + .leftBar ul li a.active { + color: #515151; + background-color: #eee; + border-left: 2px solid #515151; + margin-left: -2px; + } + + + /* Main Profile Page */ + + .mainPage { + background-color: #fff; + color: #333333; + border: 1px solid #a1a1a1; + padding: 20px 0 10px 0; + border-radius: 5px; + font-size: 16px; + text-align: center; + min-height: 460px; + } + + + + /* Styles for Smaller Screen Sizes */ + + @media(max-width:700px) { + .mainPage { + margin-top: 30px; + } + } + + + /* Styles for Larger Screen Sizes */ + + @media(min-width:765px) { + + * { + margin: 0; + padding: 0; + box-sizing: border-box; + } + + .actions { + display:flex; + justify-content: space-between; + padding: 0 4em; + margin: 15px 0 -25px 0; + } + + .container { + padding: 2em; + } + + .wrapper { + display: grid; + grid-template-columns: 1fr 3fr; + grid-gap: 30px; + } + + .wrapper > .mainPage { + padding: 2em; + } + + .leftBar { + text-align: left; + max-height: 403px; + max-width: 400px; + font-size: 16px; + } + + .mainPage { + font-size: 16px; + } + } + ` + } + + constructor() { + super() + this.selectedView = { id: 'info', name: 'General Account Info' } + } + + render() { + return html` + + + + +
+

+ this.closeSettings()} title="Close Settings" >highlight_off +
+ +
+
+
+
Qortal UI Settings
+
    +
  • this.setSettingsView('info')} >Account
  • +
  • this.setSettingsView('security')} >Security
  • +
  • this.setSettingsView('notification')} >Notifications
  • +
+
+ +
+

${ this.selectedView.name}

+
+ ${html`${this.renderSettingViews(this.selectedView)}`} + +
+
+
+
+ ` + } + + stateChanged(state) { + this.loggedIn = state.app.loggedIn + } + + renderSettingViews(selectedView) { + + if (selectedView.id === 'info') { + return html``; + } else if (selectedView.id === 'security') { + return html``; + } else if (selectedView.id === 'notification') { + return html``; + } + } + + setSettingsView(pageId) { + + if (pageId === 'info') { + return this.selectedView = { id: 'info', name: 'General Account Info' } + } else if (pageId === 'security') { + return this.selectedView = { id: 'security', name: 'Account Security' } + } else if (pageId === 'notification') { + return this.selectedView = { id: 'notification', name: 'UI Notifications' } + } + } + + openSettings() { + if (this.loggedIn) { + + this.shadowRoot.getElementById('userSettingsDialog').open() + } + } + + closeSettings() { + + this.shadowRoot.getElementById('userSettingsDialog').close() + this.cleanUp() + } + + cleanUp() { + this.selectedView = { id: 'info', name: 'General Account Info' } + } +} + +window.customElements.define('user-settings', UserSettings) diff --git a/qortal-ui-core/src/components/show-plugin.js b/qortal-ui-core/src/components/show-plugin.js new file mode 100644 index 00000000..3d03d5af --- /dev/null +++ b/qortal-ui-core/src/components/show-plugin.js @@ -0,0 +1,118 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../store.js' +import { Epml } from '../epml.js' +import { addPluginRoutes } from '../plugins/addPluginRoutes.js' + +class ShowPlugin extends connect(store)(LitElement) { + static get properties() { + return { + app: { type: Object }, + pluginConfig: { type: Object }, + url: { type: String }, + linkParam: { type: String } + } + } + + static get styles() { + return css` + html { + --scrollbarBG: #a1a1a1; + --thumbBG: #6a6c75; + } + + *::-webkit-scrollbar { + width: 11px; + } + + * { + scrollbar-width: thin; + scrollbar-color: var(--thumbBG) var(--scrollbarBG); + } + + *::-webkit-scrollbar-track { + background: var(--scrollbarBG); + } + + *::-webkit-scrollbar-thumb { + background-color: var(--thumbBG); + border-radius: 6px; + border: 3px solid var(--scrollbarBG); + } + + iframe#showPluginFrame { + width:100%; + height:calc(var(--window-height) - 68px); + border:0; + padding:0; + margin:0; + } + ` + } + + render() { + const plugSrc = (myPlug) => { + return myPlug === undefined ? 'about:blank' : `${window.location.origin}/plugin/${myPlug.domain}/${myPlug.page}${this.linkParam}` + } + + const plugArr = [] + this.app.registeredUrls.forEach(myPlugArr => { + myPlugArr.menus.length === 0 ? plugArr.push(myPlugArr) : myPlugArr.menus.forEach(i => plugArr.push(myPlugArr, i)) + }) + + const myPlugObj = plugArr.find(pagePlug => { + return pagePlug.url === this.url + }) + + return html` + + ` + } + + firstUpdated() { + + const showingPluginEpml = new Epml({ + type: 'WINDOW', + source: this.shadowRoot.getElementById('showPluginFrame').contentWindow + }) + addPluginRoutes(showingPluginEpml) + showingPluginEpml.imReady() + this.showingPluginEpml = showingPluginEpml + Epml.registerProxyInstance('visible-plugin', showingPluginEpml) + } + + updated(changedProps) { + if (changedProps.has('url')) { + //... + } + + if (changedProps.has('computerUrl')) { + if (this.computedUrl !== 'about:blank') { + this.loading = true + } + } + } + + stateChanged(state) { + this.app = state.app + this.config = state.config + + const split = state.app.url.split('/') + + if (split[0] === '' && split[1] === 'app' && split[2] === undefined) { + this.url = 'wallet' + this.linkParam = '' + } else if (split.length === 5 && split[1] === 'app') { + this.url = split[2] + this.linkParam = split[3] === undefined ? '' : '?' + split[3] + '/' + split[4] + } else if (split[1] === 'app') { + this.url = split[2] + this.linkParam = '' + } else { + this.url = '404' + this.linkParam = '' + } + } +} + +window.customElements.define('show-plugin', ShowPlugin) diff --git a/qortal-ui-core/src/components/sidenav-menu.js b/qortal-ui-core/src/components/sidenav-menu.js new file mode 100644 index 00000000..5564a35b --- /dev/null +++ b/qortal-ui-core/src/components/sidenav-menu.js @@ -0,0 +1,254 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../store.js' + +import '@material/mwc-icon' +import '@polymer/paper-ripple' +import { doLogout } from '../redux/app/actions/login' + +class SidenavMenu extends connect(store)(LitElement) { + static get properties() { + return { + config: { type: Object }, + urls: { type: Object } + } + } + + static get styles() { + return [ + css` + .mcd-menu { + list-style: none; + padding: 0px 0px; + background: rgb(255, 255, 255); + border-radius: 2px; + width: 100%; + outline: none; + } + .mcd-menu li { + position: relative; + /* height:48px; */ + line-height: 48px; + outline: none; + padding: 2px; + list-style: none; + } + .mcd-menu li a { + display: block; + text-decoration: none; + padding-left: 20px; + color: var(--mdc-theme-on-surface); + text-align: left; + height: 48px; + position: relative; + border-bottom: 1px solid #EEE; + outline: none; + } + .mcd-menu li a mwc-icon { + float: left; + margin: 0 10px 0 0; + padding-top: 12px; + padding-right: 9px; + } + + .mcd-menu li a span { + display: block; + text-transform: uppercase; + outline: none; + } + + .mcd-menu li a small { + display: block; + font-size: 10px; + outline: none; + } + + .mcd-menu li:hover > a mwc-icon { + opacity: 1; + } + .mcd-menu li:hover a span { + opacity: 1; + outline: none; + } + + .mcd-menu li:hover > a { + background: #f8f8f8; + color: #515151; + } + .mcd-menu li a.active { + position: relative; + color: #515151; + background-color: #eee; + outline: none; + } + .mcd-menu li a.active:before { + content: ""; + position: absolute; + top: 42%; + left: 0; + border-left: 5px solid #515151; + border-top: 5px solid transparent; + border-bottom: 5px solid transparent; + outline: none; + } + + .mcd-menu li a.active:after { + content: ""; + position: absolute; + top: 42%; + right: 0; + border-right: 5px solid #515151; + border-top: 5px solid transparent; + border-bottom: 5px solid transparent; + outline: none; + } + + .mcd-menu li ul, + .mcd-menu li ul li ul { + position: absolute; + height: auto; + min-width: 240px; + padding: 0; + margin: 0; + background: #FFF; + opacity: 0; + visibility: hidden; + transition: all 300ms linear; + -o-transition: all 300ms linear; + -ms-transition: all 300ms linear; + -moz-transition: all 300ms linear; + -webkit-transition: all 300ms linear; + z-index: 999999999; + left:280px; + top: 0px; + border-left: 4px solid #515151; + outline: none; + } + .mcd-menu li ul:before { + content: ""; + position: absolute; + top: 25px; + left: -9px; + border-right: 5px solid #515151; + border-bottom: 5px solid transparent; + border-top: 5px solid transparent; + outline: none; + } + .mcd-menu li:hover > ul, + .mcd-menu li ul li:hover > ul { + display: block; + opacity: 1; + visibility: visible; + left:260px; + outline: none; + } + + .mcd-menu li ul li a { + /* padding: 10px; */ + text-align: left; + border: 0; + border-bottom: 1px solid #EEE; + height: auto; + outline: none; + } + .mcd-menu li ul li a mwc-icon { + /* font-size: 16px; */ + display: inline-block; + margin: 0 10px 0 0; + } + .mcd-menu li ul li ul { + left: 230px; + top: 0; + border: 0; + border-left: 4px solid #515151; + outline: none; + } + .mcd-menu li ul li ul:before { + content: ""; + position: absolute; + top: 15px; + left: -9px; + border-right: 5px solid #515151; + border-bottom: 5px solid transparent; + border-top: 5px solid transparent; + outline: none; + } + .mcd-menu li ul li:hover > ul { + top: 0px; + left: 200px; + outline: none; + } + ` + ] + } + + constructor() { + super() + this.urls = [] + } + + render() { + return html` + + +
+ +
+ ` + } + + firstUpdated() { + // ... + } + + stateChanged(state) { + this.config = state.config + this.urls = state.app.registeredUrls + } + + async logout(e) { + if(window.confirm('Are you sure you want to logout?')) { + store.dispatch(doLogout()) + } + } +} + +window.customElements.define('sidenav-menu', SidenavMenu) diff --git a/qortal-ui-core/src/components/wallet-profile.js b/qortal-ui-core/src/components/wallet-profile.js new file mode 100644 index 00000000..8e4c34f6 --- /dev/null +++ b/qortal-ui-core/src/components/wallet-profile.js @@ -0,0 +1,110 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../store.js' + +import '@polymer/paper-toast' +import '@material/mwc-icon-button' + +class WalletProfile extends connect(store)(LitElement) { + static get properties() { + return { + wallet: { type: Object }, + nodeConfig: { type: Object }, + accountInfo: { type: Object } + } + } + + static get styles() { + return [ + css` + ` + ] + } + + constructor() { + super() + this.nodeConfig = {} + this.accountInfo = { + names: [], + addressInfo: {} + } + } + + render() { + return html` + + + +
+
+ + ${this.accountInfo.names.length !== 0 ? this.accountInfo.names[0].name : ''} + + ${this.accountInfo.addressInfo ? html`Minter Level - ${this.accountInfo.addressInfo.level} ${this.accountInfo.addressInfo.flags === 1 ? html`(F)` : ''}` : ''} +

Blocks Minted - ${this.accountInfo.addressInfo.blocksMinted + this.accountInfo.addressInfo.blocksMintedAdjustment}

+

${this.wallet.addresses[0].address}

+
+
+ + ` + } + + firstUpdated() { + + const container = document.body.querySelector('main-app').shadowRoot.querySelector('app-view').shadowRoot; + const toast = this.shadowRoot.getElementById('toast') + const isMobile = window.matchMedia(`(max-width: ${getComputedStyle(document.body).getPropertyValue('--layout-breakpoint-tablet')})`).matches + + if (isMobile) { + toast.verticalAlign = 'bottom' + toast.verticalOffset = 0 + } + this.toast = container.appendChild(toast) + } + + stateChanged(state) { + this.wallet = state.app.wallet + this.nodeConfig = state.app.nodeConfig + this.accountInfo = state.app.accountInfo + } +} + +window.customElements.define('wallet-profile', WalletProfile) diff --git a/qortal-ui-core/src/cryptoUtils.js b/qortal-ui-core/src/cryptoUtils.js new file mode 100644 index 00000000..f26e8c96 --- /dev/null +++ b/qortal-ui-core/src/cryptoUtils.js @@ -0,0 +1,55 @@ +'use strict' +const utils = { + int32ToBytes (word) { + var byteArray = [] + for (var b = 0; b < 32; b += 8) { + byteArray.push((word >>> (24 - b % 32)) & 0xFF) + } + return byteArray + }, + + stringtoUTF8Array (message) { + if (typeof message === 'string') { + var s = unescape(encodeURIComponent(message)) // UTF-8 + message = new Uint8Array(s.length) + for (var i = 0; i < s.length; i++) { + message[i] = s.charCodeAt(i) & 0xff + } + } + return message + }, + // ...buffers then buffers.foreach and append to buffer1 + appendBuffer (buffer1, buffer2) { + buffer1 = new Uint8Array(buffer1) + buffer2 = new Uint8Array(buffer2) + const tmp = new Uint8Array(buffer1.byteLength + buffer2.byteLength) + tmp.set(buffer1, 0) + tmp.set(buffer2, buffer1.byteLength) + return tmp + }, + + int64ToBytes (int64) { + // we want to represent the input as a 8-bytes array + var byteArray = [0, 0, 0, 0, 0, 0, 0, 0] + + for (var index = 0; index < byteArray.length; index++) { + var byte = int64 & 0xff + byteArray[byteArray.length - index - 1] = byte + int64 = (int64 - byte) / 256 + } + + return byteArray + }, + + equal (buf1, buf2) { + if (buf1.byteLength != buf2.byteLength) return false + var dv1 = new Uint8Array(buf1) + var dv2 = new Uint8Array(buf2) + for (var i = 0; i != buf1.byteLength; i++) { + if (dv1[i] != dv2[i]) return false + } + return true + } +} + +export default utils diff --git a/qortal-ui-core/src/custom-elements/frag-file-input.js b/qortal-ui-core/src/custom-elements/frag-file-input.js new file mode 100644 index 00000000..a0aa0bd5 --- /dev/null +++ b/qortal-ui-core/src/custom-elements/frag-file-input.js @@ -0,0 +1,126 @@ +import { LitElement, html, css } from 'lit-element' + +import '@material/mwc-button' +import '@material/mwc-icon' + +class FragFileInput extends LitElement { + static get properties () { + return { + accept: { + type: String + }, + readAs: { + type: String + } + } + } + + static get styles () { + return css` + #drop-area { + border: 2px dashed #ccc; + font-family: "Roboto", sans-serif; + padding: 20px; + } + #trigger:hover { + cursor: pointer; + } + #drop-area.highlight { + border-color: var(--mdc-theme-primary, #000); + } + p { + margin-top: 0; + } + form { + margin-bottom: 10px; + } + #fileInput { + display: none; + } + ` + } + + constructor () { + super() + this.readAs = this.readAs || 'Text' + } + + render () { + return html` + + +
+ + +
+ this.shadowRoot.getElementById('fileInput').click()} style="dispay:inline;"> + cloud_upload  Select file + + Drag and drop backup here +
+
+ + + + + ` + } + + readFile (file) { + const fr = new FileReader() + + fr.onload = () => { + this.dispatchEvent(new CustomEvent('file-read-success', { + detail: { result: fr.result }, + bubbles: true, + composed: true + })) + } + + fr['readAs' + this.readAs](file) + } + + firstUpdated () { + this._dropArea = this.shadowRoot.getElementById('drop-area') + // console.log(this._dropArea) + + const preventDefaults = e => { + e.preventDefault() + e.stopPropagation() + } + + ;['dragenter', 'dragover', 'dragleave', 'drop'].forEach(eventName => { + this._dropArea.addEventListener(eventName, preventDefaults, false) + }) + + const highlight = e => { + this._dropArea.classList.add('highlight') + } + + const unhighlight = e => { + this._dropArea.classList.remove('highlight') + } + + ;['dragenter', 'dragover'].forEach(eventName => { + // console.log('dragenter/dragover') + this._dropArea.addEventListener(eventName, highlight, false) + }) + + ;['dragleave', 'drop'].forEach(eventName => { + // console.log('drag-leave/drop') + this._dropArea.addEventListener(eventName, unhighlight, false) + }) + + this._dropArea.addEventListener('drop', e => { + // console.log('DROPPED') + const dt = e.dataTransfer + const file = dt.files[0] + + this.readFile(file) + }, false) + } +} + +window.customElements.define('frag-file-input', FragFileInput) diff --git a/qortal-ui-core/src/epml.js b/qortal-ui-core/src/epml.js new file mode 100644 index 00000000..188f8def --- /dev/null +++ b/qortal-ui-core/src/epml.js @@ -0,0 +1,11 @@ +import { Epml, EpmlReadyPlugin, RequestPlugin, ContentWindow as EpmlContentWindowPlugin, EpmlStreamPlugin, EpmlProxyPlugin, EpmlStream } from 'epml' + +// Epml.registerPlugin(contentWindowsPlugin) +Epml.registerPlugin(RequestPlugin) +Epml.registerPlugin(EpmlReadyPlugin) +Epml.registerPlugin(EpmlContentWindowPlugin) +Epml.registerPlugin(EpmlStreamPlugin) +Epml.registerPlugin(EpmlProxyPlugin) +Epml.allowProxying = true + +export { Epml, EpmlStream } diff --git a/qortal-ui-core/src/functional-components/confirm-transaction-dialog.js b/qortal-ui-core/src/functional-components/confirm-transaction-dialog.js new file mode 100644 index 00000000..5eb6b1e0 --- /dev/null +++ b/qortal-ui-core/src/functional-components/confirm-transaction-dialog.js @@ -0,0 +1,96 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../store.js' + +import { listenForRequest } from '../transactionRequest.js' + +import '@polymer/paper-dialog/paper-dialog.js' +import '@material/mwc-button' + +class ConfirmTransactionDialog extends connect(store)(LitElement) { + static get properties() { + return { + txInfo: { type: Object } + } + } + + static get styles() { + return css` + .decline { + --mdc-theme-primary: var(--mdc-theme-error) + } + #txInfo { + text-align:left; + max-width:520px; + } + + .buttons { + text-align:right; + } + table td, th{ + padding:4px; + text-align:left; + font-size:14px; + } + ` + } + + constructor() { + super() + this.transaction = { + template: html`Awaiting transaction info` + } + this.txInfo = html`` + listenForRequest(args => this.requestTransaction(args)) + } + + render() { + return html` + + + +

Transaction request

+
+ ${this.txInfo} +
+
+ this.decline(e)} dialog-dismiss>Decline + this.confirm(e)} dialog-confirm autofocus>Confirm +
+
+ ` + } + + stateChanged(state) { + this.loggedIn = state.app.loggedIn + } + + requestTransaction(transaction) { + this.shadowRoot.getElementById('confirmDialog').open() + this.transaction = transaction + this.txInfo = transaction.render(html) + + return new Promise((resolve, reject) => { + this._resolve = resolve + this._reject = reject + }) + } + + confirm(e) { + this._resolve({ + success: true + }) + } + + decline(e) { + + this._reject(new Error('User declined transaction')) + } +} + +window.customElements.define('confirm-transaction-dialog', ConfirmTransactionDialog) + +const txDialog = document.createElement('confirm-transaction-dialog') +export const requestTransactionDialog = document.body.appendChild(txDialog) diff --git a/qortal-ui-core/src/functional-components/copy-text-menu.js b/qortal-ui-core/src/functional-components/copy-text-menu.js new file mode 100644 index 00000000..86a192ad --- /dev/null +++ b/qortal-ui-core/src/functional-components/copy-text-menu.js @@ -0,0 +1,246 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../store'; + +import { doCopyMenuSwitch } from '../redux/app/app-actions'; + + +let copyTextMenuElement + +class CopyTextMenu extends connect(store)(LitElement) { + static get properties() { + return { + selectedText: { + type: String, + attribute: 'selected-text', + reflectToAttribute: true + }, + eventObject: { + type: Object, + attribute: 'event-object', + reflectToAttribute: true + }, + isCopyMenuOpen: { + type: Boolean + } + } + } + + constructor() { + super() + this.selectedText = '' + this.eventObject = {} + this.isCopyMenuOpen = false + } + + static get styles() { + return css` + .context-menu{ + display: block; + opacity: 0; + position: absolute; + pointer-events: none; + padding: 5px, 0; + border: 1px solid #B2B2B2; + min-width: 150px; + max-width: 300px; + background: #F9F9F9; + /* box-shadow: 3px 3px 2px #E9E9E9; */ + border-radius: 4px; + } + + .c-open { + pointer-events: all; + opacity: 1; + z-index: 120; + } + + #items { + list-style: none; + margin: 0px; + margin-top: 4px; + padding-left: 5px; + padding-right: 5px; + padding-bottom: 3px; + font-size: 17px; + color: #333333; + } + hr { + width: 85%; + background-color: #E4E4E4; + border-color: #E4E4E4; + color: #E4E4E4; + } + li{ + padding: 3px; + padding-left:10px; + } + + #items :hover{ + color: white; + background: #6a6c75; + border-radius: 2px; + } + ` + } + + render() { + return html` +
+
    +
  • this.saveToClipboard(this.selectedText)} >Copy
  • +
+ + +
+ ` + } + + firstUpdated() { + this.contextElement = this.shadowRoot.querySelector('.context-menu') + } + + saveToClipboard(text) { + + try { + + navigator.clipboard.writeText(text).then(() => { + + window.getSelection().removeAllRanges() + window.parent.getSelection().removeAllRanges() + + store.dispatch(doCopyMenuSwitch(false)) + + // ... + }).catch((err) => { + console.log('failed: ', err) + }) + } catch (err) { + + // Fallback, if all fails + document.execCommand('copy'); + + window.getSelection().removeAllRanges() + window.parent.getSelection().removeAllRanges() + + store.dispatch(doCopyMenuSwitch(false)) + } + } + + textMenu(selectedText, eventObject, isFrame) { + + this.selectedText = selectedText + + const getPosition = (isFrame, event) => { + let posx = 0 + let posy = 0 + + if (isFrame) { + + const p = document.querySelector('main') + const d = document.getElementById('main-app').shadowRoot.querySelector('app-view').shadowRoot.querySelector('app-drawer-layout').children[1].querySelector('show-plugin').shadowRoot.querySelector('iframe') + + posx = p.offsetWidth - d.offsetWidth + event.pageX + posy = d.offsetTop + event.pageY + } else { + if (event.pageX || event.pageY) { + + posx = event.pageX + posy = event.pageY + } else if (event.clientX || event.clientY) { + + posx = event.clientX + document.body.scrollLeft + + document.documentElement.scrollLeft + posy = event.clientY + document.body.scrollTop + + document.documentElement.scrollTop + } + } + + return { + x: posx, + y: posy + } + } + + const positionMenu = (isFrame, event) => { + + const newPosition = { + left: '0px', + top: '0px' + } + + const clickCoords = getPosition(isFrame, event) + + const clickCoordsX = clickCoords.x + const clickCoordsY = clickCoords.y + + const menuWidth = this.contextElement.offsetWidth + 4 + const menuHeight = this.contextElement.offsetHeight + 4 + + const windowWidth = window.innerWidth + const windowHeight = window.innerHeight + + if ((windowWidth - clickCoordsX) < menuWidth) { + + newPosition.left = windowWidth - menuWidth + 'px' + } else { + + newPosition.left = clickCoordsX + 'px' + } + + if ((windowHeight - clickCoordsY) < menuHeight) { + + newPosition.top = windowHeight - menuHeight + 'px' + } else { + + newPosition.top = clickCoordsY + 'px' + } + + return newPosition + } + + const pos = positionMenu(isFrame, eventObject) + this.contextElement.style.top = pos.top + this.contextElement.style.left = pos.left + this.contextElement.style.opacity = '1' + this.contextElement.releasePointerCapture = true + this.contextElement.classList.add('c-open') + document.getElementById('main-app').shadowRoot.querySelector('copy-text-menu').inert = false + } + + open(textMenuObject) { + + const selectedText = textMenuObject.selectedText + const eventObject = textMenuObject.eventObject + const isFrame = textMenuObject.isFrame + this.textMenu(selectedText, eventObject, isFrame) + store.dispatch(doCopyMenuSwitch(true)) + } + + close() { + this.contextElement.style.opacity = '0' + this.contextElement.classList.remove('c-open') + } + + stateChanged(state) { + + this.isCopyMenuOpen = state.app.copyMenuSwitch + } +} + +window.customElements.define('copy-text-menu', CopyTextMenu) + +const copyTextMenuNode = document.createElement('copy-text-menu') +copyTextMenuNode.id = 'copy-text-menu-node' +copyTextMenuNode.inert = false +copyTextMenuNode.eventObject = {} +copyTextMenuElement = document.body.appendChild(copyTextMenuNode) +setTimeout(() => { + const menuNode = document.getElementById('copy-text-menu-node') + const mainApp = document.getElementById('main-app').shadowRoot + const shadow = mainApp + copyTextMenuElement = shadow.appendChild(menuNode) +}, 500) +export default copyTextMenuElement diff --git a/qortal-ui-core/src/functional-components/frame-paste-menu.js b/qortal-ui-core/src/functional-components/frame-paste-menu.js new file mode 100644 index 00000000..389449ba --- /dev/null +++ b/qortal-ui-core/src/functional-components/frame-paste-menu.js @@ -0,0 +1,204 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../store'; + +import { doFramePasteMenuSwitch } from '../redux/app/app-actions'; + + +let framePasteMenuElement + +class FramePasteMenu extends connect(store)(LitElement) { + static get properties() { + return { + eventObject: { + type: Object, + attribute: 'event-object', + reflectToAttribute: true + }, + framePasteMenuOpen: { + type: Object + }, + elementId: { + type: String + } + } + } + + constructor() { + super() + this.eventObject = {} + this.framePasteMenuOpen = { + isOpen: false, + elementId: '' + } + this.elementId = '' + } + + static get styles() { + return css` + .frame-paste-context-menu{ + display: block; + opacity: 0; + position: absolute; + pointer-events: none; + padding: 5px, 0; + border: 1px solid #B2B2B2; + min-width: 150px; + max-width: 300px; + background: #F9F9F9; + /* box-shadow: 3px 3px 2px #E9E9E9; */ + border-radius: 4px; + } + + .p-open { + pointer-events: all; + opacity: 1; + z-index: 120; + } + + #items { + list-style: none; + margin: 0px; + margin-top: 4px; + padding-left: 5px; + padding-right: 5px; + padding-bottom: 3px; + font-size: 17px; + color: #333333; + } + hr { + width: 85%; + background-color: #E4E4E4; + border-color: #E4E4E4; + color: #E4E4E4; + } + li{ + padding: 3px; + padding-left:10px; + } + + #items :hover{ + color: white; + background: #6a6c75; + border-radius: 2px; + } + ` + } + + render() { + return html` +
+
    +
  • this.paste()} >Paste
  • +
+
+ ` + } + + firstUpdated() { + this.contextElement = this.shadowRoot.querySelector('.frame-paste-context-menu') + } + + paste() { + + store.dispatch(doFramePasteMenuSwitch({ isOpen: false, elementId: this.elementId })) + } + + positionMenu(eventObject) { + + + const getPosition = (event) => { + let posx = 0 + let posy = 0 + + const p = document.querySelector('main') + const d = document.getElementById('main-app').shadowRoot.querySelector('app-view').shadowRoot.querySelector('app-drawer-layout').children[1].querySelector('show-plugin').shadowRoot.querySelector('iframe') + + posx = p.offsetWidth - d.offsetWidth + event.pageX + posy = d.offsetTop + event.pageY + + return { + x: posx, + y: posy + } + } + + const positionMenu = (event) => { + + const newPosition = { + left: '0px', + top: '0px' + } + + const clickCoords = getPosition(event) + + const clickCoordsX = clickCoords.x + const clickCoordsY = clickCoords.y + + const menuWidth = this.contextElement.offsetWidth + 4 + const menuHeight = this.contextElement.offsetHeight + 4 + + const windowWidth = window.innerWidth + const windowHeight = window.innerHeight + + if ((windowWidth - clickCoordsX) < menuWidth) { + + newPosition.left = windowWidth - menuWidth + 'px' + } else { + + newPosition.left = clickCoordsX + 'px' + } + + if ((windowHeight - clickCoordsY) < menuHeight) { + + newPosition.top = windowHeight - menuHeight + 'px' + } else { + + newPosition.top = clickCoordsY + 'px' + } + + return newPosition + } + + const pos = positionMenu(eventObject) + this.contextElement.style.top = pos.top + this.contextElement.style.left = pos.left + this.contextElement.style.opacity = '1' + this.contextElement.releasePointerCapture = true + this.contextElement.classList.add('p-open') + document.getElementById('main-app').shadowRoot.querySelector('frame-paste-menu').inert = false + } + + open(eventObject) { + + this.elementId = eventObject.elementId + this.positionMenu(eventObject) + store.dispatch(doFramePasteMenuSwitch({ isOpen: true, elementId: eventObject.elementId })) + } + + close() { + this.contextElement.style.opacity = '0' + this.contextElement.classList.remove('p-open') + } + + + stateChanged(state) { + + this.framePasteMenuOpen = state.app.framePasteMenuSwitch + } +} + +window.customElements.define('frame-paste-menu', FramePasteMenu) + +const framePasteMenuNode = document.createElement('frame-paste-menu') +framePasteMenuNode.id = 'frame-paste-menu-node' +framePasteMenuNode.inert = false +framePasteMenuNode.eventObject = {} +framePasteMenuElement = document.body.appendChild(framePasteMenuNode) +setTimeout(() => { + const menuNode = document.getElementById('frame-paste-menu-node') + const mainApp = document.getElementById('main-app').shadowRoot + const shadow = mainApp + framePasteMenuElement = shadow.appendChild(menuNode) +}, 500) +export default framePasteMenuElement diff --git a/qortal-ui-core/src/functional-components/loading-ripple.js b/qortal-ui-core/src/functional-components/loading-ripple.js new file mode 100644 index 00000000..c0158550 --- /dev/null +++ b/qortal-ui-core/src/functional-components/loading-ripple.js @@ -0,0 +1,199 @@ +import { LitElement, html, css } from 'lit-element' + +const TRANSITION_EVENT_NAMES = ['transitionend', 'webkitTransitionEnd', 'oTransitionEnd', 'MSTransitionEnd'] + +let rippleElement + +class LoadingRipple extends LitElement { + static get properties () { + return { + welcomeMessage: { + type: String, + attribute: 'welcome-message', + reflectToAttribute: true + }, + loadingMessage: { + type: String, + attribute: 'loading-message', + reflectToAttribute: true + } + } + } + + constructor () { + super() + this.welcomeMessage = '' + this.loadingMessage = '' + } + + static get styles () { + return css` + * { + --paper-spinner-color: var(--mdc-theme-secondary); + } + + #rippleWrapper{ + position:fixed; + top:0; + left:0; + bottom:0; + right:0; + height:0; + width:0; + z-index:999; + overflow: visible; + --ripple-activating-transition: transform 0.3s cubic-bezier(0.6, 0.0, 1, 1), opacity 0.3s cubic-bezier(0.6, 0.0, 1, 1); + --ripple-disable-transition: opacity 0.5s ease; + } + #ripple { + border-radius:50%; + border-width:0; + margin-left:-100vmax; + margin-top: -100vmax; + height:200vmax; + width:200vmax; + overflow:hidden; + background: var(--mdc-theme-primary); + transform: scale(0); + overflow:hidden; + } + #ripple.error { + transition: var(--ripple-activating-transition); + background: var(--mdc-theme-error) + } + #rippleShader { + background: var(--mdc-theme-surface); + opacity:0; + height:100%; + width:100%; + } + #ripple.activating{ + transition: var(--ripple-activating-transition); + transform: scale(1) + } + .activating #rippleShader { + transition: var(--ripple-activating-transition); + opacity: 1; + } + #ripple.disabling{ + transition: var(--ripple-disable-transition); + opacity: 0; + } + #rippleContentWrapper { + position: absolute; + top:100vmax; + left:100vmax; + height:var(--window-height); + width:100vw; + display: flex; + align-items: center; + justify-content: center; + } + #rippleContent { + opacity: 0; + text-align:center; + } + .activating-done #rippleContent { + opacity: 1; + transition: var(--ripple-activating-transition); + } + + ` + } + + render () { + return html` +
+
+
+
+
+

${this.welcomeMessage}

+ +

${this.loadingMessage}

+
+
+
+
+ ` + } + + firstUpdated () { + this._rippleWrapper = this.shadowRoot.getElementById('rippleWrapper') + this._ripple = this.shadowRoot.getElementById('ripple') + this._rippleContentWrapper = this.shadowRoot.getElementById('rippleContentWrapper') + } + + // duh + open (origin) { + this._rippleWrapper.style.top = origin.y + 'px' + this._rippleWrapper.style.left = origin.x + 'px' + this._rippleContentWrapper.style.marginTop = -origin.y + 'px' + this._rippleContentWrapper.style.marginLeft = -origin.x + 'px' + + return new Promise((resolve, reject) => { + this._ripple.classList.add('activating') + let isOpened = false + const doneOpeningEvent = () => { + if (isOpened) return + // Clear events + TRANSITION_EVENT_NAMES.forEach(name => this._ripple.removeEventListener(name, doneOpeningEvent)) + this._ripple.classList.add('activating-done') + isOpened = true + resolve() + } + TRANSITION_EVENT_NAMES.forEach(name => this._ripple.addEventListener(name, doneOpeningEvent)) + }) + } + + // Fades out + fade () { + return new Promise((resolve, reject) => { + // CAN'T FADE OUT CAUSE THE STUPID THING GETS KILLED CAUSE OF STATE.APP.LOGGEEDIN + // let rippleClosed = false + this._ripple.classList.remove('activating') + this._ripple.classList.remove('activating-done') + this._ripple.classList.remove('disabling') + resolve() + }) + } + + // un-ripples... + close () { + return new Promise((resolve, reject) => { + let rippleClosed = false + this._ripple.classList.add('error') + this._ripple.classList.remove('activating') + this._ripple.classList.remove('activating-done') + const rippleClosedEvent = () => { + if (rippleClosed) return + rippleClosed = true + TRANSITION_EVENT_NAMES.forEach(name => this._ripple.removeEventListener(name, rippleClosedEvent)) + // Reset the ripple + this._ripple.classList.remove('error') + this.rippleIsOpen = false + resolve() + } + TRANSITION_EVENT_NAMES.forEach(name => this._ripple.addEventListener(name, rippleClosedEvent)) + }) + } + + stateChanged (state) { + // this.loggedIn = state.app.loggedIn + } +} + +window.customElements.define('loading-ripple', LoadingRipple) + +const rippleNode = document.createElement('loading-ripple') +rippleNode.id = 'ripple-node' +rippleNode.loadingMessage = '' +rippleElement = document.body.appendChild(rippleNode) +setTimeout(() => { + const ripple = document.getElementById('ripple-node') + const mainApp = document.getElementById('main-app') + const shadow = mainApp.shadowRoot + // console.log(shadow) + rippleElement = shadow.appendChild(ripple) +}, 500) // Should just keep checking for the main-app and it's shadow and then append once it's there +export default rippleElement diff --git a/qortal-ui-core/src/functional-components/paste-menu.js b/qortal-ui-core/src/functional-components/paste-menu.js new file mode 100644 index 00000000..37c22ae2 --- /dev/null +++ b/qortal-ui-core/src/functional-components/paste-menu.js @@ -0,0 +1,202 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../store'; + +import { doPasteMenuSwitch } from '../redux/app/app-actions'; + + +let pasteMenuElement + +class FramePasteMenu extends connect(store)(LitElement) { + static get properties() { + return { + eventObject: { + type: Object, + attribute: 'event-object', + reflectToAttribute: true + }, + isPasteMenuOpen: { + type: Boolean + } + } + } + + constructor() { + super() + this.eventObject = {} + this.isPasteMenuOpen = false + } + + static get styles() { + return css` + .paste-context-menu{ + display: block; + opacity: 0; + position: absolute; + pointer-events: none; + padding: 5px, 0; + border: 1px solid #B2B2B2; + min-width: 150px; + max-width: 300px; + background: #F9F9F9; + /* box-shadow: 3px 3px 2px #E9E9E9; */ + border-radius: 4px; + } + + .p-open { + pointer-events: all; + opacity: 1; + z-index: 120; + } + + #items { + list-style: none; + margin: 0px; + margin-top: 4px; + padding-left: 5px; + padding-right: 5px; + padding-bottom: 3px; + font-size: 17px; + color: #333333; + } + hr { + width: 85%; + background-color: #E4E4E4; + border-color: #E4E4E4; + color: #E4E4E4; + } + li{ + padding: 3px; + padding-left:10px; + } + + #items :hover{ + color: white; + background: #6a6c75; + border-radius: 2px; + } + ` + } + + render() { + return html` +
+
    +
  • this.paste()} >Paste
  • +
+
+ ` + } + + firstUpdated() { + this.contextElement = this.shadowRoot.querySelector('.paste-context-menu') + } + + paste() { + + store.dispatch(doPasteMenuSwitch(false)) + } + + positionMenu(eventObject) { + + + const getPosition = (event) => { + let posx = 0 + let posy = 0 + + if (event.pageX || event.pageY) { + + posx = event.pageX + posy = event.pageY + } else if (event.clientX || event.clientY) { + + posx = event.clientX + document.body.scrollLeft + + document.documentElement.scrollLeft + posy = event.clientY + document.body.scrollTop + + document.documentElement.scrollTop + } + + return { + x: posx, + y: posy + } + } + + const positionMenu = (event) => { + + const newPosition = { + left: '0px', + top: '0px' + } + + const clickCoords = getPosition(event) + + const clickCoordsX = clickCoords.x + const clickCoordsY = clickCoords.y + + const menuWidth = this.contextElement.offsetWidth + 4 + const menuHeight = this.contextElement.offsetHeight + 4 + + const windowWidth = window.innerWidth + const windowHeight = window.innerHeight + + if ((windowWidth - clickCoordsX) < menuWidth) { + + newPosition.left = windowWidth - menuWidth + 'px' + } else { + + newPosition.left = clickCoordsX + 'px' + } + + if ((windowHeight - clickCoordsY) < menuHeight) { + + newPosition.top = windowHeight - menuHeight + 'px' + } else { + + newPosition.top = clickCoordsY + 'px' + } + + return newPosition + } + + const pos = positionMenu(eventObject) + this.contextElement.style.top = pos.top + this.contextElement.style.left = pos.left + this.contextElement.style.opacity = '1' + this.contextElement.releasePointerCapture = true + this.contextElement.classList.add('p-open') + document.getElementById('main-app').shadowRoot.querySelector('paste-menu').inert = false + } + + open(eventObject) { + + this.positionMenu(eventObject) + store.dispatch(doPasteMenuSwitch(true)) + } + + close() { + this.contextElement.style.opacity = '0' + this.contextElement.classList.remove('p-open') + } + + + stateChanged(state) { + + this.isPasteMenuOpen = state.app.pasteMenuSwitch + } +} + +window.customElements.define('paste-menu', FramePasteMenu) + +const pasteMenuNode = document.createElement('paste-menu') +pasteMenuNode.id = 'paste-menu-node' +pasteMenuNode.inert = false +pasteMenuNode.eventObject = {} +pasteMenuElement = document.body.appendChild(pasteMenuNode) +setTimeout(() => { + const menuNode = document.getElementById('paste-menu-node') + const mainApp = document.getElementById('main-app').shadowRoot + const shadow = mainApp + pasteMenuElement = shadow.appendChild(menuNode) +}, 500) +export default pasteMenuElement diff --git a/qortal-ui-core/src/functional-components/settings-page.js b/qortal-ui-core/src/functional-components/settings-page.js new file mode 100644 index 00000000..c12bd89d --- /dev/null +++ b/qortal-ui-core/src/functional-components/settings-page.js @@ -0,0 +1,151 @@ +import { LitElement, html, css } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../store.js' + +import { doAddNode, doSetNode } from '../redux/app/app-actions.js' + +import '@material/mwc-dialog' +import '@material/mwc-button' +import '@material/mwc-select' +import '@material/mwc-textfield' +import '@material/mwc-icon' + +import '@material/mwc-list/mwc-list-item.js' + +import snackbar from './snackbar.js' + +let settingsDialog + +class SettingsPage extends connect(store)(LitElement) { + static get properties() { + return { + lastSelected: { type: Number }, + nodeConfig: { type: Object } + } + } + + static get styles() { + return css` + .red { + --mdc-theme-primary: red; + } + ` + } + + constructor() { + super() + this.nodeConfig = {} + } + + render() { + return html` + + + +
+ + this.nodeSelected(e)} style="min-width: 130px; max-width:100%; width:100%;"> + ${this.nodeConfig.knownNodes.map((n, index) => html` + ${n.protocol + '://' + n.domain + ':' + n.port} + `)} + + +

Select a node from the default list of nodes above or add a custom node to the list above by clicking on the button below

+ + this.shadowRoot.querySelector('#addNodeDialog').show()}>addAdd Custom Node +
+ + Close + +
+ + + + http + https + +
+ + + + Cancel + + + Add + +
+ ` + } + + stateChanged(state) { + this.config = state.config + this.nodeConfig = state.app.nodeConfig + } + + show() { + this.shadowRoot.getElementById('settingsDialog').show() + } + + nodeSelected(e) { + const selectedNodeIndex = this.shadowRoot.getElementById('nodeSelect').value + const selectedNode = this.nodeConfig.knownNodes[selectedNodeIndex] + const selectedNodeUrl = `${selectedNode.protocol + '://' + selectedNode.domain + ':' + selectedNode.port}` + + const index = parseInt(selectedNodeIndex) + if (isNaN(index)) return + + // Set selected node + store.dispatch(doSetNode(selectedNodeIndex)) + snackbar.add({ + labelText: `UI Set to Node : ${selectedNodeUrl}`, + dismiss: true + }) + } + + addNode() { + const protocolList = this.shadowRoot.getElementById('protocolList').value + const domainInput = this.shadowRoot.getElementById('domainInput').value + const portInput = this.shadowRoot.getElementById('portInput').value + + if (protocolList.length >= 4 && domainInput.length >= 3 && portInput.length >= 4) { + const nodeObject = { + protocol: protocolList, + domain: domainInput, + port: portInput + } + + store.dispatch(doAddNode(nodeObject)) + + snackbar.add({ + labelText: 'Successfully Added a Custom Node', + dismiss: true + }) + + this.shadowRoot.getElementById('protocolList').value = '' + this.shadowRoot.getElementById('domainInput').value = '' + this.shadowRoot.getElementById('portInput').value = '' + + this.shadowRoot.querySelector('#addNodeDialog').close() + } + } +} + +window.customElements.define('settings-page', SettingsPage) + +const settings = document.createElement('settings-page') +settingsDialog = document.body.appendChild(settings) + +export default settingsDialog diff --git a/qortal-ui-core/src/functional-components/snackbar.js b/qortal-ui-core/src/functional-components/snackbar.js new file mode 100644 index 00000000..968d000f --- /dev/null +++ b/qortal-ui-core/src/functional-components/snackbar.js @@ -0,0 +1,90 @@ +import { LitElement, html, css } from 'lit-element' +import '@material/mwc-snackbar' + +let queueElement + +class SnackQueue extends LitElement { + static get properties() { + return { + busy: { + type: Boolean, + attribute: 'busy', + reflectToAttribute: true + }, + currentSnack: { + type: Object, + attribute: 'current-snack', + reflectToAttribute: true + }, + _queue: { + type: Array + }, + _labelText: { type: String }, + _stacked: { type: Boolean }, + _leading: { type: Boolean }, + _closeOnEscape: { type: Boolean }, + _timeoutMs: { type: Number }, + action: {}, + _dismiss: {}, + _dismissIcon: { type: String } + } + } + + static get styles() { + return css`` + } + + constructor() { + super() + this._queue = [] + this.busy = false + this._timeoutMs = 5000 + } + + render() { + return html` + + ${this._action} + ${this._dismiss ? html` + + ` : ''} + + ` + } + + firstUpdated() { + this._snackbar = this.shadowRoot.getElementById('snack') + } + + _shift() { + if (this.busy || this._queue.length === 0) return + const item = this._queue.shift() + this._labelText = item.labelText || '' + this._action = item.action || '' + this._dismiss = item.dismiss || false + this._dismissIcon = item.dismissIcon || 'close' + this._leading = !!item.leading + this._closeOnEscape = (item.closeOnEscape && item.closeOnEscape !== false) // JSON.parse maybe needs to be compared to 'false'...in which case no need for complex expression + this._timeoutMs = (item.timeoutMs >= 4000 && item.timeoutMs <= 10000) ? item.timeoutMs : 5000 + this._snackbar.show() + } + + add(item) { + this._queue.push(item) + this._shift() + } +} + +window.customElements.define('snack-queue', SnackQueue) + +const queueNode = document.createElement('snack-queue') +queueNode.id = 'queue-node' +queueNode.loadingMessage = '' +queueElement = document.body.appendChild(queueNode) +setTimeout(() => { + queueElement = document.getElementById('queue-node') + const mainApp = document.getElementById('main-app') + const shadow = mainApp.shadowRoot + queueElement = shadow.appendChild(queueElement) +}, 500) +export default queueElement diff --git a/qortal-ui-core/src/initStore.js b/qortal-ui-core/src/initStore.js new file mode 100644 index 00000000..c924af57 --- /dev/null +++ b/qortal-ui-core/src/initStore.js @@ -0,0 +1,42 @@ +import { store } from './store.js' +import { doLoadConfigFromAPI } from './redux/config/config-actions.js' +import { doLoadNodeConfig, doInitWorkers } from './redux/app/app-actions.js' +import { doLoadNotificationConfig } from './redux/user/user-actions.js' + + +import './persistState.js' + +import { initApi } from 'qortal-ui-crypto' + +initApi(store) + +const workerInitChecker = () => { + const state = store.getState() + + if (store.getState().app.nodeConfig.knownNodes.length === 0) { + store.dispatch(doLoadNodeConfig()) + } + + if (state.config.loaded) { + store.dispatch(doLoadNodeConfig()) + + if (state.app.workers.ready) { + + workerInitSubscription() + } else { + + if (!state.app.workers.loading) store.dispatch(doInitWorkers(state.config.crypto.kdfThreads, state.config.user.constants.workerURL)) + } + } +} +workerInitChecker() +const workerInitSubscription = store.subscribe(workerInitChecker) + +if (!store.getState().config.loaded) { + store.dispatch(doLoadConfigFromAPI()) + store.dispatch(doLoadNodeConfig()) +} + +if (!store.getState().user.loaded) { + store.dispatch(doLoadNotificationConfig()) +} diff --git a/qortal-ui-core/src/localStorageHelpers.js b/qortal-ui-core/src/localStorageHelpers.js new file mode 100644 index 00000000..b8eaab2b --- /dev/null +++ b/qortal-ui-core/src/localStorageHelpers.js @@ -0,0 +1,25 @@ +export const loadStateFromLocalStorage = (key) => { + try { + const config = localStorage.getItem(key) + if (config === null) return void 0 + return JSON.parse(config) + } catch (e) { + // Could add error handling in case there's a weird one...don't want to overwrite config if it's malfunctioned + return void 0 + } +} + +// const loadConfigFromAPI = () => { +// return fetch(configURL).then(res => res.json()) +// } + +// export const loadConfig = async (key) => loadConfigFromLocalStorage() || loadConfigFromAPI() + +export const saveStateToLocalStorage = (key, state) => { + try { + const stateJSON = JSON.stringify(state) + localStorage.setItem(key, stateJSON) + } catch (e) { + console.error(e, 'e') + } +} diff --git a/qortal-ui-core/src/main.js b/qortal-ui-core/src/main.js new file mode 100644 index 00000000..039350b6 --- /dev/null +++ b/qortal-ui-core/src/main.js @@ -0,0 +1,3 @@ + +import './initStore.js' +import './components/main-app.js' diff --git a/qortal-ui-core/src/notifications/config.js b/qortal-ui-core/src/notifications/config.js new file mode 100644 index 00000000..200a4cdf --- /dev/null +++ b/qortal-ui-core/src/notifications/config.js @@ -0,0 +1,12 @@ +const config = { + default: { + title: 'Qortal', + body: 'Qortal Notifications', + icon: '/img/favicon/favicon-96x96.png' + }, + newMessageAudio: '/sound/newmessage.ogg', + messageAlert: '/sound/messageAlert.ogg', + blockAlert: '/sound/blockAlert.ogg' +} + +export default config diff --git a/qortal-ui-core/src/notifications/controller.js b/qortal-ui-core/src/notifications/controller.js new file mode 100644 index 00000000..3f6aa7af --- /dev/null +++ b/qortal-ui-core/src/notifications/controller.js @@ -0,0 +1,78 @@ +import config from './config' +import { dispatcher } from './dispatcher' +import snackbar from '../functional-components/snackbar.js' +import { NEW_MESSAGE } from './types' + +let initial = 0 +let _state + +const notificationCheck = function () { + if (window.Notification && Notification.permission === 'granted') { + // ... + return true + } else if (window.Notification && Notification.permission !== 'denied') { + Notification.requestPermission().then(permission => { + if (permission === 'granted') { + dispatcher(_state) + _state = '' + return true + } else { + initial = initial + 1 + snackbar.add({ + labelText: 'Notification is disabled, Enable it to recieve notifications.', + dismiss: true + }) + } + }) + } else { + if ([1, 3, 5, 7, 9, 11, 13, 15].includes(initial)) { + snackbar.add({ + labelText: 'Notification is disabled in this browser, Enable it to recieve notifications.', + dismiss: true + }) + } + + initial = initial + 1 + } +} + +/** + * @param req + * @property notificationState = { type: NEW_MESSAGE, data } + * @property data = { title: 'Qortal Chat', sound: config.messageAlert, options: { body: 'New Message', icon: config.default.icon, badge: config.default.icon }, req } +*/ + +export const doNewMessage = function (req) { + const newMessage = () => { + let data + + if (req.groupId) { + const title = `${req.groupName}` + const body = `New Message from ${req.senderName === undefined ? req.sender : req.senderName}` + data = { title, sound: config.messageAlert, options: { body, icon: config.default.icon, badge: config.default.icon }, req } + } else { + const title = `${req.senderName === undefined ? req.sender : req.senderName}` + const body = 'New Message' + data = { title, sound: config.messageAlert, options: { body, icon: config.default.icon, badge: config.default.icon }, req } + } + + const notificationState = { type: NEW_MESSAGE, data: data } + + const canI = notificationCheck() + + if (canI === true) { + dispatcher(notificationState) + } else { + _state = notificationState + } + } + + const page = window.top.location.href + if (!document.hasFocus()) { + newMessage() + } else { + if (page.includes(req.url) === false) { + newMessage() + } + } +} diff --git a/qortal-ui-core/src/notifications/dispatcher.js b/qortal-ui-core/src/notifications/dispatcher.js new file mode 100644 index 00000000..21344a6c --- /dev/null +++ b/qortal-ui-core/src/notifications/dispatcher.js @@ -0,0 +1,10 @@ +import { NEW_MESSAGE } from './types' +import { newMessage } from './notification-actions' + +export const dispatcher = function (notificationState) { + switch (notificationState.type) { + case NEW_MESSAGE: + return newMessage(notificationState.data) + default: + } +} diff --git a/qortal-ui-core/src/notifications/notification-actions/index.js b/qortal-ui-core/src/notifications/notification-actions/index.js new file mode 100644 index 00000000..37eaaba6 --- /dev/null +++ b/qortal-ui-core/src/notifications/notification-actions/index.js @@ -0,0 +1 @@ +export { newMessage } from './new-message' diff --git a/qortal-ui-core/src/notifications/notification-actions/new-message.js b/qortal-ui-core/src/notifications/notification-actions/new-message.js new file mode 100644 index 00000000..3edfc88f --- /dev/null +++ b/qortal-ui-core/src/notifications/notification-actions/new-message.js @@ -0,0 +1,40 @@ +import { store } from '../../store.js' +import { doPageUrl } from '../../redux/app/app-actions.js' + +export const newMessage = (data) => { + + const alert = playSound(data.sound) + + // Should I show notification ? + if (store.getState().user.notifications.q_chat.showNotification) { + + // Yes, I can but should I play sound ? + if (store.getState().user.notifications.q_chat.playSound) { + + const notify = new Notification(data.title, data.options) + + notify.onshow = (e) => { + alert.play() + } + + notify.onclick = (e) => { + const pageUrl = `/app/q-chat/${data.req.url}` + store.dispatch(doPageUrl(pageUrl)) + } + } else { + + const notify = new Notification(data.title, data.options) + + notify.onclick = (e) => { + const pageUrl = `/app/q-chat/${data.req.url}` + store.dispatch(doPageUrl(pageUrl)) + } + } + } + +} + +const playSound = (soundUrl) => { + + return new Audio(soundUrl) +} diff --git a/qortal-ui-core/src/notifications/types.js b/qortal-ui-core/src/notifications/types.js new file mode 100644 index 00000000..b8366a38 --- /dev/null +++ b/qortal-ui-core/src/notifications/types.js @@ -0,0 +1 @@ +export const NEW_MESSAGE = 'NEW_MESSAGE' diff --git a/qortal-ui-core/src/persistState.js b/qortal-ui-core/src/persistState.js new file mode 100644 index 00000000..d0195d12 --- /dev/null +++ b/qortal-ui-core/src/persistState.js @@ -0,0 +1,23 @@ +import { store } from './store.js' +import { saveStateToLocalStorage } from './localStorageHelpers.js' + +const keys = [ + 'config', + 'user' +] + +const oldReducers = {} + +const oldState = store.getState() +for (const key of keys) { + oldReducers[key] = oldState[key] +} + +store.subscribe(() => { + const newState = store.getState() + keys.forEach(key => { + if (newState[key] !== oldState[key]) { + saveStateToLocalStorage(key, store.getState()[key]) + } + }) +}) diff --git a/qortal-ui-core/src/plugins/addPluginRoutes.js b/qortal-ui-core/src/plugins/addPluginRoutes.js new file mode 100644 index 00000000..59796749 --- /dev/null +++ b/qortal-ui-core/src/plugins/addPluginRoutes.js @@ -0,0 +1,7 @@ +import { routes } from './routes.js' + +export const addPluginRoutes = epmlInstance => { + Object.entries(routes).forEach(([route, handler]) => { + epmlInstance.route(route, handler) + }) +} diff --git a/qortal-ui-core/src/plugins/load-plugins.js b/qortal-ui-core/src/plugins/load-plugins.js new file mode 100644 index 00000000..693e255e --- /dev/null +++ b/qortal-ui-core/src/plugins/load-plugins.js @@ -0,0 +1,46 @@ +import { store } from '../store.js' +import { Epml } from '../epml.js' +import { addPluginRoutes } from './addPluginRoutes' +import { doAddPlugin } from '../redux/app/app-actions.js' + +let retryLoadPluginsInterval = 0 +export const loadPlugins = () => fetch('/getPlugins') + .then(response => response.json()) + .then(response => { + const plugins = response.plugins + const config = store.getState().config + pluginLoader(plugins, config) + }) + .catch(err => { + retryLoadPluginsInterval += 1000 + console.error(err) + console.error(`Could not load plugins. Retrying in ${retryLoadPluginsInterval / 1000} second(s)`) + setTimeout(loadPlugins, retryLoadPluginsInterval) + }) + +export const pluginLoader = (plugins, config) => { + const pluginContentWindows = [] + plugins.forEach(plugin => { + const frame = document.createElement('iframe') + frame.className += 'pluginJSFrame' + frame.sandbox = 'allow-scripts allow-same-origin' + + frame.src = window.location.origin + '/qortal-components/plugin-mainjs-loader.html#' + plugin + '/main.js' + + const insertedFrame = window.document.body.appendChild(frame) + + pluginContentWindows.push(insertedFrame.contentWindow) + + const epmlInstance = new Epml({ + type: 'WINDOW', + source: insertedFrame.contentWindow + }) + + addPluginRoutes(epmlInstance) + epmlInstance.imReady() + + Epml.registerProxyInstance(`${plugin}-plugin`, epmlInstance) + + store.dispatch(doAddPlugin(epmlInstance)) + }) +} diff --git a/qortal-ui-core/src/plugins/plugin-mainjs-loader.html b/qortal-ui-core/src/plugins/plugin-mainjs-loader.html new file mode 100644 index 00000000..c424fdd5 --- /dev/null +++ b/qortal-ui-core/src/plugins/plugin-mainjs-loader.html @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/qortal-ui-core/src/plugins/plugin-mainjs-loader.js b/qortal-ui-core/src/plugins/plugin-mainjs-loader.js new file mode 100644 index 00000000..c185a97b --- /dev/null +++ b/qortal-ui-core/src/plugins/plugin-mainjs-loader.js @@ -0,0 +1,12 @@ +'use strict' +import { Epml, EpmlStream } from '../epml.js' + +window.Epml = Epml +window.EpmlStream = EpmlStream + +const pluginScript = document.createElement('script') +pluginScript.async = false +pluginScript.type = 'module' +const hash = window.location.hash +pluginScript.src = '/plugin/' + hash.slice(1) +document.body.appendChild(pluginScript) diff --git a/qortal-ui-core/src/plugins/routes.js b/qortal-ui-core/src/plugins/routes.js new file mode 100644 index 00000000..e7ba0eb7 --- /dev/null +++ b/qortal-ui-core/src/plugins/routes.js @@ -0,0 +1,287 @@ +import { store } from '../store.js' +import { doAddPluginUrl, doUpdateBlockInfo, doUpdateNodeStatus, doUpdateNodeInfo, doSetNode, doPageUrl, doSetChatHeads, doUpdateAccountInfo } from '../redux/app/app-actions.js' +import * as api from 'qortal-ui-crypto' +import { requestTransactionDialog } from '../functional-components/confirm-transaction-dialog.js' +import { doNewMessage } from '../notifications/controller.js' +import snackbar from '../functional-components/snackbar.js' +import { loadStateFromLocalStorage, saveStateToLocalStorage } from '../localStorageHelpers.js' +import copyTextMenu from '../functional-components/copy-text-menu.js' +import framePasteMenu from '../functional-components/frame-paste-menu.js' + +const createTransaction = api.createTransaction +const processTransaction = api.processTransaction +const signChatTransaction = api.signChatTransaction +const tradeBotCreateRequest = api.tradeBotCreateRequest +const tradeBotRespondRequest = api.tradeBotRespondRequest +const signTradeBotTxn = api.signTradeBotTxn +const deleteTradeOffer = api.deleteTradeOffer +const cancelAllOffers = api.cancelAllOffers +const sendBtc = api.sendBtc +const sendLtc = api.sendLtc +const sendDoge = api.sendDoge + +export const routes = { + hello: async (req) => { + return 'Hello from awesomeness' + }, + + registerUrl: async (req) => { + store.dispatch(doAddPluginUrl(req.data)) + }, + + setAccountInfo: async (req) => { + store.dispatch(doUpdateAccountInfo(req.data)) + }, + + getAccountInfo: async (req) => { + return store.getState().app.accountInfo + }, + + setChatHeads: async (req) => { + return store.dispatch(doSetChatHeads(req.data)) + }, + + getChatHeads: async (req) => { + return store.getState().app.chatHeads + }, + + updateBlockInfo: async (req) => { + store.dispatch(doUpdateBlockInfo(req.data)) + }, + + updateNodeStatus: async (req) => { + store.dispatch(doUpdateNodeStatus(req.data)) + }, + + updateNodeInfo: async (req) => { + store.dispatch(doUpdateNodeInfo(req.data)) + }, + + setNode: async (req) => { + store.dispatch(doSetNode(req.data)) + }, + + getNodeConfig: async (req) => { + return store.getState().app.nodeConfig + }, + + setPageUrl: async (req) => { + return store.dispatch(doPageUrl(req.data)) + }, + + getLocalStorage: async (req) => { + return loadStateFromLocalStorage(req.data) + }, + + setLocalStorage: async (req) => { + return saveStateToLocalStorage(req.data.key, req.data.dataObj) + }, + + openCopyTextMenu: async (req) => { + const textMenuObject = { + selectedText: req.data.selectedText, + eventObject: req.data.eventObject, + isFrame: req.data.isFrame, + } + copyTextMenu.open(textMenuObject) + }, + + closeCopyTextMenu: async (req) => { + copyTextMenu.close() + }, + + openFramePasteMenu: async (req) => { + framePasteMenu.open(req.data) + }, + + closeFramePasteMenu: async (req) => { + framePasteMenu.close() + }, + + apiCall: async (req) => { + const url = req.data.url + delete req.data.url + return api.request(url, req.data) + }, + + addresses: async (req) => { + return store.getState().app.wallet.addresses.map((address) => { + return { + address: address.address, + color: address.color, + nonce: address.nonce, + textColor: address.textColor, + base58PublicKey: address.base58PublicKey, + } + }) + }, + + transaction: async (req) => { + let response + try { + const tx = createTransaction(req.data.type, store.getState().app.wallet._addresses[req.data.nonce].keyPair, req.data.params) + await requestTransactionDialog.requestTransaction(tx) + const res = await processTransaction(tx.signedBytes) + response = { + success: true, + data: res, + } + } catch (e) { + console.error(e) + console.error(e.message) + response = { + success: false, + message: e.message, + } + } + return response + }, + + username: async (req) => { + const state = store.getState() + const username = state.user.storedWallets[state.app.wallet.addresses[0].address].name + + return username + }, + + chat: async (req) => { + let response + try { + const tx = createTransaction(req.data.type, store.getState().app.wallet._addresses[req.data.nonce].keyPair, req.data.params) + + response = tx.chatBytes + } catch (e) { + console.error(e) + console.error(e.message) + response = false + } + return response + }, + + sign_chat: async (req) => { + let response + try { + const signedChatBytes = await signChatTransaction(req.data.chatBytesArray, req.data.chatNonce, store.getState().app.wallet._addresses[req.data.nonce].keyPair) + + const res = await processTransaction(signedChatBytes) + response = res + } catch (e) { + console.error(e) + console.error(e.message) + response = false + } + return response + }, + + showNotification: async (req) => { + doNewMessage(req.data) + }, + + showSnackBar: async (req) => { + snackbar.add({ + labelText: req.data, + dismiss: true, + }) + }, + + tradeBotCreateRequest: async (req) => { + let response + try { + const unsignedTxn = await tradeBotCreateRequest(req.data) + + const signedTxnBytes = await signTradeBotTxn(unsignedTxn, store.getState().app.selectedAddress.keyPair) + + const res = await processTransaction(signedTxnBytes) + response = res + } catch (e) { + console.error(e) + console.error(e.message) + response = e.message + } + return response + }, + + tradeBotRespondRequest: async (req) => { + let response + try { + const res = await tradeBotRespondRequest(req.data) + + response = res + } catch (e) { + console.error(e) + console.error(e.message) + response = e.message + } + return response + }, + + deleteTradeOffer: async (req) => { + let response + try { + const unsignedTxn = await deleteTradeOffer(req.data) + + const signedTxnBytes = await signTradeBotTxn(unsignedTxn, store.getState().app.selectedAddress.keyPair) + + const res = await processTransaction(signedTxnBytes) + + response = res + } catch (e) { + console.error(e) + console.error(e.message) + response = e.message + } + return response + }, + + cancelAllOffers: async (req) => { + let response + try { + const res = await cancelAllOffers(store.getState().app.selectedAddress) + response = res + } catch (e) { + console.error(e) + console.error(e.message) + response = e.message + } + return response + }, + + sendBtc: async (req) => { + let response + try { + const res = await sendBtc(req.data) + response = res + } catch (e) { + console.error(e) + console.error(e.message) + response = e.message + } + return response + }, + + sendLtc: async (req) => { + let response + try { + const res = await sendLtc(req.data) + response = res + } catch (e) { + console.error(e) + console.error(e.message) + response = e.message + } + return response + }, + + sendDoge: async (req) => { + let response + try { + const res = await sendDoge(req.data) + response = res + } catch (e) { + console.error(e) + console.error(e.message) + response = e.message + } + return response + }, +} diff --git a/qortal-ui-core/src/plugins/streams.js b/qortal-ui-core/src/plugins/streams.js new file mode 100644 index 00000000..18bf5f53 --- /dev/null +++ b/qortal-ui-core/src/plugins/streams.js @@ -0,0 +1,66 @@ +import { store } from '../store.js' +import { EpmlStream } from 'epml' + +const LOGIN_STREAM_NAME = 'logged_in' +const CONFIG_STREAM_NAME = 'config' +const SELECTED_ADDRESS_STREAM_NAME = 'selected_address' +// const APP_INFO_STATE = 'app_info_state' +const CHAT_HEADS_STREAM_NAME = 'chat_heads' +const NODE_CONFIG_STREAM_NAME = 'node_config' +const COPY_MENU_SWITCH = 'copy_menu_switch' +const FRAME_PASTE_MENU_SWITCH = 'frame_paste_menu_switch' + +export const loggedInStream = new EpmlStream(LOGIN_STREAM_NAME, () => store.getState().app.loggedIn) +export const configStream = new EpmlStream(CONFIG_STREAM_NAME, () => store.getState().config) +export const selectedAddressStream = new EpmlStream(SELECTED_ADDRESS_STREAM_NAME, () => store.getState().app.selectedAddress) +// export const appInfoStateStream = new EpmlStream(APP_INFO_STATE, () => store.getState().app.appInfo) +export const chatHeadsStateStream = new EpmlStream(CHAT_HEADS_STREAM_NAME, () => store.getState().app.chatHeads) +export const nodeConfigStream = new EpmlStream(NODE_CONFIG_STREAM_NAME, () => store.getState().app.nodeConfig) +export const copyMenuSwitchStream = new EpmlStream(COPY_MENU_SWITCH, () => store.getState().app.copyMenuSwitch) +export const framePasteMenuSwitchStream = new EpmlStream(FRAME_PASTE_MENU_SWITCH, () => store.getState().app.framePasteMenuSwitch) + + +let oldState = { + app: {} +} + +store.subscribe(() => { + const state = store.getState() + + if (oldState.app.loggedIn !== state.app.loggedIn) { + loggedInStream.emit(state.app.loggedIn) + } + // This one may be a little on the heavy side...AHHH, NEED TO MOVE STORAGE OF ENCRYPTED SEED. DONE <3 + if (oldState.config !== state.config) { + configStream.emit(state.config) + } + + if (oldState.app.nodeConfig !== state.app.nodeConfig) { + nodeConfigStream.emit(state.app.nodeConfig) + } + + if (oldState.app.copyMenuSwitch !== state.app.copyMenuSwitch) { + copyMenuSwitchStream.emit(state.app.copyMenuSwitch) + } + + if (oldState.app.framePasteMenuSwitch !== state.app.framePasteMenuSwitch) { + framePasteMenuSwitchStream.emit(state.app.framePasteMenuSwitch) + } + + if (oldState.app.selectedAddress !== state.app.selectedAddress) { + selectedAddressStream.emit({ + address: state.app.selectedAddress.address, + color: state.app.selectedAddress.color, + nonce: state.app.selectedAddress.nonce, + textColor: state.app.selectedAddress.textColor + }) + } + if (oldState.app.chatHeads !== state.app.chatHeads) { + chatHeadsStateStream.emit(state.app.chatHeads) + } + + // if (oldState.app.appInfo !== state.app.appInfo) { + // appInfoStateStream.emit(state.app.appInfo) + // } + oldState = state +}) diff --git a/qortal-ui-core/src/redux/app/actions/app-core.js b/qortal-ui-core/src/redux/app/actions/app-core.js new file mode 100644 index 00000000..e96b11b4 --- /dev/null +++ b/qortal-ui-core/src/redux/app/actions/app-core.js @@ -0,0 +1,107 @@ +// Core App Actions here... +import { UPDATE_BLOCK_INFO, UPDATE_NODE_STATUS, UPDATE_NODE_INFO, CHAT_HEADS, ACCOUNT_INFO, COPY_MENU_SWITCH, PASTE_MENU_SWITCH, FRAME_PASTE_MENU_SWITCH } from '../app-action-types.js' + +export const doUpdateBlockInfo = (blockObj) => { + return (dispatch, getState) => { + dispatch(updateBlock(blockObj)) + } +} + +const updateBlock = (payload) => { + return { + type: UPDATE_BLOCK_INFO, + payload + } +} + +export const doUpdateNodeStatus = (nodeStatusObj) => { + return (dispatch, getState) => { + dispatch(updateNodeStatus(nodeStatusObj)) + } +} + +const updateNodeStatus = (payload) => { + return { + type: UPDATE_NODE_STATUS, + payload + } +} + +export const doUpdateNodeInfo = (nodeInfoObj) => { + return (dispatch, getState) => { + dispatch(updateNodeInfo(nodeInfoObj)) + } +} + +const updateNodeInfo = (payload) => { + return { + type: UPDATE_NODE_INFO, + payload + } +} + +export const doSetChatHeads = (chatHeadsObj) => { + return (dispatch, getState) => { + dispatch(setChatHeads(chatHeadsObj)) + } +} + +const setChatHeads = (payload) => { + return { + type: CHAT_HEADS, + payload + } +} + +export const doUpdateAccountInfo = (appInfoObj) => { + return (dispatch, getState) => { + dispatch(updateAccountInfo(appInfoObj)) + } +} + +const updateAccountInfo = (payload) => { + return { + type: ACCOUNT_INFO, + payload + } +} + +export const doCopyMenuSwitch = (value) => { + return (dispatch, getState) => { + dispatch(copyMenuSwitch(value)) + } +} + +const copyMenuSwitch = (payload) => { + return { + type: COPY_MENU_SWITCH, + payload + } +} + +export const doPasteMenuSwitch = (value) => { + return (dispatch, getState) => { + dispatch(pasteMenuSwitch(value)) + } +} + +const pasteMenuSwitch = (payload) => { + return { + type: PASTE_MENU_SWITCH, + payload + } +} + + +export const doFramePasteMenuSwitch = (value) => { + return (dispatch, getState) => { + dispatch(framePasteMenuSwitch(value)) + } +} + +const framePasteMenuSwitch = (payload) => { + return { + type: FRAME_PASTE_MENU_SWITCH, + payload + } +} diff --git a/qortal-ui-core/src/redux/app/actions/init-worker.js b/qortal-ui-core/src/redux/app/actions/init-worker.js new file mode 100644 index 00000000..ce77b25e --- /dev/null +++ b/qortal-ui-core/src/redux/app/actions/init-worker.js @@ -0,0 +1,30 @@ +import { Epml } from '../../../epml.js' +import { EpmlWorkerPlugin } from 'epml' + +import { INIT_WORKERS } from '../app-action-types.js' +Epml.registerPlugin(EpmlWorkerPlugin) + +export const doInitWorkers = (numberOfWorkers, workerURL) => { + const workers = [] + return (dispatch, getState) => { + dispatch(initWorkers()) + try { + for (let i = 0; i < numberOfWorkers; i++) { + workers.push(new Epml({ type: 'WORKER', source: new Worker(workerURL) })) + } + Promise.all(workers.map(workerEpml => workerEpml.ready())) + .then(() => { + dispatch(initWorkers('success', workers)) + }) + } catch (e) { + dispatch(initWorkers('error', e)) + } + } +} +const initWorkers = (status, payload) => { + return { + type: INIT_WORKERS, + status, + payload + } +} diff --git a/qortal-ui-core/src/redux/app/actions/login-view.js b/qortal-ui-core/src/redux/app/actions/login-view.js new file mode 100644 index 00000000..687db794 --- /dev/null +++ b/qortal-ui-core/src/redux/app/actions/login-view.js @@ -0,0 +1,17 @@ +// Maybe not use redux? Login pages aren't needed all through the app? + +// import { NAVIGATE_LOGIN_VIEW } from '../app-action-types.js' + +// export const doAddPlugin = (epmlInstance) => { +// // Add the appropriate routes here +// return (dispatch, getState) => { +// dispatch(addPlugin(epmlInstance)) +// } +// } + +// const addPlugin = (payload) => { +// return { +// type: ADD_PLUGIN, +// payload +// } +// } diff --git a/qortal-ui-core/src/redux/app/actions/login.js b/qortal-ui-core/src/redux/app/actions/login.js new file mode 100644 index 00000000..02ce7e52 --- /dev/null +++ b/qortal-ui-core/src/redux/app/actions/login.js @@ -0,0 +1,43 @@ +import { LOG_IN, LOG_OUT, SELECT_ADDRESS } from '../app-action-types.js' + +export const doSelectAddress = address => { + return (dispatch, getState) => { + dispatch(selectAddress(address)) + } +} + +const selectAddress = address => { + return { + type: SELECT_ADDRESS, + address + } +} + +export const doLogin = wallet => { + return (dispatch, getState) => { + dispatch(login('success', { + wallet + })) + } +} + +const login = (status, payload) => { + return { + type: LOG_IN, + status, + payload + } +} + +export const doLogout = () => { + // THOUGHTS: Maybe add some checks for ongoing stuff... + return (dispatch, getState) => { + dispatch(logout()) + } +} + +const logout = () => { + return { + type: LOG_OUT + } +} diff --git a/qortal-ui-core/src/redux/app/actions/node-config.js b/qortal-ui-core/src/redux/app/actions/node-config.js new file mode 100644 index 00000000..3550c3ac --- /dev/null +++ b/qortal-ui-core/src/redux/app/actions/node-config.js @@ -0,0 +1,61 @@ +// Node Config Actions here... +import { LOAD_NODE_CONFIG, SET_NODE, ADD_NODE } from '../app-action-types.js' + +const nodeConfigUrl = '/getConfig' + +export const doLoadNodeConfig = () => { + + return (dispatch, getState) => { + fetch(nodeConfigUrl) + .then(res => { + return res.json() + }) + .then(data => { + const nodeConfig = { + node: 0, + knownNodes: [{}], + version: '' + } + nodeConfig.node = data.config.user.node + nodeConfig.knownNodes = data.config.user.knownNodes + nodeConfig.version = data.config.user.version + return dispatch(loadNodeConfig(nodeConfig)) + }) + .catch(err => { + console.error(err) + }) + } +} + +const loadNodeConfig = (payload) => { + return { + type: LOAD_NODE_CONFIG, + payload + } +} + +export const doSetNode = (nodeIndex) => { + return (dispatch, getState) => { + return dispatch(setNode(nodeIndex)) + } +} + +const setNode = (payload) => { + return { + type: SET_NODE, + payload + } +} + +export const doAddNode = (nodeObject) => { + return (dispatch, getState) => { + return dispatch(addNode(nodeObject)) + } +} + +const addNode = (payload) => { + return { + type: ADD_NODE, + payload + } +} diff --git a/qortal-ui-core/src/redux/app/actions/plugins.js b/qortal-ui-core/src/redux/app/actions/plugins.js new file mode 100644 index 00000000..84e4d820 --- /dev/null +++ b/qortal-ui-core/src/redux/app/actions/plugins.js @@ -0,0 +1,40 @@ +import { ADD_PLUGIN, ADD_PLUGIN_URL, PAGE_URL } from '../app-action-types.js' + +export const doAddPluginUrl = (pluginUrlsConf) => { + return (dispatch, getState) => { + dispatch(addPluginUrl(pluginUrlsConf)) + } +} + +const addPluginUrl = (payload) => { + return { + type: ADD_PLUGIN_URL, + payload + } +} + +export const doAddPlugin = (epmlInstance) => { + return (dispatch, getState) => { + dispatch(addPlugin(epmlInstance)) + } +} + +const addPlugin = (payload) => { + return { + type: ADD_PLUGIN, + payload + } +} + +export const doPageUrl = (pageUrl) => { + return (dispatch, getState) => { + dispatch(myPageUrl(pageUrl)) + } +} + +const myPageUrl = (payload) => { + return { + type: PAGE_URL, + payload + } +} diff --git a/qortal-ui-core/src/redux/app/app-action-types.js b/qortal-ui-core/src/redux/app/app-action-types.js new file mode 100644 index 00000000..00f4c54d --- /dev/null +++ b/qortal-ui-core/src/redux/app/app-action-types.js @@ -0,0 +1,22 @@ +export const INIT_WORKERS = 'INIT_WORKERS' +export const LOG_IN = 'LOG_IN' +export const LOG_OUT = 'LOG_OUT' +export const ADD_PLUGIN_URL = 'ADD_PLUGIN_URL' +export const ADD_PLUGIN = 'ADD_PLUGIN' +export const NAVIGATE = 'NAVIGATE' +export const SELECT_ADDRESS = 'SELECT_ADDRESS' +export const NETWORK_CONNECTION_STATUS = 'NETWORK_CONNECTION_STATUS' +export const NAVIGATE_LOGIN_VIEW = 'NAVIGATE_LOGIN_VIEW' +export const UPDATE_BLOCK_INFO = 'UPDATE_BLOCK_INFO' +export const UPDATE_NODE_STATUS = 'UPDATE_NODE_STATUS' +export const UPDATE_NODE_INFO = 'UPDATE_NODE_INFO' +export const SET_NODE = 'SET_NODE' +export const ADD_NODE = 'ADD_NODE' +export const LOAD_NODE_CONFIG = 'LOAD_NODE_CONFIG' +export const PAGE_URL = 'PAGE_URL' +export const CHAT_HEADS = 'CHAT_HEADS' +export const ACCOUNT_INFO = 'ACCOUNT_INFO' +export const ADD_NEW_PLUGIN_URL = 'ADD_NEW_PLUGIN_URL' +export const COPY_MENU_SWITCH = 'COPY_MENU_SWITCH' +export const PASTE_MENU_SWITCH = 'PASTE_MENU_SWITCH' +export const FRAME_PASTE_MENU_SWITCH = 'FRAME_PASTE_MENU_SWITCH' diff --git a/qortal-ui-core/src/redux/app/app-actions.js b/qortal-ui-core/src/redux/app/app-actions.js new file mode 100644 index 00000000..51574a58 --- /dev/null +++ b/qortal-ui-core/src/redux/app/app-actions.js @@ -0,0 +1,29 @@ +import { NAVIGATE, NETWORK_CONNECTION_STATUS } from './app-action-types.js' + +export * from './actions/login.js' +export * from './actions/init-worker.js' +export * from './actions/plugins.js' +export * from './actions/app-core.js' +export * from './actions/node-config.js' + +export const doNavigate = loca => { + return (dispatch, getState) => { + dispatch(navigate(loca)) + } +} + +const navigate = loca => { + + return { + type: NAVIGATE, + url: loca.pathname + } +} + +export const updateNetworkConnectionStatus = status => { + + return { + type: NETWORK_CONNECTION_STATUS, + payload: status + } +} diff --git a/qortal-ui-core/src/redux/app/app-reducer.js b/qortal-ui-core/src/redux/app/app-reducer.js new file mode 100644 index 00000000..0fa9b67a --- /dev/null +++ b/qortal-ui-core/src/redux/app/app-reducer.js @@ -0,0 +1,152 @@ +// Loading state, login state, isNavDrawOpen state etc. None of this needs to be saved to localstorage. +import { LOG_IN, LOG_OUT, NETWORK_CONNECTION_STATUS, INIT_WORKERS, ADD_PLUGIN_URL, ADD_PLUGIN, ADD_NEW_PLUGIN_URL, NAVIGATE, SELECT_ADDRESS, ACCOUNT_INFO, CHAT_HEADS, UPDATE_BLOCK_INFO, UPDATE_NODE_STATUS, UPDATE_NODE_INFO, LOAD_NODE_CONFIG, SET_NODE, ADD_NODE, PAGE_URL, COPY_MENU_SWITCH, PASTE_MENU_SWITCH, FRAME_PASTE_MENU_SWITCH } from './app-action-types.js' +import { initWorkersReducer } from './reducers/init-workers.js' +import { loginReducer } from './reducers/login-reducer.js' +import { setNode, addNode } from './reducers/manage-node.js' + +const INITIAL_STATE = { + loggedIn: false, + drawerOpen: false, + workers: { + workers: [], + ready: false, + loading: false + }, + wallet: { + addresses: [ + { + address: '' + } + ] + }, + nodeConfig: { + node: 0, + knownNodes: [{}], + version: '' + }, + plugins: [], + registeredUrls: [], + accountInfo: { + names: [], + addressInfo: {} + }, + url: '', + selectedAddress: {}, + chatHeads: {}, + blockInfo: {}, + nodeInfo: {}, + nodeStatus: {}, + pageUrl: '', + copyMenuSwitch: false, + pasteMenuSwitch: false, + framePasteMenuSwitch: { + isOpen: false, + elementId: '' + } +} + +export default (state = INITIAL_STATE, action) => { + switch (action.type) { + case INIT_WORKERS: + return initWorkersReducer(state, action) + case LOG_IN: + return loginReducer(state, action) + case LOG_OUT: + return { + ...state, + pin: '', + loggedIn: false, + loggingIn: false, + wallet: INITIAL_STATE.wallet + } + case ADD_PLUGIN: + return { + ...state, + plugins: [ + ...state.plugins, + action.payload + ] + } + case ADD_PLUGIN_URL: + return { + ...state, + registeredUrls: action.payload + } + case ADD_NEW_PLUGIN_URL: // TODO: Will be used in to add new plugins in future... + return { + ...state, + registeredUrls: state.registeredUrls.concat(action.payload) + } + case CHAT_HEADS: + return { + ...state, + chatHeads: action.payload + } + case UPDATE_BLOCK_INFO: + return { + ...state, + blockInfo: action.payload + } + case UPDATE_NODE_STATUS: + return { + ...state, + nodeStatus: action.payload + } + case UPDATE_NODE_INFO: + return { + ...state, + nodeInfo: action.payload + } + case ACCOUNT_INFO: + return { + ...state, + accountInfo: action.payload + } + case LOAD_NODE_CONFIG: + return { + ...state, + nodeConfig: action.payload + } + case SET_NODE: + return setNode(state, action) + case ADD_NODE: + return addNode(state, action) + case PAGE_URL: + return { + ...state, + pageUrl: action.payload + } + case NAVIGATE: + return { + ...state, + url: action.url + } + case SELECT_ADDRESS: + return { + ...state, + selectedAddress: action.address + } + case NETWORK_CONNECTION_STATUS: + return { + ...state, + networkIsConnected: action.payload + } + case COPY_MENU_SWITCH: + return { + ...state, + copyMenuSwitch: action.payload + } + case PASTE_MENU_SWITCH: + return { + ...state, + pasteMenuSwitch: action.payload + } + case FRAME_PASTE_MENU_SWITCH: + return { + ...state, + framePasteMenuSwitch: action.payload + } + default: + return state + } +} diff --git a/qortal-ui-core/src/redux/app/reducers/init-workers.js b/qortal-ui-core/src/redux/app/reducers/init-workers.js new file mode 100644 index 00000000..993cd261 --- /dev/null +++ b/qortal-ui-core/src/redux/app/reducers/init-workers.js @@ -0,0 +1,32 @@ +export const initWorkersReducer = (state, action) => { + switch (action.status) { + case 'success': + return { + ...state, + workers: { + workers: action.payload, + ready: true, + loading: false + } + } + case 'error': + return { + ...state, + workers: { + ...state.workers, + ready: false, + loading: false, + lastError: action.payload + } + } + default: + return { + ...state, + workers: { + ...state.workers, + // ready: true, + loading: true + } + } + } +} diff --git a/qortal-ui-core/src/redux/app/reducers/login-reducer.js b/qortal-ui-core/src/redux/app/reducers/login-reducer.js new file mode 100644 index 00000000..2a50f20a --- /dev/null +++ b/qortal-ui-core/src/redux/app/reducers/login-reducer.js @@ -0,0 +1,22 @@ +export const loginReducer = (state, action) => { + switch (action.status) { + case 'success': + return { + ...state, + wallet: action.payload.wallet, + loggedIn: true, + loggingIn: false + } + case 'error': + return { + ...state, + loggedIn: false, + loggingIn: false + } + default: + return { + ...state, + loggingIn: true + } + } +} diff --git a/qortal-ui-core/src/redux/app/reducers/manage-node.js b/qortal-ui-core/src/redux/app/reducers/manage-node.js new file mode 100644 index 00000000..ad284452 --- /dev/null +++ b/qortal-ui-core/src/redux/app/reducers/manage-node.js @@ -0,0 +1,22 @@ +export const setNode = (state, action) => { + return { + ...state, + nodeConfig: { + ...state.nodeConfig, + node: action.payload + } + } +} + +export const addNode = (state, action) => { + return { + ...state, + nodeConfig: { + ...state.nodeConfig, + knownNodes: [ + ...state.nodeConfig.knownNodes, + action.payload + ] + } + } +} diff --git a/qortal-ui-core/src/redux/config/config-actions.js b/qortal-ui-core/src/redux/config/config-actions.js new file mode 100644 index 00000000..c8a0a2de --- /dev/null +++ b/qortal-ui-core/src/redux/config/config-actions.js @@ -0,0 +1,25 @@ +export const LOAD_CONFIG_FROM_API = 'LOAD_CONFIG_FROM_API' + +const configUrl = '/getConfig' + +export const doLoadConfigFromAPI = () => { + return (dispatch, getState) => { + if (getState().config.loaded) return dispatch(loadConfigFromAPI('success')) + dispatch(loadConfigFromAPI()) + fetch(configUrl) + .then(res => res.json()) + .then(data => dispatch(loadConfigFromAPI('success', data.config))) + .catch(err => { + console.error(err) + dispatch(loadConfigFromAPI('error', err)) + }) + } +} + +const loadConfigFromAPI = (status, payload) => { + return { + type: LOAD_CONFIG_FROM_API, + status, + payload + } +} diff --git a/qortal-ui-core/src/redux/config/config-reducer.js b/qortal-ui-core/src/redux/config/config-reducer.js new file mode 100644 index 00000000..9dc83059 --- /dev/null +++ b/qortal-ui-core/src/redux/config/config-reducer.js @@ -0,0 +1,36 @@ +// Must be saved to localstorage. Will storage things such as saved addresses and themes (day/night mode) etc. +// Initial state needs to be loaded from either the getConfig url or localstorage...NOT set via this +import { loadStateFromLocalStorage } from '../../localStorageHelpers' +import { LOAD_CONFIG_FROM_API } from './config-actions.js' +import { loadConfigFromAPI } from './reducers/load-config-from-api.js' + +const DEFAULT_INITIAL_STATE = { + styles: { + breakpoints: {}, + theme: { + color: 'green', + colors: {} + } + }, + coin: { + name: '' + }, + user: { + language: 'english', + theme: 'light', + server: {}, + node: 0, + knownNodes: [{}] + }, + savedWallets: {}, + loaded: false +} + +export default (state = loadStateFromLocalStorage('config') || DEFAULT_INITIAL_STATE, action) => { + switch (action.type) { + case LOAD_CONFIG_FROM_API: + return loadConfigFromAPI(state, action) + default: + return state + } +} diff --git a/qortal-ui-core/src/redux/config/reducers/load-config-from-api.js b/qortal-ui-core/src/redux/config/reducers/load-config-from-api.js new file mode 100644 index 00000000..10add38b --- /dev/null +++ b/qortal-ui-core/src/redux/config/reducers/load-config-from-api.js @@ -0,0 +1,22 @@ +export const loadConfigFromAPI = (state, action) => { + switch (action.status) { + case 'success': + return { + ...action.payload, + loaded: true, + loading: false + } + case 'error': + return { + ...state, + loaded: false, + loading: false, + loadingError: action.payload + } + default: + return { + ...state, + loading: true + } + } +} diff --git a/qortal-ui-core/src/redux/reducers.js b/qortal-ui-core/src/redux/reducers.js new file mode 100644 index 00000000..8fb963a0 --- /dev/null +++ b/qortal-ui-core/src/redux/reducers.js @@ -0,0 +1,11 @@ +import { combineReducers } from 'redux' + +import app from './app/app-reducer.js' +import config from './config/config-reducer.js' +import user from './user/user-reducer.js' + +export default combineReducers({ + user, + app, + config +}) diff --git a/qortal-ui-core/src/redux/user/actions/claim-airdrop.js b/qortal-ui-core/src/redux/user/actions/claim-airdrop.js new file mode 100644 index 00000000..24f25dda --- /dev/null +++ b/qortal-ui-core/src/redux/user/actions/claim-airdrop.js @@ -0,0 +1,14 @@ +import { CLAIM_AIRDROP } from '../user-action-types.js' + +export const doClaimAirdrop = (address) => { + return (dispatch, getState) => { + dispatch(claimAidrop()) + } +} + +const claimAidrop = (payload) => { + return { + type: CLAIM_AIRDROP, + payload + } +} diff --git a/qortal-ui-core/src/redux/user/actions/notification-config.js b/qortal-ui-core/src/redux/user/actions/notification-config.js new file mode 100644 index 00000000..646865f6 --- /dev/null +++ b/qortal-ui-core/src/redux/user/actions/notification-config.js @@ -0,0 +1,57 @@ + +import { LOAD_NOTIFICATION_CONFIG, SET_QCHAT_NOTIFICATION_CONFIG } from '../user-action-types.js' + +const configUrl = '/getConfig' + +export const doLoadNotificationConfig = () => { + + return (dispatch, getState) => { + + fetch(configUrl) + .then(res => { + return res.json() + }) + .then(data => { + + const notifications = { + q_chat: {}, + block: {} + } + notifications.q_chat = data.config.user.notifications.q_chat + notifications.block = data.config.user.notifications.block + return dispatch(loadNotificationConfig(notifications)) + }) + .catch(err => { + console.error(err) + }) + } +} + +const loadNotificationConfig = (payload) => { + + return { + type: LOAD_NOTIFICATION_CONFIG, + payload + } +} + +/** + * doSetQChatNotificationConfig action to set QChat Notification + * @param { Object } qChatNotificationObject - { playSound: boolean, showNotification: boolean } + */ + +export const doSetQChatNotificationConfig = (qChatNotificationObject) => { + + return (dispatch, getState) => { + + return dispatch(setQChatNotificationConfig(qChatNotificationObject)) + } +} + +const setQChatNotificationConfig = (payload) => { + + return { + type: SET_QCHAT_NOTIFICATION_CONFIG, + payload + } +} diff --git a/qortal-ui-core/src/redux/user/actions/start-minting.js b/qortal-ui-core/src/redux/user/actions/start-minting.js new file mode 100644 index 00000000..e69de29b diff --git a/qortal-ui-core/src/redux/user/actions/store-wallet.js b/qortal-ui-core/src/redux/user/actions/store-wallet.js new file mode 100644 index 00000000..2621ad25 --- /dev/null +++ b/qortal-ui-core/src/redux/user/actions/store-wallet.js @@ -0,0 +1,50 @@ +import { STORE_WALLET, REMOVE_WALLET, UPDATE_STORED_WALLET_NAME } from '../user-action-types.js' + +export const doStoreWallet = (wallet, password, name, statusUpdateFn = () => { }) => { + return (dispatch, getState) => { + + return wallet.generateSaveWalletData(password, getState().config.crypto.kdfThreads, statusUpdateFn).then(data => { + + dispatch(storeWallet({ + ...data, + name + })) + }) + } +} + +const storeWallet = payload => { + return { + type: STORE_WALLET, + payload + } +} + +export const doRemoveWallet = (address) => { + return (dispatch, getState) => { + return dispatch(removeWallet({ + address + })) + } +} + +const removeWallet = payload => { + return { + type: REMOVE_WALLET, + payload + } +} +export const doUpdateStoredWalletName = (address, name) => { + return (dispatch, getState) => { + return updateStoredWalletName({ + address, name + }) + } +} + +const updateStoredWalletName = payload => { + return { + type: UPDATE_STORED_WALLET_NAME, + payload + } +} diff --git a/qortal-ui-core/src/redux/user/actions/update-account-info.js b/qortal-ui-core/src/redux/user/actions/update-account-info.js new file mode 100644 index 00000000..def4695f --- /dev/null +++ b/qortal-ui-core/src/redux/user/actions/update-account-info.js @@ -0,0 +1,14 @@ +import { UPDATE_ACCOUNT_INFO } from '../user-action-types' + +export const doUpdateAccountInfo = (accInfo) => { + return (dispatch, getState) => { + return dispatch(updateAccountInfo(accInfo)) + } +} + +export const updateAccountInfo = (payload) => { + return { + type: UPDATE_ACCOUNT_INFO, + payload + } +} diff --git a/qortal-ui-core/src/redux/user/actions/update-name.js b/qortal-ui-core/src/redux/user/actions/update-name.js new file mode 100644 index 00000000..b1529bb0 --- /dev/null +++ b/qortal-ui-core/src/redux/user/actions/update-name.js @@ -0,0 +1,46 @@ +import { updateAccountInfo } from './update-account-info.js' +// import { doUpdateStoredWalletName } from '../user-actions.js' +import { doUpdateStoredWalletName } from './store-wallet.js' + +const GET_NAME_URL = 'names/address/' +const CHECK_NAME_INTERVAL = 1000 * 3 // Every 3 seconds + +export const UPDATE_NAME_STATUSES = { + LOADING: 'LOADING', + LOADED: 'LOADED', + DOES_NOT_EXIST: 'DOES_NOT_EXIST', + WAITING_FOR_CONFIRM: 'WAITING_FOR_CONFIRM' +} + +export const doUpdateAccountName = (address, expectedName, awaitingConfirm) => { + return (dispatch, getState) => { + dispatch(updateAccountInfo({ + nameStatus: UPDATE_NAME_STATUSES.LOADING, + name: expectedName + })) + const state = getState() + const config = state.config + const node = config.coin.node.api + // console.log(config.constants) + // const url = config.constants.proxyURL + node.url + node.tail + GET_NAME_URL + address + const url = node.url + node.tail + GET_NAME_URL + address + return fetch(url) + .then(res => res.json()) + .then(names => { + if (names.length > 0) { + const name = names[0] + dispatch(updateAccountInfo({ + nameStatus: UPDATE_NAME_STATUSES.LOADED, + name + })) + // ... + if (state.user.storedWallets[address]) dispatch(doUpdateStoredWalletName(address, name)) + } else { + dispatch(updateAccountInfo({ + nameStatus: awaitingConfirm ? UPDATE_NAME_STATUSES.DOES_NOT_EXIST : UPDATE_NAME_STATUSES.WAITING_FOR_CONFIRM + })) + if (awaitingConfirm) setTimeout(() => dispatch(doUpdateAccountName(address, expectedName, awaitingConfirm)), CHECK_NAME_INTERVAL) + } + }) + } +} diff --git a/qortal-ui-core/src/redux/user/user-action-types.js b/qortal-ui-core/src/redux/user/user-action-types.js new file mode 100644 index 00000000..440843e5 --- /dev/null +++ b/qortal-ui-core/src/redux/user/user-action-types.js @@ -0,0 +1,7 @@ +export const STORE_WALLET = 'STORE_WALLET' +export const REMOVE_WALLET = 'REMOVE_WALLET' +export const CLAIM_AIRDROP = 'CLAIM_AIRDROP' +export const UPDATE_ACCOUNT_INFO = 'UPDATE_ACCOUNT_INFO' +export const UPDATE_STORED_WALLET_NAME = 'UPDATE_STORED_WALLET_NAME' +export const LOAD_NOTIFICATION_CONFIG = 'LOAD_NOTIFICATION_CONFIG' +export const SET_QCHAT_NOTIFICATION_CONFIG = 'SET_QCHAT_NOTIFICATION_CONFIG' \ No newline at end of file diff --git a/qortal-ui-core/src/redux/user/user-actions.js b/qortal-ui-core/src/redux/user/user-actions.js new file mode 100644 index 00000000..88a264ec --- /dev/null +++ b/qortal-ui-core/src/redux/user/user-actions.js @@ -0,0 +1,4 @@ +export * from './actions/store-wallet.js' +export * from './actions/claim-airdrop.js' +export * from './actions/update-name.js' +export * from './actions/notification-config.js' diff --git a/qortal-ui-core/src/redux/user/user-reducer.js b/qortal-ui-core/src/redux/user/user-reducer.js new file mode 100644 index 00000000..b6535737 --- /dev/null +++ b/qortal-ui-core/src/redux/user/user-reducer.js @@ -0,0 +1,64 @@ +import { loadStateFromLocalStorage } from '../../localStorageHelpers' +import { STORE_WALLET, REMOVE_WALLET, CLAIM_AIRDROP, UPDATE_ACCOUNT_INFO, LOAD_NOTIFICATION_CONFIG, SET_QCHAT_NOTIFICATION_CONFIG } from './user-action-types.js' + +const DEFAULT_INITIAL_STATE = { + storedWallets: {}, + hasClaimedAirdrop: false, + accountInfo: { + // nameStatus: '' + }, + notifications: { + q_chat: {}, + block: {} + }, + loaded: false +} + +export default (state = loadStateFromLocalStorage('user') || DEFAULT_INITIAL_STATE, action) => { + switch (action.type) { + case STORE_WALLET: + return { + ...state, + storedWallets: { + ...(state.storedWallets || {}), + [action.payload.address0]: action.payload + } + } + case REMOVE_WALLET: + delete state.storedWallets[action.payload.address] + return { + ...state, + storedWallets:state.storedWallets + } + case CLAIM_AIRDROP: + return { + ...state, + hasClaimedAirdrop: true + } + case UPDATE_ACCOUNT_INFO: { + return { + ...state, + accountInfo: { + ...state.accountInfo, + ...action.payload + } + } + } + case LOAD_NOTIFICATION_CONFIG: + return { + ...state, + notifications: action.payload, + loaded: true + } + case SET_QCHAT_NOTIFICATION_CONFIG: + return { + ...state, + notifications: { + ...state.notifications, + q_chat: action.payload + } + } + default: + return state + } +} diff --git a/qortal-ui-core/src/stateAwait.js b/qortal-ui-core/src/stateAwait.js new file mode 100644 index 00000000..1668cb54 --- /dev/null +++ b/qortal-ui-core/src/stateAwait.js @@ -0,0 +1,23 @@ +/** + * Simple helper function so that I can do `await stateAwait(state => state.something === true)` or `await stateAwait(state => state.name === 'myName')` + */ +import { store } from './store.js' + +let subscriptions = [] +store.subscribe(() => { + const state = store.getState() + subscriptions = subscriptions.filter(fn => fn(state)) +}) +export const stateAwait = fn => { + return new Promise((resolve, reject) => { + // Check immediately...then if not true store it + if (fn(store.getState())) resolve() + subscriptions.push(state => { + if (fn(state)) { + resolve() + return true + } + return false + }) + }) +} diff --git a/qortal-ui-core/src/store.js b/qortal-ui-core/src/store.js new file mode 100644 index 00000000..16622e7d --- /dev/null +++ b/qortal-ui-core/src/store.js @@ -0,0 +1,12 @@ +import { createStore, compose, applyMiddleware } from 'redux' +import thunk from 'redux-thunk' + +import reducers from './redux/reducers.js' +const composeEnhancers = window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ || compose + +export const store = createStore( + reducers, + composeEnhancers( + applyMiddleware(thunk) + ) +) diff --git a/qortal-ui-core/src/styles/app-styles.js b/qortal-ui-core/src/styles/app-styles.js new file mode 100644 index 00000000..e35ec88d --- /dev/null +++ b/qortal-ui-core/src/styles/app-styles.js @@ -0,0 +1,86 @@ +import { LitElement, html } from 'lit-element' + +// import '../styles/styles.scss' +import './styles.scss' +import './app-theme.js' + +class AppStyles extends LitElement { + // static get styles () { + // return [ + // css` + // html, * { + // color: var(--color, green); + // } + // ` + // ] + // } + + /* Disable shadow DOM, so that the styles DO bleed */ + createRenderRoot () { + return this + } + + render () { + return html` + + + ` + } + + constructor () { + super() + this.windowHeight = html`100vh` + window.addEventListener('resize', () => this._windowResized()) + this._windowResized() + } + + // For mobile chrome's address bar + _windowResized () { + const ua = navigator.userAgent + const isMobile = /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini|Mobile|mobile|CriOS/i.test(ua) + // console.log(isMobile, 'MOBILE') + const isChrome = /Chrome/i.test(ua) + const isSafari = /Version\/[\d\.]+.*Safari/.test(ua) + + if (isMobile && isChrome) { + this.windowHeight = html`calc(100vh - 56px)` + // document.body.style.setProperty('--window-height', 'calc(100vh - 56px)') + // console.log('not same') + } else if (isMobile && isSafari) { + this.windowHeight = html`calc(100vh - 72px)` + } else { + this.windowHeight = html`100vh` + // document.body.style.setProperty('--window-height', '100vh') + // console.log('same') + } + } +} + +window.customElements.define('app-styles', AppStyles) diff --git a/qortal-ui-core/src/styles/app-theme.js b/qortal-ui-core/src/styles/app-theme.js new file mode 100644 index 00000000..7a70ac27 --- /dev/null +++ b/qortal-ui-core/src/styles/app-theme.js @@ -0,0 +1,66 @@ +import { LitElement, html } from 'lit-element' +import { connect } from 'pwa-helpers' +import { store } from '../store.js' + +class AppTheme extends connect(store)(LitElement) { + // static get styles () { + // return [ + // css` + // html, * { + // color: var(--color, green); + // } + // ` + // ] + // } + + static get properties () { + return { + styles: { type: Object }, + theme: { type: Object } + } + } + + /* Disable shady css, so that the styles DO bleed */ + createRenderRoot () { + return this + } + + render () { + return html` + + ` + } + + stateChanged (state) { + this.styles = state.config.styles + this.theme = this.styles.theme + } +} + +window.customElements.define('app-theme', AppTheme) diff --git a/qortal-ui-core/src/styles/styles.scss b/qortal-ui-core/src/styles/styles.scss new file mode 100644 index 00000000..da6a76ae --- /dev/null +++ b/qortal-ui-core/src/styles/styles.scss @@ -0,0 +1,17 @@ +$mdc-layout-grid-breakpoints: ( + desktop: 960px, + tablet: 480px, + phone: 0px +); + +:root, html, body{ + --layout-breakpoint-desktop: #{map-get($mdc-layout-grid-breakpoints, desktop)}; + --layout-breakpoint-tablet: #{map-get($mdc-layout-grid-breakpoints, tablet)}; + --layout-breakpoint-mobile: #{map-get($mdc-layout-grid-breakpoints, phone)}; +} + +// @import '../../node_modules/@material/layout-grid/mdc-layout-grid.scss'; + +iframe.pluginJSFrame { + display:none; +} diff --git a/qortal-ui-core/src/transactionRequest.js b/qortal-ui-core/src/transactionRequest.js new file mode 100644 index 00000000..ee080ca6 --- /dev/null +++ b/qortal-ui-core/src/transactionRequest.js @@ -0,0 +1,12 @@ +let transactionRequestListener = async () => { + return { + confirmed: false, + reason: 'Dialoag not registered' + } +} + +export const requestTransaction = async (...args) => transactionRequestListener(...args) + +export const listenForRequest = listener => { + transactionRequestListener = listener +} diff --git a/qortal-ui-core/src/worker.js b/qortal-ui-core/src/worker.js new file mode 100644 index 00000000..212f481e --- /dev/null +++ b/qortal-ui-core/src/worker.js @@ -0,0 +1,23 @@ +import { Epml, EpmlReadyPlugin, RequestPlugin, EpmlWorkerPlugin } from 'epml' + +import utils from './cryptoUtils.js' +import { Sha512, bytes_to_base64 as bytesToBase64 } from 'asmcrypto.js' +import bcrypt from 'bcryptjs' + +Epml.registerPlugin(RequestPlugin) +Epml.registerPlugin(EpmlReadyPlugin) +Epml.registerPlugin(EpmlWorkerPlugin) + +const parentEpml = new Epml({ type: 'WORKER', source: self }) + +parentEpml.route('kdf', async req => { + + const { salt, key, nonce, staticSalt, staticBcryptSalt } = req.data + const combinedBytes = utils.appendBuffer(salt, utils.stringtoUTF8Array(staticSalt + key + nonce)) + const sha512Hash = new Sha512().process(combinedBytes).finish().result + const sha512HashBase64 = bytesToBase64(sha512Hash) + const result = bcrypt.hashSync(sha512HashBase64.substring(0, 72), staticBcryptSalt) + return { key, nonce, result } +}) + +parentEpml.imReady() diff --git a/qortal-ui-core/tooling/build.js b/qortal-ui-core/tooling/build.js new file mode 100644 index 00000000..4b50d746 --- /dev/null +++ b/qortal-ui-core/tooling/build.js @@ -0,0 +1,38 @@ +const rollup = require('rollup') + +async function writeBundle(bundle, outputOptions) { + + await bundle.generate(outputOptions) + + await bundle.write(outputOptions) +} + +async function buildInline(conf) { + + const bundle = await rollup.rollup(conf.inputOptions).catch(err => { + throw err + }) + + await writeBundle(bundle, conf.outputOptions) + console.log('BUILD CORE ==> Bundling Done 🎉'); +} + +async function build(options, outputs, outputOptions, inputOptions, inlineConfigs) { + + const bundle = await rollup.rollup(inputOptions).catch(err => { + throw err + }) + + for (const option of outputs) { + await writeBundle(bundle, { + ...outputOptions, + ...option + }) + } + + for (const conf of inlineConfigs) { + await buildInline(conf) + } +} + +module.exports = build diff --git a/qortal-ui-core/tooling/generateBuildConfig.js b/qortal-ui-core/tooling/generateBuildConfig.js new file mode 100644 index 00000000..e8beb2b8 --- /dev/null +++ b/qortal-ui-core/tooling/generateBuildConfig.js @@ -0,0 +1,98 @@ +const path = require('path') +const { nodeResolve } = require('@rollup/plugin-node-resolve') +const progress = require('rollup-plugin-progress') +const replace = require('@rollup/plugin-replace') +const globals = require('rollup-plugin-node-globals') +const commonjs = require('@rollup/plugin-commonjs') +const alias = require('@rollup/plugin-alias') +const { terser } = require('rollup-plugin-terser') +const scss = require('rollup-plugin-scss') +const generateES5BuildConfig = require('./generateES5BuildConfig') + + +const generateInputs = (tree, inputs = {}) => { + + for (const file of Object.values(tree)) { + + inputs[file.file.split('.')[0]] = file.source + if (file.children) generateInputs(file.children, inputs) + } + return inputs +} + +const generateBuildConfig = ({ elementComponents, functionalComponents, otherOutputs, apiComponents, aliases, options, inlineComponents }) => { + const buildConfig = { + outputs: [ + { + dir: 'es6', + format: 'esm' + } + ], + outputOptions: { + sourcemap: false + }, + inputOptions: { + onwarn: (warning, rollupWarn) => { + if (warning.code !== 'CIRCULAR_DEPENDENCY') { + rollupWarn(warning) + } + }, + input: { + main: options.inputFile, + ...generateInputs(elementComponents) + }, + plugins: [ + alias({ + entries: Object.keys(aliases).map(find => { + return { + find, + replacement: aliases[find] + } + }) + }), + nodeResolve({ + preferBuiltins: false, + mainFields: ['module', 'browser'] + }), + replace({ + preventAssignment: true, + "process.env.NODE_ENV": JSON.stringify("production"), + }), + commonjs(), + globals(), + progress(), + scss({ + output: options.sassOutputDir + }), + terser({ + compress: true, + output: { + comments: false + } + }) + ], + preserveEntrySignatures: false, + external: ['crypto'], + context: 'window' + }, + options: { + outputDir: options.outputDir + } + } + + for (const output of buildConfig.outputs) { + output.dir = path.join(options.outputDir, output.dir) + } + + const inlineConfigs = generateES5BuildConfig(inlineComponents, { + outputDir: options.outputDir, + aliases + }) + + return { + buildConfig, + inlineConfigs + } +} + +module.exports = generateBuildConfig diff --git a/qortal-ui-core/tooling/generateES5BuildConfig.js b/qortal-ui-core/tooling/generateES5BuildConfig.js new file mode 100644 index 00000000..2b5d15b1 --- /dev/null +++ b/qortal-ui-core/tooling/generateES5BuildConfig.js @@ -0,0 +1,66 @@ +const babel = require('@rollup/plugin-babel'); +const { nodeResolve } = require('@rollup/plugin-node-resolve'); +const replace = require('@rollup/plugin-replace'); +const commonjs = require('@rollup/plugin-commonjs'); +const progress = require('rollup-plugin-progress'); +const { terser } = require("rollup-plugin-terser"); +const path = require('path'); +const alias = require('@rollup/plugin-alias'); + +const generateRollupConfig = (file, { outputDir, aliases }) => { + + return { + inputOptions: { + input: file.input, + onwarn: (warning, rollupWarn) => { + if (warning.code !== 'CIRCULAR_DEPENDENCY') { + rollupWarn(warning) + } + }, + plugins: [ + nodeResolve({ + preferBuiltins: false, + mainFields: ['module', 'browser'] + }), + replace({ + preventAssignment: true, + "process.env.NODE_ENV": JSON.stringify("production"), + }), + alias({ + entries: Object.keys(aliases).map(find => { + return { + find, + replacement: aliases[find] + } + }) + }), + commonjs(), + progress(), + babel.babel({ + babelHelpers: 'bundled', + exclude: 'node_modules/**' + }), + terser({ + compress: true, + output: { + comments: false, + }, + }) + ], + preserveEntrySignatures: false, + external: ['crypto'] + }, + outputOptions: { + file: path.join(outputDir, file.output), + format: 'umd', + name: 'worker', + sourcemap: false + } + } +} + +const generateES5BuildConfig = (files, options) => { + return files.map(file => generateRollupConfig(file, options)) +} + +module.exports = generateES5BuildConfig diff --git a/qortal-ui-core/tooling/utils.js b/qortal-ui-core/tooling/utils.js new file mode 100644 index 00000000..2574b018 --- /dev/null +++ b/qortal-ui-core/tooling/utils.js @@ -0,0 +1,21 @@ +const path = require('path') + +// So that the directory rollup is running in doesn't matter as the paths aren't relative +const makeSourceAbsolute = (dir, tree) => { + for (const component of Object.values(tree)) { + // console.log(component) + component.source = path.join(dir, component.file) + if (component.children) { + makeSourceAbsolute(dir, component.children) + // for (const child of Object.values(component.children)) { + // console.log(child) + // addPathToSource(child) + // } + } + } + return tree +} + +module.exports = { + makeSourceAbsolute +} diff --git a/qortal-ui-core/tooling/watch-inlines.js b/qortal-ui-core/tooling/watch-inlines.js new file mode 100644 index 00000000..540ce53e --- /dev/null +++ b/qortal-ui-core/tooling/watch-inlines.js @@ -0,0 +1,41 @@ +const rollup = require('rollup') + +async function watchInlines (inlineConfigs) { + for (const conf of inlineConfigs) { + const watchOptions = { + ...conf.inputOptions, + // output: [outputOptions], + output: [conf.outputOptions], + watch: { + // chokidar, + // clearScreen, + // exclude, + // include + } + } + + const watcher = rollup.watch(watchOptions) + + watcher.on('event', event => { + // event.code can be one of: + // START — the watcher is (re)starting + // BUNDLE_START — building an individual bundle + // BUNDLE_END — finished building a bundle + // END — finished building all bundles + // ERROR — encountered an error while bundling + // FATAL — encountered an unrecoverable error + }) + + // stop watching + // watcher.close() + } + // console.log(bundle.watchFiles) // an array of file names this bundle depends on + + // console.log(bundle, conf.outputOptions) + // await writeBundle(bundle, conf.outputOptions) + // console.log('bundle written') +} + +// build() + +module.exports = watchInlines diff --git a/qortal-ui-core/tooling/watch.js b/qortal-ui-core/tooling/watch.js new file mode 100644 index 00000000..71eddc7f --- /dev/null +++ b/qortal-ui-core/tooling/watch.js @@ -0,0 +1,43 @@ +const rollup = require('rollup') + +async function watch(options, outputs, outputOptions, inputOptions) { + + const watchOptions = { + ...inputOptions, + output: outputs.map(option => { + return { + ...outputOptions, + ...option + } + }), + watch: { + // chokidar, + // clearScreen, + // exclude, + // include + } + } + const watcher = rollup.watch(watchOptions) + + watcher.on('event', event => { + // ... + }) +} + +async function writeBundle(bundle, outputOptions) { + + await bundle.generate(outputOptions) + + await bundle.write(outputOptions) + console.log('WATCH CORE ==> Write Bundle : Done 🎉'); +} + +async function buildInline(conf) { + const bundle = await rollup.rollup(conf.inputOptions).catch(err => { + throw err + }) + + await writeBundle(bundle, conf.outputOptions) +} + +module.exports = watch diff --git a/qortal-ui-core/ui-core.js b/qortal-ui-core/ui-core.js new file mode 100644 index 00000000..4876d417 --- /dev/null +++ b/qortal-ui-core/ui-core.js @@ -0,0 +1,49 @@ + +const SERVER = 'server' +const BUILD = 'build' +const WATCH = 'watch' +const WATCH_INLINE = 'watch_inline' +const DEFAULT_CONFIG = 'default_config' +const GENERATE_BUILD_CONFIG = 'generate_build_config' + +/** + * @package UI Core Controller + * @param type String + */ + +const uiCoreController = (type) => { + switch (type) { + case SERVER: + const { createServer } = require('./server/server.js') + return createServer + case BUILD: + const build = require('./tooling/build.js') + return build + case WATCH: + const watch = require('./tooling/watch.js') + return watch + case WATCH_INLINE: + const watchInlines = require('./tooling/watch-inlines.js') + return watchInlines + case DEFAULT_CONFIG: + const defaultConfig = require('./config/config.js') + return defaultConfig + case GENERATE_BUILD_CONFIG: + const generateBuildConfig = require('./tooling/generateBuildConfig.js') + return generateBuildConfig + default: + return + } + +} + +module.exports = uiCoreController + +/** + * Performance update + * Write a CSS ripple effect and replace all paper-ripple and mwc-ripple + * Do something about the particles... + */ + +// TODO: notifications settings, do not show notification in an active chat, Fix double message rendering, right custom menu in chat + diff --git a/qortal-ui-crypto/api.js b/qortal-ui-crypto/api.js new file mode 100644 index 00000000..b2cfad3c --- /dev/null +++ b/qortal-ui-crypto/api.js @@ -0,0 +1,21 @@ +import { Sha256 } from 'asmcrypto.js' +import Base58 from './api/deps/Base58' +import { base58PublicKeyToAddress } from './api/wallet/base58PublicKeyToAddress' +import { validateAddress } from './api/wallet/validateAddress' +import { decryptChatMessage } from './api/transactions/chat/decryptChatMessage'; +import _ from 'lodash'; + + +window.Sha256 = Sha256 +window.Base58 = Base58 +window._ = _ +window.base58PublicKeyToAddress = base58PublicKeyToAddress +window.validateAddress = validateAddress +window.decryptChatMessage = decryptChatMessage + +export { initApi, store } from './api_deps.js' + +export * from './api/deps/deps.js' +export * from './api/api.js' +export * from './api/registerUsername.js' +export { createWallet } from './api/createWallet.js' diff --git a/qortal-ui-crypto/api/PhraseWallet.js b/qortal-ui-crypto/api/PhraseWallet.js new file mode 100644 index 00000000..86aaca35 --- /dev/null +++ b/qortal-ui-crypto/api/PhraseWallet.js @@ -0,0 +1,161 @@ +/* +Copyright 2017-2018 @ irontiga and vbcs (original developer) +*/ +'use strict'; +import Base58 from './deps/Base58.js' +import { Sha256, Sha512 } from 'asmcrypto.js' +import nacl from './deps/nacl-fast.js' +import utils from './deps/utils.js' + +import { generateSaveWalletData } from './storeWallet.js' + +import publicKeyToAddress from './wallet/publicKeyToAddress.js' +import AltcoinHDWallet from "./bitcoin/AltcoinHDWallet"; + +export default class PhraseWallet { + constructor(seed, walletVersion) { + + this._walletVersion = walletVersion || 2 + this.seed = seed + + this.savedSeedData = {} + this.hasBeenSaved = false + } + + set seed(seed) { + this._byteSeed = seed + this._base58Seed = Base58.encode(seed) + + this._addresses = [] + + this.genAddress(0) + } + + getAddress(nonce) { + return this._addresses[nonce] + } + + get addresses() { + return this._addresses + } + + get addressIDs() { + return this._addresses.map(addr => { + return addr.address + }) + } + + get seed() { + return this._byteSeed + } + + addressExists(nonce) { + return this._addresses[nonce] != undefined + } + + _genAddressSeed(seed) { + let newSeed = new Sha512().process(seed).finish().result + newSeed = new Sha512().process(utils.appendBuffer(newSeed, seed)).finish().result + return newSeed + } + + genAddress(nonce) { + if (nonce >= this._addresses.length) { + this._addresses.length = nonce + 1 + } + + if (this.addressExists(nonce)) { + return this.addresses[nonce] + } + + const nonceBytes = utils.int32ToBytes(nonce) + + let addrSeed = new Uint8Array() + addrSeed = utils.appendBuffer(addrSeed, nonceBytes) + addrSeed = utils.appendBuffer(addrSeed, this._byteSeed) + addrSeed = utils.appendBuffer(addrSeed, nonceBytes) + + if (this._walletVersion == 1) { + addrSeed = new Sha256().process( + new Sha256() + .process(addrSeed) + .finish() + .result + ).finish().result + + addrSeed = this._byteSeed + } else { + addrSeed = this._genAddressSeed(addrSeed).slice(0, 32) + } + + const addrKeyPair = nacl.sign.keyPair.fromSeed(new Uint8Array(addrSeed)); + + const address = publicKeyToAddress(addrKeyPair.publicKey); + const qoraAddress = publicKeyToAddress(addrKeyPair.publicKey, true); + + // Create Bitcoin HD Wallet + const btcSeed = [...addrSeed]; + const btcWallet = new AltcoinHDWallet({ + mainnet: { + private: 0x0488ADE4, + public: 0x0488B21E, + prefix: 0 + }, + testnet: { + private: 0x04358394, + public: 0x043587CF, + prefix: 0x6F + } + }).createWallet(new Uint8Array(btcSeed), false); + + // Create Litecoin HD Wallet + const ltcSeed = [...addrSeed]; + const ltcWallet = new AltcoinHDWallet({ + mainnet: { + private: 0x0488ADE4, + public: 0x0488B21E, + prefix: 0x30 + }, + testnet: { + private: 0x04358394, + public: 0x043587CF, + prefix: 0x6F + } + }).createWallet(new Uint8Array(ltcSeed), false, 'LTC'); + + // Create Dogecoin HD Wallet + const dogeSeed = [...addrSeed]; + const dogeWallet = new AltcoinHDWallet({ + mainnet: { + private: 0x02FAC398, + public: 0x02FACAFD, + prefix: 0x1E + }, + testnet: { + private: 0x04358394, + public: 0x043587CF, + prefix: 0x71 + } + }).createWallet(new Uint8Array(dogeSeed), false, 'DOGE'); + + this._addresses[nonce] = { + address, + btcWallet, + ltcWallet, + dogeWallet, + qoraAddress, + keyPair: { + publicKey: addrKeyPair.publicKey, + privateKey: addrKeyPair.secretKey + }, + base58PublicKey: Base58.encode(addrKeyPair.publicKey), + seed: addrSeed, + nonce: nonce + } + return this._addresses[nonce] + } + + generateSaveWalletData(...args) { + return generateSaveWalletData(this, ...args) + } +} diff --git a/qortal-ui-crypto/api/api.js b/qortal-ui-crypto/api/api.js new file mode 100644 index 00000000..bcc5d8b8 --- /dev/null +++ b/qortal-ui-crypto/api/api.js @@ -0,0 +1,9 @@ +export { request } from './fetch-request.js' + +export { transactionTypes as transactions } from './transactions/transactions.js' + +export { processTransaction, createTransaction, computeChatNonce, signChatTransaction } from './createTransaction.js' + +export { tradeBotCreateRequest, tradeBotRespondRequest, signTradeBotTxn, deleteTradeOffer, sendBtc, sendLtc, sendDoge } from './tradeRequest.js' + +export { cancelAllOffers } from './transactions/trade-portal/tradeoffer/cancelAllOffers.js' diff --git a/qortal-ui-crypto/api/bitcoin/AltcoinHDWallet.js b/qortal-ui-crypto/api/bitcoin/AltcoinHDWallet.js new file mode 100644 index 00000000..2050c87e --- /dev/null +++ b/qortal-ui-crypto/api/bitcoin/AltcoinHDWallet.js @@ -0,0 +1,873 @@ +'use strict'; +import Base58 from '../deps/Base58.js' +import { Sha256, Sha512 } from 'asmcrypto.js' +import jsSHA from "jssha"; +import RIPEMD160 from '../deps/ripemd160.js' +import utils from '../deps/utils.js' +import { EllipticCurve, BigInteger } from './ecbn.js'; + + +export default class AltcoinHDWallet { + + constructor(addressParams) { + + /** + * Seed - 32 bytes + */ + + this.seed = new Uint8Array(32) + + /** + * Version Bytes - 4 byte + */ + + this.versionBytes = addressParams + + /** + * Depth - 1 byte + */ + + this.depth = 0 + + /** + * Parent Fingerprint - 4 bytes + */ + + this.parentFingerprint = '0x00000000' // master key + + /** + * Child Index - 4 bytes + */ + + this.childIndex = '0x00000000' // master key + + /** + * Chain Code - 32 bytes + */ + + this.chainCode = new Uint8Array(32) + + /** + * Key Data - 33 bytes + */ + + this.keyData = new Uint8Array(33) + + /** + * Seed Hash - 64 bytes + */ + + this.seedHash = new Uint8Array(64) + + /** + * Private Key - 32 bytes + */ + + this.privateKey = new Uint8Array(32) + + /** + * Public Key - 33 bytes (compressed) + */ + + this.publicKey = new Uint8Array(33) + + /** + * Public Key Hash160 (used to derive the parent fingerprint for derived) + */ + + this.publicKeyHash = new Uint8Array(20) + + /** + * Master Private Key (Base58 encoded) + */ + + this.masterPrivateKey = '' + + /** + * Master Public Key (Base58 encoded) + */ + + this.masterPublicKey = '' + + /** + * Testnet Master Private Key (Base58 encoded) - THIS IS TESTNET + */ + + this._tMasterPrivateKey = '' + + /** + * Testnet Master Public Key (Base58 encoded) - THIS IS TESTNET + */ + + this._tmasterPublicKey = '' + + + + + /** + * Child Keys Derivation from the Parent Keys + */ + + + /** + * Child Private Key - 32 bytes + */ + + this.childPrivateKey = new Uint8Array(32) + + /** + * Child Chain Code - 32 bytes + */ + + this.childChainCode = new Uint8Array(32) + + /** + * Child Public Key - 33 bytes (compressed) + */ + + this.childPublicKey = new Uint8Array(33) + + /** + * Child Public Key Hash160 (used to derive the parent fingerprint for derived) + */ + + this.childPublicKeyHash = new Uint8Array(20) + + /** + * Extended Private Child Key - Base58 encoded + */ + + this.xPrivateChildKey = '' + + /** + * Extended Public Child Key - Base58 encoded + */ + + this.xPublicChildKey = '' + + + + /** + * Grand Child Keys Derivation from the Child Keys + */ + + + /** + * Grand Child Private Key - 32 bytes + */ + + this.grandChildPrivateKey = new Uint8Array(32) + + /** + * Grand Child Chain Code - 32 bytes + */ + + this.grandChildChainCode = new Uint8Array(32) + + /** + * Grand Child Public Key - 33 bytes (compressed) + */ + + this.grandChildPublicKey = new Uint8Array(33) + + /** + * Grand Public Key Hash160 (used to derive the parent fingerprint for derived) + */ + + this.grandChildPublicKeyHash = new Uint8Array(20) + + /** + * Extended Private Grand Child Key - Base58 encoded + */ + + this.xPrivateGrandChildKey = '' + + /** + * Extended Public Grand Child Key - Base58 encoded + */ + + this.xPublicGrandChildKey = '' + + /** + * Litecoin Legacy Address - Derived from the Grand Child Public Key Hash + */ + + this.litecoinLegacyAddress = '' + + /** + * TESTNET Litecoin Legacy Address (Derived from the Grand Child Public Key Hash) - THIS IS TESTNET + */ + + this._tlitecoinLegacyAddress = '' + + + /** + * Wallet - Wallet Object (keys...) + */ + + this.wallet = {} + } + + setSeed(seed) { + this.seed = seed + } + + createWallet(seed, isBIP44, indicator = null) { + + // Set Seeed + this.setSeed(seed) + + // Generate Seed Hash + this.generateSeedHash(this.seed, isBIP44, indicator) + + // Generate Private Key + this.generatePrivateKey(this.seedHash) + + // Generate Chain Code + this.generateChainCode(this.seedHash) + + // Generate Public Key from Private Key + this.generatePublicKey(this.privateKey) + + // Generate Mainnet Master Private Key + this.generateMainnetMasterPrivateKey() + + // Generate Mainnet Master Public Key + this.generateMainnetMasterPublicKey() + + // Generate Testnet Master Private Key + this.generateTestnetMasterPrivateKey() + + // Generate Testnet Master Public Key + this.generateTestnetMasterPublicKey() + + // Generate Child and Grand Child Keys + this.generateDerivedChildKeys() + + // Return Wallet Object Specification + return this.returnWallet() + } + + + generateSeedHash(seed, isBIP44, indicator = null) { + + let buffer; + + if (isBIP44) { + buffer = utils.appendBuffer(seed.reverse(), utils.int32ToBytes(indicator)) + } else { + if(indicator !== null) { + const indicatorString = utils.stringtoUTF8Array(indicator); + buffer = utils.appendBuffer(seed.reverse(), indicatorString); + } + else + { + buffer = seed.reverse(); + } + } + + const _reverseSeedHash = new Sha256().process(buffer).finish().result; + this.seedHash = new Sha512().process(utils.appendBuffer(seed, _reverseSeedHash)).finish().result; + } + + generatePrivateKey(seedHash) { + + const SECP256K1_CURVE_ORDER = new BigInteger("0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141"); + + const privateKeyHash = seedHash.slice(0, 32); + + const _privateKeyHash = [...privateKeyHash] + let privateKeyBigInt = BigInteger.fromByteArrayUnsigned(_privateKeyHash); + + const privateKey = (privateKeyBigInt.mod(SECP256K1_CURVE_ORDER.subtract(BigInteger.ONE))).add(BigInteger.ONE) + this.privateKey = privateKey.toByteArrayUnsigned() + } + + generateChainCode(seedHash) { + + this.chainCode = new Sha256().process(seedHash.slice(32, 64)).finish().result; + } + + generatePublicKey(privateKey) { + + const _privateKey = [...privateKey] + const privateKeyBigInt = BigInteger.fromByteArrayUnsigned(_privateKey); + + const epCurve = EllipticCurve.getSECCurveByName("secp256k1"); + const curvePoints = epCurve.getG().multiply(privateKeyBigInt); + + + const x = curvePoints.getX().toBigInteger(); + const y = curvePoints.getY().toBigInteger(); + + /** + * Deriving Uncompressed Public Key (65 bytes) + * + * const publicKeyBytes = EllipticCurve.integerToBytes(x, 32); + * this.publicKey = publicKeyBytes.concat(EllipticCurve.integerToBytes(y, 32)); + * this.publicKey.unshift(0x04); // append point indicator + */ + + + // Compressed Public Key (33 bytes) + this.publicKey = EllipticCurve.integerToBytes(x, 32) + + + if (y.isEven()) { + + this.publicKey.unshift(0x02) // append point indicator + } else { + + this.publicKey.unshift(0x03) // append point indicator + } + + // PublicKey Hash + const publicKeySHA256 = new Sha256().process(new Uint8Array(this.publicKey)).finish().result + const _publicKeyHash = new RIPEMD160().update(Buffer.from(publicKeySHA256)).digest('hex') + this.publicKeyHash = _publicKeyHash + } + + generateMainnetMasterPrivateKey() { + + // Serialization Variable + const s = [] + + // Append Version Byte + s.push(...(utils.int32ToBytes(this.versionBytes.mainnet.private))) + + // Append Depth + s.push(this.depth) + + // Append Parent Fingerprint + s.push(...(utils.int32ToBytes(this.parentFingerprint))) + + // Append Child Number + s.push(...(utils.int32ToBytes(this.childIndex))) + + // Append Chain Code + s.push(...this.chainCode) + + // Append 1 byte '0x00' (to make the key data 33 bytes, DO THIS ONLY FOR PRIVATE KEYS ) + s.push(0) + + //if the private key length is less than 32 let's add leading zeros + if(this.privateKey.length<32){ + for(let i=this.privateKey.length;i<32;i++){ + s.push(0) + } + } + + // Append Private Key + s.push(...this.privateKey) + + // Generate CheckSum + const _s = new Uint8Array(s) + const _checkSum = new Sha256().process(new Sha256().process(_s).finish().result).finish().result + const checkSum = _checkSum.slice(0, 4) + + // Append CheckSum + s.push(...checkSum) // And this brings us to the end of the serialization... + + // Save to Private Key as Base58 encoded + this.masterPrivateKey = Base58.encode(s) + } + + generateMainnetMasterPublicKey() { + + // Serialization Variable + const s = [] + + // Append Version Byte + s.push(...(utils.int32ToBytes(this.versionBytes.mainnet.public))) + + // Append Depth + s.push(this.depth) + + // Append Parent Fingerprint + s.push(...(utils.int32ToBytes(this.parentFingerprint))) + + // Append Child Number + s.push(...(utils.int32ToBytes(this.childIndex))) + + // Append Chain Code + s.push(...this.chainCode) + + // Append Public Key + s.push(...this.publicKey) + + // Generate CheckSum + const _s = new Uint8Array(s) + const _checkSum = new Sha256().process(new Sha256().process(_s).finish().result).finish().result + const checkSum = _checkSum.slice(0, 4) + + // Append CheckSum + s.push(...checkSum) // And this brings us to the end of the serialization... + + // Save to Public Key as Base58 encoded + this.masterPublicKey = Base58.encode(s) + } + + generateTestnetMasterPrivateKey() { + + // To be Used ONLY in Testnet... + + // Serialization Variable + const s = [] + + // Append Version Byte + s.push(...(utils.int32ToBytes(this.versionBytes.testnet.private))) + + // Append Depth + s.push(this.depth) + + // Append Parent Fingerprint + s.push(...(utils.int32ToBytes(this.parentFingerprint))) + + // Append Child Number + s.push(...(utils.int32ToBytes(this.childIndex))) + + // Append Chain Code + s.push(...this.chainCode) + + // Append 1 byte '0x00' (to make the key data 33 bytes, DO THIS ONLY FOR PRIVATE KEYS ) + s.push(0) + + // Append Private Key + s.push(...this.privateKey) + + // Generate CheckSum + const _s = new Uint8Array(s) + const _checkSum = new Sha256().process(new Sha256().process(_s).finish().result).finish().result + const checkSum = _checkSum.slice(0, 4) + + // Append CheckSum + s.push(...checkSum) // And this brings us to the end of the serialization... + + // Save to Private Key as Base58 encoded + this._tMasterPrivateKey = Base58.encode(s) + } + + generateTestnetMasterPublicKey() { + + // To be Used ONLY in Testnet... + + // Serialization Variable + const s = [] + + // Append Version Byte + s.push(...(utils.int32ToBytes(this.versionBytes.testnet.public))) + + // Append Depth + s.push(this.depth) + + // Append Parent Fingerprint + s.push(...(utils.int32ToBytes(this.parentFingerprint))) + + // Append Child Number + s.push(...(utils.int32ToBytes(this.childIndex))) + + // Append Chain Code + s.push(...this.chainCode) + + // Append Private Key + s.push(...this.publicKey) + + // Generate CheckSum + const _s = new Uint8Array(s) + const _checkSum = new Sha256().process(new Sha256().process(_s).finish().result).finish().result + const checkSum = _checkSum.slice(0, 4) + + // Append CheckSum + s.push(...checkSum) // And this brings us to the end of the serialization... + + // Save to Private Key as Base58 encoded + this._tmasterPublicKey = Base58.encode(s) + } + + generateDerivedChildKeys() { + + // SPEC INFO: https://en.bitcoin.it/wiki/BIP_0032#Child_key_derivation_.28CKD.29_functions + // NOTE: will not be using some of derivations func as the value is known. (So I'd rather shove in the values and rewrite out the derivations later ?) + + // NOTE: I "re-wrote" and "reduplicate" the code for child and grandChild keys derivations inorder to get the child and grandchild from the child + // TODO: Make this more better in the future + + const path = 'm/0/0' + // let p = path.split('/'); + + // Get Public kEY + const derivePublicChildKey = () => { + + const _privateKey = [...this.childPrivateKey] + const privateKeyBigInt = BigInteger.fromByteArrayUnsigned(_privateKey); + + const epCurve = EllipticCurve.getSECCurveByName("secp256k1"); + const curvePoints = epCurve.getG().multiply(privateKeyBigInt); + + const x = curvePoints.getX().toBigInteger(); + const y = curvePoints.getY().toBigInteger(); + + // Compressed Public Key (33 bytes) + this.childPublicKey = EllipticCurve.integerToBytes(x, 32) + + + if (y.isEven()) { + + this.childPublicKey.unshift(0x02) // append point indicator + } else { + + this.childPublicKey.unshift(0x03) // append point indicator + } + + // PublicKey Hash + const childPublicKeySHA256 = new Sha256().process(new Uint8Array(this.childPublicKey)).finish().result + const _childPublicKeyHash = new RIPEMD160().update(Buffer.from(childPublicKeySHA256)).digest('hex') + this.childPublicKeyHash = _childPublicKeyHash + + + // Call deriveExtendedPublicChildKey // WIll be hardcoding the values... + deriveExtendedPublicChildKey(1, 0) + } + + const derivePrivateChildKey = (cI) => { + + let ib = []; + ib.push((cI >> 24) & 0xff); + ib.push((cI >> 16) & 0xff); + ib.push((cI >> 8) & 0xff); + ib.push(cI & 0xff); + + const s = [...this.publicKey].concat(ib); + + const _hmacSha512 = new jsSHA("SHA-512", "UINT8ARRAY", { numRounds: 1, hmacKey: { value: this.chainCode, format: "UINT8ARRAY" } }); + _hmacSha512.update(new Uint8Array(s)) + + + const IL = BigInteger.fromByteArrayUnsigned([..._hmacSha512.getHMAC('UINT8ARRAY').slice(0, 32)]) + this.childChainCode = _hmacSha512.getHMAC('UINT8ARRAY').slice(32, 64) // IR according to the SPEC + + + // SECP256k1 init + const epCurve = EllipticCurve.getSECCurveByName("secp256k1"); + + + const ki = IL.add(BigInteger.fromByteArrayUnsigned(this.privateKey)).mod(epCurve.getN()); // parse256(IL) + kpar (mod n) ==> ki + this.childPrivateKey = ki.toByteArrayUnsigned() + + // Call deriveExtendedPrivateChildKey + deriveExtendedPrivateChildKey(1, 0) + } + + + const deriveExtendedPrivateChildKey = (i, childIndex) => { + + // Serialization Variable + const s = [] + + // Append Version Byte + s.push(...(utils.int32ToBytes(this.versionBytes.mainnet.private))) + + // Append Depth (using the index as depth) + i = parseInt(i) + s.push(i) + + // Append Parent Fingerprint + s.push(...(this.publicKeyHash.slice(0, 4))) + + // Append Child Index + s.push(childIndex >>> 24); + s.push((childIndex >>> 16) & 0xff); + s.push((childIndex >>> 8) & 0xff); + s.push(childIndex & 0xff); + + // Append Chain Code + s.push(...this.childChainCode) + + // Append 1 byte '0x00' (to make the key data 33 bytes, DO THIS ONLY FOR PRIVATE KEYS ) + s.push(0) + + // Append Private Key + s.push(...this.childPrivateKey) + + // Generate CheckSum + const _s = new Uint8Array(s) + const _checkSum = new Sha256().process(new Sha256().process(_s).finish().result).finish().result + const checkSum = _checkSum.slice(0, 4) + + // Append CheckSum + s.push(...checkSum) // And this brings us to the end of the serialization... + + // Save to Private Key as Base58 encoded + this.xPrivateChildKey = Base58.encode(s) + } + + const deriveExtendedPublicChildKey = (i, childIndex) => { + + // Serialization Variable + const s = [] + + // Append Version Byte + s.push(...(utils.int32ToBytes(this.versionBytes.mainnet.public))) + + // Append Depth + i = parseInt(i) + s.push(i) + + // Append Parent Fingerprint + s.push(...(this.publicKeyHash.slice(0, 4))) + + // Append Child Index + s.push(childIndex >>> 24); + s.push((childIndex >>> 16) & 0xff); + s.push((childIndex >>> 8) & 0xff); + s.push(childIndex & 0xff); + + // Append Chain Code + s.push(...this.childChainCode) + + // Append Public Key + s.push(...this.childPublicKey) + + // Generate CheckSum + const _s = new Uint8Array(s) + const _checkSum = new Sha256().process(new Sha256().process(_s).finish().result).finish().result + const checkSum = _checkSum.slice(0, 4) + + // Append CheckSum + s.push(...checkSum) // And this brings us to the end of the serialization... + + + // Save to Public Key as Base58 encoded + this.xPublicChildKey = Base58.encode(s) + } + + + /** + * GRAND CHILD KEYS + * + * NOTE: I know this is not the best way to generate this (even though it works the way it ought) + * Things to rewrite will be and not limited to deriving this through a for loop, removing hard code values, etc... + */ + + const derivePublicGrandChildKey = () => { + + const _privateKey = [...this.grandChildPrivateKey] + const privateKeyBigInt = BigInteger.fromByteArrayUnsigned(_privateKey); + + + const epCurve = EllipticCurve.getSECCurveByName("secp256k1"); + const curvePoints = epCurve.getG().multiply(privateKeyBigInt); + + const x = curvePoints.getX().toBigInteger(); + const y = curvePoints.getY().toBigInteger(); + + // Compressed Public Key (33 bytes) + this.grandChildPublicKey = EllipticCurve.integerToBytes(x, 32) + + + if (y.isEven()) { + + this.grandChildPublicKey.unshift(0x02) // append point indicator + } else { + + this.grandChildPublicKey.unshift(0x03) // append point indicator + } + + + // PublicKey Hash + const grandChildPublicKeySHA256 = new Sha256().process(new Uint8Array(this.grandChildPublicKey)).finish().result + const _grandChildPublicKeyHash = new RIPEMD160().update(Buffer.from(grandChildPublicKeySHA256)).digest('hex') + this.grandChildPublicKeyHash = _grandChildPublicKeyHash + + + // Call deriveExtendedPublicChildKey // WIll be hardcoding the values... + deriveExtendedPublicGrandChildKey(2, 0) + + /** + * Derive Litecoin Legacy Address + */ + + // Append Address Prefix + const k = [this.versionBytes.mainnet.prefix].concat(...this.grandChildPublicKeyHash) + + // Derive Checksum + const _addressCheckSum = new Sha256().process(new Sha256().process(new Uint8Array(k)).finish().result).finish().result + const addressCheckSum = _addressCheckSum.slice(0, 4) + + // Append CheckSum + const _litecoinLegacyAddress = k.concat(...addressCheckSum) + + // Convert to Base58 + this.litecoinLegacyAddress = Base58.encode(_litecoinLegacyAddress) + + + /** + * Derive TESTNET Litecoin Legacy Address + */ + + // Append Version Byte + const tK = [this.versionBytes.testnet.prefix].concat(...this.grandChildPublicKeyHash) + + // Derive Checksum + const _tAddressCheckSum = new Sha256().process(new Sha256().process(new Uint8Array(tK)).finish().result).finish().result + const tAddressCheckSum = _tAddressCheckSum.slice(0, 4) + + // Append CheckSum + const _tlitecoinLegacyAddress = tK.concat(...tAddressCheckSum) + + // Convert to Base58 + this._tlitecoinLegacyAddress = Base58.encode(_tlitecoinLegacyAddress) + } + + const derivePrivateGrandChildKey = (cI, i) => { + + let ib = []; + ib.push((cI >> 24) & 0xff); + ib.push((cI >> 16) & 0xff); + ib.push((cI >> 8) & 0xff); + ib.push(cI & 0xff); + + const s = [...this.childPublicKey].concat(ib); + + + const _hmacSha512 = new jsSHA("SHA-512", "UINT8ARRAY", { numRounds: 1, hmacKey: { value: this.childChainCode, format: "UINT8ARRAY" } }); + _hmacSha512.update(new Uint8Array(s)) + + + const IL = BigInteger.fromByteArrayUnsigned([..._hmacSha512.getHMAC('UINT8ARRAY').slice(0, 32)]) + this.grandChildChainCode = _hmacSha512.getHMAC('UINT8ARRAY').slice(32, 64) // IR according to the SPEC + + // SECP256k1 init + const epCurve = EllipticCurve.getSECCurveByName("secp256k1"); + + + const ki = IL.add(BigInteger.fromByteArrayUnsigned(this.childPrivateKey)).mod(epCurve.getN()); // parse256(IL) + kpar (mod n) ==> ki + this.grandChildPrivateKey = ki.toByteArrayUnsigned() + + + // Call deriveExtendedPrivateChildKey + deriveExtendedPrivateGrandChildKey(2, 0) + } + + + const deriveExtendedPrivateGrandChildKey = (i, childIndex) => { + + // Serialization Variable + const s = [] + + // Append Version Byte + s.push(...(utils.int32ToBytes(this.versionBytes.mainnet.private))) + + // Append Depth (using the index as depth) + i = parseInt(i) + s.push(i) + + // Append Parent Fingerprint + s.push(...(this.childPublicKeyHash.slice(0, 4))) + + // Append Child Index + s.push(childIndex >>> 24); + s.push((childIndex >>> 16) & 0xff); + s.push((childIndex >>> 8) & 0xff); + s.push(childIndex & 0xff); + + // Append Chain Code + s.push(...this.grandChildChainCode) + + // Append 1 byte '0x00' (to make the key data 33 bytes, DO THIS ONLY FOR PRIVATE KEYS ) + s.push(0) + + // Append Private Key + s.push(...this.grandChildPrivateKey) + + // Generate CheckSum + const _s = new Uint8Array(s) + const _checkSum = new Sha256().process(new Sha256().process(_s).finish().result).finish().result + const checkSum = _checkSum.slice(0, 4) + + // Append CheckSum + s.push(...checkSum) // And this brings us to the end of the serialization... + + // Save to Private Key as Base58 encoded + this.xPrivateGrandChildKey = Base58.encode(s) + } + + const deriveExtendedPublicGrandChildKey = (i, childIndex) => { + + // Serialization Variable + const s = [] + + // Append Version Byte + s.push(...(utils.int32ToBytes(this.versionBytes.mainnet.public))) + + // Append Depth + i = parseInt(i) + s.push(i) + + // Append Parent Fingerprint + s.push(...(this.childPublicKeyHash.slice(0, 4))) + + // Append Child Index + s.push(childIndex >>> 24); + s.push((childIndex >>> 16) & 0xff); + s.push((childIndex >>> 8) & 0xff); + s.push(childIndex & 0xff); + + // Append Chain Code + s.push(...this.grandChildChainCode) + + // Append Public Key + s.push(...this.grandChildPublicKey) + + // Generate CheckSum + const _s = new Uint8Array(s) + const _checkSum = new Sha256().process(new Sha256().process(_s).finish().result).finish().result + const checkSum = _checkSum.slice(0, 4) + + // Append CheckSum + s.push(...checkSum) // And this brings us to the end of the serialization... + + // Save to Public Key as Base58 encoded + this.xPublicGrandChildKey = Base58.encode(s) + } + + + + // Hard Code value.. + let childIndex = 0 + + // Call derivePrivateChildKey //Hard code value + derivePrivateChildKey(childIndex) + + // Call derivePublicChildKey + derivePublicChildKey() + + + // Call derivePrivateGrandChildKey // Hard Code value... + derivePrivateGrandChildKey(0, 2) + + // Call derivePublicGrandChildKey + derivePublicGrandChildKey() + } + + returnWallet() { + + // Will be limiting the exported Wallet Object to just the Master keys and Legacy Addresses + + const wallet = { + derivedMasterPrivateKey: this.masterPrivateKey, + derivedMasterPublicKey: this.masterPublicKey, + _tDerivedMasterPrivateKey: this._tMasterPrivateKey, + _tDerivedmasterPublicKey: this._tmasterPublicKey, + // derivedPrivateChildKey: this.xPrivateChildKey, + // derivedPublicChildKey: this.xPublicChildKey, + // derivedPrivateGrandChildKey: this.xPrivateGrandChildKey, + // derivedPublicGrandChildKey: this.xPublicGrandChildKey, + address: this.litecoinLegacyAddress, + _taddress: this._tlitecoinLegacyAddress + } + + this.wallet = wallet + return wallet + } +} diff --git a/qortal-ui-crypto/api/bitcoin/ecbn.js b/qortal-ui-crypto/api/bitcoin/ecbn.js new file mode 100644 index 00000000..5c08091a --- /dev/null +++ b/qortal-ui-crypto/api/bitcoin/ecbn.js @@ -0,0 +1,2620 @@ +/**!!! +* Elliptic Curve and BigInteger implementation +* +* Copyright for each portion of code are included in their respective portions. +* Compiled and Put together by LOTW (^_^) +*/ + +(function () { + + + // Copyright (c) 2005 Tom Wu + // All Rights Reserved. + // See "LICENSE" for details. + + // Basic JavaScript BN library - subset useful for RSA encryption. + + // Bits per digit + var dbits; + + // JavaScript engine analysis + var canary = 0xdeadbeefcafe; + var j_lm = (canary & 0xffffff) == 0xefcafe; + + // (public) Constructor + function BigInteger(a, b, c) { + if (a != null) + if ('number' == typeof a) this.fromNumber(a, b, c); + else if (b == null && 'string' != typeof a) this.fromString(a, 256); + else this.fromString(a, b); + } + + // return new, unset BigInteger + function nbi() { + return new BigInteger(null); + } + + // am: Compute w_j += (x*this_i), propagate carries, + // c is initial carry, returns final carry. + // c < 3*dvalue, x < 2*dvalue, this_i < dvalue + // We need to select the fastest one that works in this environment. + + // am1: use a single mult and divide to get the high bits, + // max digit bits should be 26 because + // max internal value = 2*dvalue^2-2*dvalue (< 2^53) + function am1(i, x, w, j, c, n) { + while (--n >= 0) { + var v = x * this[i++] + w[j] + c; + c = Math.floor(v / 0x4000000); + w[j++] = v & 0x3ffffff; + } + return c; + } + // am2 avoids a big mult-and-extract completely. + // Max digit bits should be <= 30 because we do bitwise ops + // on values up to 2*hdvalue^2-hdvalue-1 (< 2^31) + function am2(i, x, w, j, c, n) { + var xl = x & 0x7fff, + xh = x >> 15; + while (--n >= 0) { + var l = this[i] & 0x7fff; + var h = this[i++] >> 15; + var m = xh * l + h * xl; + l = xl * l + ((m & 0x7fff) << 15) + w[j] + (c & 0x3fffffff); + c = (l >>> 30) + (m >>> 15) + xh * h + (c >>> 30); + w[j++] = l & 0x3fffffff; + } + return c; + } + // Alternately, set max digit bits to 28 since some + // browsers slow down when dealing with 32-bit numbers. + function am3(i, x, w, j, c, n) { + var xl = x & 0x3fff, + xh = x >> 14; + while (--n >= 0) { + var l = this[i] & 0x3fff; + var h = this[i++] >> 14; + var m = xh * l + h * xl; + l = xl * l + ((m & 0x3fff) << 14) + w[j] + c; + c = (l >> 28) + (m >> 14) + xh * h; + w[j++] = l & 0xfffffff; + } + return c; + } + var inBrowser = typeof navigator !== 'undefined'; + if (inBrowser && j_lm && navigator.appName == 'Microsoft Internet Explorer') { + BigInteger.prototype.am = am2; + dbits = 30; + } else if (inBrowser && j_lm && navigator.appName != 'Netscape') { + BigInteger.prototype.am = am1; + dbits = 26; + } else { + // Mozilla/Netscape seems to prefer am3 + BigInteger.prototype.am = am3; + dbits = 28; + } + + BigInteger.prototype.DB = dbits; + BigInteger.prototype.DM = (1 << dbits) - 1; + BigInteger.prototype.DV = 1 << dbits; + + var BI_FP = 52; + BigInteger.prototype.FV = Math.pow(2, BI_FP); + BigInteger.prototype.F1 = BI_FP - dbits; + BigInteger.prototype.F2 = 2 * dbits - BI_FP; + + // Digit conversions + var BI_RM = '0123456789abcdefghijklmnopqrstuvwxyz'; + var BI_RC = new Array(); + var rr, vv; + rr = '0'.charCodeAt(0); + for (vv = 0; vv <= 9; ++vv) BI_RC[rr++] = vv; + rr = 'a'.charCodeAt(0); + for (vv = 10; vv < 36; ++vv) BI_RC[rr++] = vv; + rr = 'A'.charCodeAt(0); + for (vv = 10; vv < 36; ++vv) BI_RC[rr++] = vv; + + function int2char(n) { + return BI_RM.charAt(n); + } + function intAt(s, i) { + var c = BI_RC[s.charCodeAt(i)]; + return c == null ? -1 : c; + } + + // (protected) copy this to r + function bnpCopyTo(r) { + for (var i = this.t - 1; i >= 0; --i) r[i] = this[i]; + r.t = this.t; + r.s = this.s; + } + + // (protected) set from integer value x, -DV <= x < DV + function bnpFromInt(x) { + this.t = 1; + this.s = x < 0 ? -1 : 0; + if (x > 0) this[0] = x; + else if (x < -1) this[0] = x + this.DV; + else this.t = 0; + } + + // return bigint initialized to value + function nbv(i) { + var r = nbi(); + r.fromInt(i); + return r; + } + + // (protected) set from string and radix + function bnpFromString(s, b) { + // Auto-detect string notations + if (!b && s.length >= 2 && s[0] === '0') { + var isDetected = true; + switch (s[1]) { + case 'x': // Hexadecimal notation + b = 16; + break; + case 'b': // Binary notation + b = 2; + break; + case 'o': // Octal notation + b = 8; + break; + default: + isDetected = false; + } + + // Remove the notation string if any has been detected + if (isDetected) { + s = s.substr(2); + } + } + + var k; + if (b == 16) k = 4; + else if (b == 8) k = 3; + else if (b == 256) k = 8; + // byte array + else if (b == 2) k = 1; + else if (b == 32) k = 5; + else if (b == 4) k = 2; + else { + this.fromRadix(s, b); + return; + } + this.t = 0; + this.s = 0; + var i = s.length, + mi = false, + sh = 0; + while (--i >= 0) { + var x = k == 8 ? s[i] & 0xff : intAt(s, i); + if (x < 0) { + if (s.charAt(i) == '-') mi = true; + continue; + } + mi = false; + if (sh == 0) this[this.t++] = x; + else if (sh + k > this.DB) { + this[this.t - 1] |= (x & ((1 << (this.DB - sh)) - 1)) << sh; + this[this.t++] = x >> (this.DB - sh); + } else this[this.t - 1] |= x << sh; + sh += k; + if (sh >= this.DB) sh -= this.DB; + } + if (k == 8 && (s[0] & 0x80) != 0) { + this.s = -1; + if (sh > 0) this[this.t - 1] |= ((1 << (this.DB - sh)) - 1) << sh; + } + this.clamp(); + if (mi) BigInteger.ZERO.subTo(this, this); + } + + // (protected) clamp off excess high words + function bnpClamp() { + var c = this.s & this.DM; + while (this.t > 0 && this[this.t - 1] == c) --this.t; + } + + // (public) return string representation in given radix + function bnToString(b) { + if (this.s < 0) return '-' + this.negate().toString(b); + var k; + if (b == 16) k = 4; + else if (b == 8) k = 3; + else if (b == 2) k = 1; + else if (b == 32) k = 5; + else if (b == 4) k = 2; + else return this.toRadix(b); + var km = (1 << k) - 1, + d, + m = false, + r = '', + i = this.t; + var p = this.DB - ((i * this.DB) % k); + if (i-- > 0) { + if (p < this.DB && (d = this[i] >> p) > 0) { + m = true; + r = int2char(d); + } + while (i >= 0) { + if (p < k) { + d = (this[i] & ((1 << p) - 1)) << (k - p); + d |= this[--i] >> (p += this.DB - k); + } else { + d = (this[i] >> (p -= k)) & km; + if (p <= 0) { + p += this.DB; + --i; + } + } + if (d > 0) m = true; + if (m) r += int2char(d); + } + } + return m ? r : '0'; + } + + // (public) -this + function bnNegate() { + var r = nbi(); + BigInteger.ZERO.subTo(this, r); + return r; + } + + // (public) |this| + function bnAbs() { + return this.s < 0 ? this.negate() : this; + } + + // (public) return + if this > a, - if this < a, 0 if equal + function bnCompareTo(a) { + var r = this.s - a.s; + if (r != 0) return r; + var i = this.t; + r = i - a.t; + if (r != 0) return this.s < 0 ? -r : r; + while (--i >= 0) if ((r = this[i] - a[i]) != 0) return r; + return 0; + } + + // returns bit length of the integer x + function nbits(x) { + var r = 1, + t; + if ((t = x >>> 16) != 0) { + x = t; + r += 16; + } + if ((t = x >> 8) != 0) { + x = t; + r += 8; + } + if ((t = x >> 4) != 0) { + x = t; + r += 4; + } + if ((t = x >> 2) != 0) { + x = t; + r += 2; + } + if ((t = x >> 1) != 0) { + x = t; + r += 1; + } + return r; + } + + // (public) return the number of bits in "this" + function bnBitLength() { + if (this.t <= 0) return 0; + return ( + this.DB * (this.t - 1) + nbits(this[this.t - 1] ^ (this.s & this.DM)) + ); + } + + // (protected) r = this << n*DB + function bnpDLShiftTo(n, r) { + var i; + for (i = this.t - 1; i >= 0; --i) r[i + n] = this[i]; + for (i = n - 1; i >= 0; --i) r[i] = 0; + r.t = this.t + n; + r.s = this.s; + } + + // (protected) r = this >> n*DB + function bnpDRShiftTo(n, r) { + for (var i = n; i < this.t; ++i) r[i - n] = this[i]; + r.t = Math.max(this.t - n, 0); + r.s = this.s; + } + + // (protected) r = this << n + function bnpLShiftTo(n, r) { + var bs = n % this.DB; + var cbs = this.DB - bs; + var bm = (1 << cbs) - 1; + var ds = Math.floor(n / this.DB), + c = (this.s << bs) & this.DM, + i; + for (i = this.t - 1; i >= 0; --i) { + r[i + ds + 1] = (this[i] >> cbs) | c; + c = (this[i] & bm) << bs; + } + for (i = ds - 1; i >= 0; --i) r[i] = 0; + r[ds] = c; + r.t = this.t + ds + 1; + r.s = this.s; + r.clamp(); + } + + // (protected) r = this >> n + function bnpRShiftTo(n, r) { + r.s = this.s; + var ds = Math.floor(n / this.DB); + if (ds >= this.t) { + r.t = 0; + return; + } + var bs = n % this.DB; + var cbs = this.DB - bs; + var bm = (1 << bs) - 1; + r[0] = this[ds] >> bs; + for (var i = ds + 1; i < this.t; ++i) { + r[i - ds - 1] |= (this[i] & bm) << cbs; + r[i - ds] = this[i] >> bs; + } + if (bs > 0) r[this.t - ds - 1] |= (this.s & bm) << cbs; + r.t = this.t - ds; + r.clamp(); + } + + // (protected) r = this - a + function bnpSubTo(a, r) { + var i = 0, + c = 0, + m = Math.min(a.t, this.t); + while (i < m) { + c += this[i] - a[i]; + r[i++] = c & this.DM; + c >>= this.DB; + } + if (a.t < this.t) { + c -= a.s; + while (i < this.t) { + c += this[i]; + r[i++] = c & this.DM; + c >>= this.DB; + } + c += this.s; + } else { + c += this.s; + while (i < a.t) { + c -= a[i]; + r[i++] = c & this.DM; + c >>= this.DB; + } + c -= a.s; + } + r.s = c < 0 ? -1 : 0; + if (c < -1) r[i++] = this.DV + c; + else if (c > 0) r[i++] = c; + r.t = i; + r.clamp(); + } + + // (protected) r = this * a, r != this,a (HAC 14.12) + // "this" should be the larger one if appropriate. + function bnpMultiplyTo(a, r) { + var x = this.abs(), + y = a.abs(); + var i = x.t; + r.t = i + y.t; + while (--i >= 0) r[i] = 0; + for (i = 0; i < y.t; ++i) r[i + x.t] = x.am(0, y[i], r, i, 0, x.t); + r.s = 0; + r.clamp(); + if (this.s != a.s) BigInteger.ZERO.subTo(r, r); + } + + // (protected) r = this^2, r != this (HAC 14.16) + function bnpSquareTo(r) { + var x = this.abs(); + var i = (r.t = 2 * x.t); + while (--i >= 0) r[i] = 0; + for (i = 0; i < x.t - 1; ++i) { + var c = x.am(i, x[i], r, 2 * i, 0, 1); + if ( + (r[i + x.t] += x.am(i + 1, 2 * x[i], r, 2 * i + 1, c, x.t - i - 1)) >= + x.DV + ) { + r[i + x.t] -= x.DV; + r[i + x.t + 1] = 1; + } + } + if (r.t > 0) r[r.t - 1] += x.am(i, x[i], r, 2 * i, 0, 1); + r.s = 0; + r.clamp(); + } + + // (protected) divide this by m, quotient and remainder to q, r (HAC 14.20) + // r != q, this != m. q or r may be null. + function bnpDivRemTo(m, q, r) { + var pm = m.abs(); + if (pm.t <= 0) return; + var pt = this.abs(); + if (pt.t < pm.t) { + if (q != null) q.fromInt(0); + if (r != null) this.copyTo(r); + return; + } + if (r == null) r = nbi(); + var y = nbi(), + ts = this.s, + ms = m.s; + var nsh = this.DB - nbits(pm[pm.t - 1]); // normalize modulus + if (nsh > 0) { + pm.lShiftTo(nsh, y); + pt.lShiftTo(nsh, r); + } else { + pm.copyTo(y); + pt.copyTo(r); + } + var ys = y.t; + var y0 = y[ys - 1]; + if (y0 == 0) return; + var yt = y0 * (1 << this.F1) + (ys > 1 ? y[ys - 2] >> this.F2 : 0); + var d1 = this.FV / yt, + d2 = (1 << this.F1) / yt, + e = 1 << this.F2; + var i = r.t, + j = i - ys, + t = q == null ? nbi() : q; + y.dlShiftTo(j, t); + if (r.compareTo(t) >= 0) { + r[r.t++] = 1; + r.subTo(t, r); + } + BigInteger.ONE.dlShiftTo(ys, t); + t.subTo(y, y); // "negative" y so we can replace sub with am later + while (y.t < ys) y[y.t++] = 0; + while (--j >= 0) { + // Estimate quotient digit + var qd = + r[--i] == y0 ? this.DM : Math.floor(r[i] * d1 + (r[i - 1] + e) * d2); + if ((r[i] += y.am(0, qd, r, j, 0, ys)) < qd) { + // Try it out + y.dlShiftTo(j, t); + r.subTo(t, r); + while (r[i] < --qd) r.subTo(t, r); + } + } + if (q != null) { + r.drShiftTo(ys, q); + if (ts != ms) BigInteger.ZERO.subTo(q, q); + } + r.t = ys; + r.clamp(); + if (nsh > 0) r.rShiftTo(nsh, r); // Denormalize remainder + if (ts < 0) BigInteger.ZERO.subTo(r, r); + } + + // (public) this mod a + function bnMod(a) { + var r = nbi(); + this.abs().divRemTo(a, null, r); + if (this.s < 0 && r.compareTo(BigInteger.ZERO) > 0) a.subTo(r, r); + return r; + } + + // Modular reduction using "classic" algorithm + function Classic(m) { + this.m = m; + } + function cConvert(x) { + if (x.s < 0 || x.compareTo(this.m) >= 0) return x.mod(this.m); + else return x; + } + function cRevert(x) { + return x; + } + function cReduce(x) { + x.divRemTo(this.m, null, x); + } + function cMulTo(x, y, r) { + x.multiplyTo(y, r); + this.reduce(r); + } + function cSqrTo(x, r) { + x.squareTo(r); + this.reduce(r); + } + + Classic.prototype.convert = cConvert; + Classic.prototype.revert = cRevert; + Classic.prototype.reduce = cReduce; + Classic.prototype.mulTo = cMulTo; + Classic.prototype.sqrTo = cSqrTo; + + // (protected) return "-1/this % 2^DB"; useful for Mont. reduction + // justification: + // xy == 1 (mod m) + // xy = 1+km + // xy(2-xy) = (1+km)(1-km) + // x[y(2-xy)] = 1-k^2m^2 + // x[y(2-xy)] == 1 (mod m^2) + // if y is 1/x mod m, then y(2-xy) is 1/x mod m^2 + // should reduce x and y(2-xy) by m^2 at each step to keep size bounded. + // JS multiply "overflows" differently from C/C++, so care is needed here. + function bnpInvDigit() { + if (this.t < 1) return 0; + var x = this[0]; + if ((x & 1) == 0) return 0; + var y = x & 3; // y == 1/x mod 2^2 + y = (y * (2 - (x & 0xf) * y)) & 0xf; // y == 1/x mod 2^4 + y = (y * (2 - (x & 0xff) * y)) & 0xff; // y == 1/x mod 2^8 + y = (y * (2 - (((x & 0xffff) * y) & 0xffff))) & 0xffff; // y == 1/x mod 2^16 + // last step - calculate inverse mod DV directly; + // assumes 16 < DB <= 32 and assumes ability to handle 48-bit ints + y = (y * (2 - ((x * y) % this.DV))) % this.DV; // y == 1/x mod 2^dbits + // we really want the negative inverse, and -DV < y < DV + return y > 0 ? this.DV - y : -y; + } + + // Montgomery reduction + function Montgomery(m) { + this.m = m; + this.mp = m.invDigit(); + this.mpl = this.mp & 0x7fff; + this.mph = this.mp >> 15; + this.um = (1 << (m.DB - 15)) - 1; + this.mt2 = 2 * m.t; + } + + // xR mod m + function montConvert(x) { + var r = nbi(); + x.abs().dlShiftTo(this.m.t, r); + r.divRemTo(this.m, null, r); + if (x.s < 0 && r.compareTo(BigInteger.ZERO) > 0) this.m.subTo(r, r); + return r; + } + + // x/R mod m + function montRevert(x) { + var r = nbi(); + x.copyTo(r); + this.reduce(r); + return r; + } + + // x = x/R mod m (HAC 14.32) + function montReduce(x) { + while ( + x.t <= this.mt2 // pad x so am has enough room later + ) + x[x.t++] = 0; + for (var i = 0; i < this.m.t; ++i) { + // faster way of calculating u0 = x[i]*mp mod DV + var j = x[i] & 0x7fff; + var u0 = + (j * this.mpl + + (((j * this.mph + (x[i] >> 15) * this.mpl) & this.um) << 15)) & + x.DM; + // use am to combine the multiply-shift-add into one call + j = i + this.m.t; + x[j] += this.m.am(0, u0, x, i, 0, this.m.t); + // propagate carry + while (x[j] >= x.DV) { + x[j] -= x.DV; + x[++j]++; + } + } + x.clamp(); + x.drShiftTo(this.m.t, x); + if (x.compareTo(this.m) >= 0) x.subTo(this.m, x); + } + + // r = "x^2/R mod m"; x != r + function montSqrTo(x, r) { + x.squareTo(r); + this.reduce(r); + } + + // r = "xy/R mod m"; x,y != r + function montMulTo(x, y, r) { + x.multiplyTo(y, r); + this.reduce(r); + } + + Montgomery.prototype.convert = montConvert; + Montgomery.prototype.revert = montRevert; + Montgomery.prototype.reduce = montReduce; + Montgomery.prototype.mulTo = montMulTo; + Montgomery.prototype.sqrTo = montSqrTo; + + // (protected) true iff this is even + function bnpIsEven() { + return (this.t > 0 ? this[0] & 1 : this.s) == 0; + } + + // (protected) this^e, e < 2^32, doing sqr and mul with "r" (HAC 14.79) + function bnpExp(e, z) { + if (e > 0xffffffff || e < 1) return BigInteger.ONE; + var r = nbi(), + r2 = nbi(), + g = z.convert(this), + i = nbits(e) - 1; + g.copyTo(r); + while (--i >= 0) { + z.sqrTo(r, r2); + if ((e & (1 << i)) > 0) z.mulTo(r2, g, r); + else { + var t = r; + r = r2; + r2 = t; + } + } + return z.revert(r); + } + + // (public) this^e % m, 0 <= e < 2^32 + function bnModPowInt(e, m) { + var z; + if (e < 256 || m.isEven()) z = new Classic(m); + else z = new Montgomery(m); + return this.exp(e, z); + } + + // protected + BigInteger.prototype.copyTo = bnpCopyTo; + BigInteger.prototype.fromInt = bnpFromInt; + BigInteger.prototype.fromString = bnpFromString; + BigInteger.prototype.clamp = bnpClamp; + BigInteger.prototype.dlShiftTo = bnpDLShiftTo; + BigInteger.prototype.drShiftTo = bnpDRShiftTo; + BigInteger.prototype.lShiftTo = bnpLShiftTo; + BigInteger.prototype.rShiftTo = bnpRShiftTo; + BigInteger.prototype.subTo = bnpSubTo; + BigInteger.prototype.multiplyTo = bnpMultiplyTo; + BigInteger.prototype.squareTo = bnpSquareTo; + BigInteger.prototype.divRemTo = bnpDivRemTo; + BigInteger.prototype.invDigit = bnpInvDigit; + BigInteger.prototype.isEven = bnpIsEven; + BigInteger.prototype.exp = bnpExp; + + // public + BigInteger.prototype.toString = bnToString; + BigInteger.prototype.negate = bnNegate; + BigInteger.prototype.abs = bnAbs; + BigInteger.prototype.compareTo = bnCompareTo; + BigInteger.prototype.bitLength = bnBitLength; + BigInteger.prototype.mod = bnMod; + BigInteger.prototype.modPowInt = bnModPowInt; + + // "constants" + BigInteger.ZERO = nbv(0); + BigInteger.ONE = nbv(1); + BigInteger.valueOf = nbv; + + // Copyright (c) 2005-2009 Tom Wu + // All Rights Reserved. + // See "LICENSE" for details. + + // Extended JavaScript BN functions, required for RSA private ops. + + // Version 1.1: new BigInteger("0", 10) returns "proper" zero + // Version 1.2: square() API, isProbablePrime fix + + // (public) + function bnClone() { + var r = nbi(); + this.copyTo(r); + return r; + } + + // (public) return value as integer + function bnIntValue() { + if (this.s < 0) { + if (this.t == 1) return this[0] - this.DV; + else if (this.t == 0) return -1; + } else if (this.t == 1) return this[0]; + else if (this.t == 0) return 0; + // assumes 16 < DB < 32 + return ((this[1] & ((1 << (32 - this.DB)) - 1)) << this.DB) | this[0]; + } + + // (public) return value as byte + function bnByteValue() { + return this.t == 0 ? this.s : (this[0] << 24) >> 24; + } + + // (public) return value as short (assumes DB>=16) + function bnShortValue() { + return this.t == 0 ? this.s : (this[0] << 16) >> 16; + } + + // (protected) return x s.t. r^x < DV + function bnpChunkSize(r) { + return Math.floor((Math.LN2 * this.DB) / Math.log(r)); + } + + // (public) 0 if this == 0, 1 if this > 0 + function bnSigNum() { + if (this.s < 0) return -1; + else if (this.t <= 0 || (this.t == 1 && this[0] <= 0)) return 0; + else return 1; + } + + // (protected) convert to radix string + function bnpToRadix(b) { + if (b == null) b = 10; + if (this.signum() == 0 || b < 2 || b > 36) return '0'; + var cs = this.chunkSize(b); + var a = Math.pow(b, cs); + var d = nbv(a), + y = nbi(), + z = nbi(), + r = ''; + this.divRemTo(d, y, z); + while (y.signum() > 0) { + r = (a + z.intValue()).toString(b).substr(1) + r; + y.divRemTo(d, y, z); + } + return z.intValue().toString(b) + r; + } + + // (protected) convert from radix string + function bnpFromRadix(s, b) { + this.fromInt(0); + if (b == null) b = 10; + var cs = this.chunkSize(b); + var d = Math.pow(b, cs), + mi = false, + j = 0, + w = 0; + for (var i = 0; i < s.length; ++i) { + var x = intAt(s, i); + if (x < 0) { + if (s.charAt(i) == '-' && this.signum() == 0) mi = true; + continue; + } + w = b * w + x; + if (++j >= cs) { + this.dMultiply(d); + this.dAddOffset(w, 0); + j = 0; + w = 0; + } + } + if (j > 0) { + this.dMultiply(Math.pow(b, j)); + this.dAddOffset(w, 0); + } + if (mi) BigInteger.ZERO.subTo(this, this); + } + + // (protected) alternate constructor + function bnpFromNumber(a, b, c) { + if ('number' == typeof b) { + // new BigInteger(int,int,RNG) + if (a < 2) this.fromInt(1); + else { + this.fromNumber(a, c); + if (!this.testBit(a - 1)) + // force MSB set + this.bitwiseTo(BigInteger.ONE.shiftLeft(a - 1), op_or, this); + if (this.isEven()) this.dAddOffset(1, 0); // force odd + while (!this.isProbablePrime(b)) { + this.dAddOffset(2, 0); + if (this.bitLength() > a) + this.subTo(BigInteger.ONE.shiftLeft(a - 1), this); + } + } + } else { + // new BigInteger(int,RNG) + var x = new Array(), + t = a & 7; + x.length = (a >> 3) + 1; + b.nextBytes(x); + if (t > 0) x[0] &= (1 << t) - 1; + else x[0] = 0; + this.fromString(x, 256); + } + } + + // (public) convert to bigendian byte array + function bnToByteArray() { + var i = this.t, + r = new Array(); + r[0] = this.s; + var p = this.DB - ((i * this.DB) % 8), + d, + k = 0; + if (i-- > 0) { + if (p < this.DB && (d = this[i] >> p) != (this.s & this.DM) >> p) + r[k++] = d | (this.s << (this.DB - p)); + while (i >= 0) { + if (p < 8) { + d = (this[i] & ((1 << p) - 1)) << (8 - p); + d |= this[--i] >> (p += this.DB - 8); + } else { + d = (this[i] >> (p -= 8)) & 0xff; + if (p <= 0) { + p += this.DB; + --i; + } + } + if ((d & 0x80) != 0) d |= -256; + if (k == 0 && (this.s & 0x80) != (d & 0x80)) ++k; + if (k > 0 || d != this.s) r[k++] = d; + } + } + return r; + } + + function bnEquals(a) { + return this.compareTo(a) == 0; + } + function bnMin(a) { + return this.compareTo(a) < 0 ? this : a; + } + function bnMax(a) { + return this.compareTo(a) > 0 ? this : a; + } + + // (protected) r = this op a (bitwise) + function bnpBitwiseTo(a, op, r) { + var i, + f, + m = Math.min(a.t, this.t); + for (i = 0; i < m; ++i) r[i] = op(this[i], a[i]); + if (a.t < this.t) { + f = a.s & this.DM; + for (i = m; i < this.t; ++i) r[i] = op(this[i], f); + r.t = this.t; + } else { + f = this.s & this.DM; + for (i = m; i < a.t; ++i) r[i] = op(f, a[i]); + r.t = a.t; + } + r.s = op(this.s, a.s); + r.clamp(); + } + + // (public) this & a + function op_and(x, y) { + return x & y; + } + function bnAnd(a) { + var r = nbi(); + this.bitwiseTo(a, op_and, r); + return r; + } + + // (public) this | a + function op_or(x, y) { + return x | y; + } + function bnOr(a) { + var r = nbi(); + this.bitwiseTo(a, op_or, r); + return r; + } + + // (public) this ^ a + function op_xor(x, y) { + return x ^ y; + } + function bnXor(a) { + var r = nbi(); + this.bitwiseTo(a, op_xor, r); + return r; + } + + // (public) this & ~a + function op_andnot(x, y) { + return x & ~y; + } + function bnAndNot(a) { + var r = nbi(); + this.bitwiseTo(a, op_andnot, r); + return r; + } + + // (public) ~this + function bnNot() { + var r = nbi(); + for (var i = 0; i < this.t; ++i) r[i] = this.DM & ~this[i]; + r.t = this.t; + r.s = ~this.s; + return r; + } + + // (public) this << n + function bnShiftLeft(n) { + var r = nbi(); + if (n < 0) this.rShiftTo(-n, r); + else this.lShiftTo(n, r); + return r; + } + + // (public) this >> n + function bnShiftRight(n) { + var r = nbi(); + if (n < 0) this.lShiftTo(-n, r); + else this.rShiftTo(n, r); + return r; + } + + // return index of lowest 1-bit in x, x < 2^31 + function lbit(x) { + if (x == 0) return -1; + var r = 0; + if ((x & 0xffff) == 0) { + x >>= 16; + r += 16; + } + if ((x & 0xff) == 0) { + x >>= 8; + r += 8; + } + if ((x & 0xf) == 0) { + x >>= 4; + r += 4; + } + if ((x & 3) == 0) { + x >>= 2; + r += 2; + } + if ((x & 1) == 0) ++r; + return r; + } + + // (public) returns index of lowest 1-bit (or -1 if none) + function bnGetLowestSetBit() { + for (var i = 0; i < this.t; ++i) + if (this[i] != 0) return i * this.DB + lbit(this[i]); + if (this.s < 0) return this.t * this.DB; + return -1; + } + + // return number of 1 bits in x + function cbit(x) { + var r = 0; + while (x != 0) { + x &= x - 1; + ++r; + } + return r; + } + + // (public) return number of set bits + function bnBitCount() { + var r = 0, + x = this.s & this.DM; + for (var i = 0; i < this.t; ++i) r += cbit(this[i] ^ x); + return r; + } + + // (public) true iff nth bit is set + function bnTestBit(n) { + var j = Math.floor(n / this.DB); + if (j >= this.t) return this.s != 0; + return (this[j] & (1 << n % this.DB)) != 0; + } + + // (protected) this op (1<>= this.DB; + } + if (a.t < this.t) { + c += a.s; + while (i < this.t) { + c += this[i]; + r[i++] = c & this.DM; + c >>= this.DB; + } + c += this.s; + } else { + c += this.s; + while (i < a.t) { + c += a[i]; + r[i++] = c & this.DM; + c >>= this.DB; + } + c += a.s; + } + r.s = c < 0 ? -1 : 0; + if (c > 0) r[i++] = c; + else if (c < -1) r[i++] = this.DV + c; + r.t = i; + r.clamp(); + } + + // (public) this + a + function bnAdd(a) { + var r = nbi(); + this.addTo(a, r); + return r; + } + + // (public) this - a + function bnSubtract(a) { + var r = nbi(); + this.subTo(a, r); + return r; + } + + // (public) this * a + function bnMultiply(a) { + var r = nbi(); + this.multiplyTo(a, r); + return r; + } + + // (public) this^2 + function bnSquare() { + var r = nbi(); + this.squareTo(r); + return r; + } + + // (public) this / a + function bnDivide(a) { + var r = nbi(); + this.divRemTo(a, r, null); + return r; + } + + // (public) this % a + function bnRemainder(a) { + var r = nbi(); + this.divRemTo(a, null, r); + return r; + } + + // (public) [this/a,this%a] + function bnDivideAndRemainder(a) { + var q = nbi(), + r = nbi(); + this.divRemTo(a, q, r); + return new Array(q, r); + } + + // (protected) this *= n, this >= 0, 1 < n < DV + function bnpDMultiply(n) { + this[this.t] = this.am(0, n - 1, this, 0, 0, this.t); + ++this.t; + this.clamp(); + } + + // (protected) this += n << w words, this >= 0 + function bnpDAddOffset(n, w) { + if (n == 0) return; + while (this.t <= w) this[this.t++] = 0; + this[w] += n; + while (this[w] >= this.DV) { + this[w] -= this.DV; + if (++w >= this.t) this[this.t++] = 0; + ++this[w]; + } + } + + // A "null" reducer + function NullExp() { } + function nNop(x) { + return x; + } + function nMulTo(x, y, r) { + x.multiplyTo(y, r); + } + function nSqrTo(x, r) { + x.squareTo(r); + } + + NullExp.prototype.convert = nNop; + NullExp.prototype.revert = nNop; + NullExp.prototype.mulTo = nMulTo; + NullExp.prototype.sqrTo = nSqrTo; + + // (public) this^e + function bnPow(e) { + return this.exp(e, new NullExp()); + } + + // (protected) r = lower n words of "this * a", a.t <= n + // "this" should be the larger one if appropriate. + function bnpMultiplyLowerTo(a, n, r) { + var i = Math.min(this.t + a.t, n); + r.s = 0; // assumes a,this >= 0 + r.t = i; + while (i > 0) r[--i] = 0; + var j; + for (j = r.t - this.t; i < j; ++i) + r[i + this.t] = this.am(0, a[i], r, i, 0, this.t); + for (j = Math.min(a.t, n); i < j; ++i) this.am(0, a[i], r, i, 0, n - i); + r.clamp(); + } + + // (protected) r = "this * a" without lower n words, n > 0 + // "this" should be the larger one if appropriate. + function bnpMultiplyUpperTo(a, n, r) { + --n; + var i = (r.t = this.t + a.t - n); + r.s = 0; // assumes a,this >= 0 + while (--i >= 0) r[i] = 0; + for (i = Math.max(n - this.t, 0); i < a.t; ++i) + r[this.t + i - n] = this.am(n - i, a[i], r, 0, 0, this.t + i - n); + r.clamp(); + r.drShiftTo(1, r); + } + + // Barrett modular reduction + function Barrett(m) { + // setup Barrett + this.r2 = nbi(); + this.q3 = nbi(); + BigInteger.ONE.dlShiftTo(2 * m.t, this.r2); + this.mu = this.r2.divide(m); + this.m = m; + } + + function barrettConvert(x) { + if (x.s < 0 || x.t > 2 * this.m.t) return x.mod(this.m); + else if (x.compareTo(this.m) < 0) return x; + else { + var r = nbi(); + x.copyTo(r); + this.reduce(r); + return r; + } + } + + function barrettRevert(x) { + return x; + } + + // x = x mod m (HAC 14.42) + function barrettReduce(x) { + x.drShiftTo(this.m.t - 1, this.r2); + if (x.t > this.m.t + 1) { + x.t = this.m.t + 1; + x.clamp(); + } + this.mu.multiplyUpperTo(this.r2, this.m.t + 1, this.q3); + this.m.multiplyLowerTo(this.q3, this.m.t + 1, this.r2); + while (x.compareTo(this.r2) < 0) x.dAddOffset(1, this.m.t + 1); + x.subTo(this.r2, x); + while (x.compareTo(this.m) >= 0) x.subTo(this.m, x); + } + + // r = x^2 mod m; x != r + function barrettSqrTo(x, r) { + x.squareTo(r); + this.reduce(r); + } + + // r = x*y mod m; x,y != r + function barrettMulTo(x, y, r) { + x.multiplyTo(y, r); + this.reduce(r); + } + + Barrett.prototype.convert = barrettConvert; + Barrett.prototype.revert = barrettRevert; + Barrett.prototype.reduce = barrettReduce; + Barrett.prototype.mulTo = barrettMulTo; + Barrett.prototype.sqrTo = barrettSqrTo; + + // (public) this^e % m (HAC 14.85) + function bnModPow(e, m) { + var i = e.bitLength(), + k, + r = nbv(1), + z; + if (i <= 0) return r; + else if (i < 18) k = 1; + else if (i < 48) k = 3; + else if (i < 144) k = 4; + else if (i < 768) k = 5; + else k = 6; + if (i < 8) z = new Classic(m); + else if (m.isEven()) z = new Barrett(m); + else z = new Montgomery(m); + + // precomputation + var g = new Array(), + n = 3, + k1 = k - 1, + km = (1 << k) - 1; + g[1] = z.convert(this); + if (k > 1) { + var g2 = nbi(); + z.sqrTo(g[1], g2); + while (n <= km) { + g[n] = nbi(); + z.mulTo(g2, g[n - 2], g[n]); + n += 2; + } + } + + var j = e.t - 1, + w, + is1 = true, + r2 = nbi(), + t; + i = nbits(e[j]) - 1; + while (j >= 0) { + if (i >= k1) w = (e[j] >> (i - k1)) & km; + else { + w = (e[j] & ((1 << (i + 1)) - 1)) << (k1 - i); + if (j > 0) w |= e[j - 1] >> (this.DB + i - k1); + } + + n = k; + while ((w & 1) == 0) { + w >>= 1; + --n; + } + if ((i -= n) < 0) { + i += this.DB; + --j; + } + if (is1) { + // ret == 1, don't bother squaring or multiplying it + g[w].copyTo(r); + is1 = false; + } else { + while (n > 1) { + z.sqrTo(r, r2); + z.sqrTo(r2, r); + n -= 2; + } + if (n > 0) z.sqrTo(r, r2); + else { + t = r; + r = r2; + r2 = t; + } + z.mulTo(r2, g[w], r); + } + + while (j >= 0 && (e[j] & (1 << i)) == 0) { + z.sqrTo(r, r2); + t = r; + r = r2; + r2 = t; + if (--i < 0) { + i = this.DB - 1; + --j; + } + } + } + return z.revert(r); + } + + // (public) gcd(this,a) (HAC 14.54) + function bnGCD(a) { + var x = this.s < 0 ? this.negate() : this.clone(); + var y = a.s < 0 ? a.negate() : a.clone(); + if (x.compareTo(y) < 0) { + var t = x; + x = y; + y = t; + } + var i = x.getLowestSetBit(), + g = y.getLowestSetBit(); + if (g < 0) return x; + if (i < g) g = i; + if (g > 0) { + x.rShiftTo(g, x); + y.rShiftTo(g, y); + } + while (x.signum() > 0) { + if ((i = x.getLowestSetBit()) > 0) x.rShiftTo(i, x); + if ((i = y.getLowestSetBit()) > 0) y.rShiftTo(i, y); + if (x.compareTo(y) >= 0) { + x.subTo(y, x); + x.rShiftTo(1, x); + } else { + y.subTo(x, y); + y.rShiftTo(1, y); + } + } + if (g > 0) y.lShiftTo(g, y); + return y; + } + + // (protected) this % n, n < 2^26 + function bnpModInt(n) { + if (n <= 0) return 0; + var d = this.DV % n, + r = this.s < 0 ? n - 1 : 0; + if (this.t > 0) + if (d == 0) r = this[0] % n; + else for (var i = this.t - 1; i >= 0; --i) r = (d * r + this[i]) % n; + return r; + } + + // (public) 1/this % m (HAC 14.61) + function bnModInverse(m) { + var ac = m.isEven(); + if ((this.isEven() && ac) || m.signum() == 0) return BigInteger.ZERO; + var u = m.clone(), + v = this.clone(); + var a = nbv(1), + b = nbv(0), + c = nbv(0), + d = nbv(1); + while (u.signum() != 0) { + while (u.isEven()) { + u.rShiftTo(1, u); + if (ac) { + if (!a.isEven() || !b.isEven()) { + a.addTo(this, a); + b.subTo(m, b); + } + a.rShiftTo(1, a); + } else if (!b.isEven()) b.subTo(m, b); + b.rShiftTo(1, b); + } + while (v.isEven()) { + v.rShiftTo(1, v); + if (ac) { + if (!c.isEven() || !d.isEven()) { + c.addTo(this, c); + d.subTo(m, d); + } + c.rShiftTo(1, c); + } else if (!d.isEven()) d.subTo(m, d); + d.rShiftTo(1, d); + } + if (u.compareTo(v) >= 0) { + u.subTo(v, u); + if (ac) a.subTo(c, a); + b.subTo(d, b); + } else { + v.subTo(u, v); + if (ac) c.subTo(a, c); + d.subTo(b, d); + } + } + if (v.compareTo(BigInteger.ONE) != 0) return BigInteger.ZERO; + if (d.compareTo(m) >= 0) return d.subtract(m); + if (d.signum() < 0) d.addTo(m, d); + else return d; + if (d.signum() < 0) return d.add(m); + else return d; + } + + var lowprimes = [ + 2, + 3, + 5, + 7, + 11, + 13, + 17, + 19, + 23, + 29, + 31, + 37, + 41, + 43, + 47, + 53, + 59, + 61, + 67, + 71, + 73, + 79, + 83, + 89, + 97, + 101, + 103, + 107, + 109, + 113, + 127, + 131, + 137, + 139, + 149, + 151, + 157, + 163, + 167, + 173, + 179, + 181, + 191, + 193, + 197, + 199, + 211, + 223, + 227, + 229, + 233, + 239, + 241, + 251, + 257, + 263, + 269, + 271, + 277, + 281, + 283, + 293, + 307, + 311, + 313, + 317, + 331, + 337, + 347, + 349, + 353, + 359, + 367, + 373, + 379, + 383, + 389, + 397, + 401, + 409, + 419, + 421, + 431, + 433, + 439, + 443, + 449, + 457, + 461, + 463, + 467, + 479, + 487, + 491, + 499, + 503, + 509, + 521, + 523, + 541, + 547, + 557, + 563, + 569, + 571, + 577, + 587, + 593, + 599, + 601, + 607, + 613, + 617, + 619, + 631, + 641, + 643, + 647, + 653, + 659, + 661, + 673, + 677, + 683, + 691, + 701, + 709, + 719, + 727, + 733, + 739, + 743, + 751, + 757, + 761, + 769, + 773, + 787, + 797, + 809, + 811, + 821, + 823, + 827, + 829, + 839, + 853, + 857, + 859, + 863, + 877, + 881, + 883, + 887, + 907, + 911, + 919, + 929, + 937, + 941, + 947, + 953, + 967, + 971, + 977, + 983, + 991, + 997, + ]; + var lplim = (1 << 26) / lowprimes[lowprimes.length - 1]; + + // (public) test primality with certainty >= 1-.5^t + function bnIsProbablePrime(t) { + var i, + x = this.abs(); + if (x.t == 1 && x[0] <= lowprimes[lowprimes.length - 1]) { + for (i = 0; i < lowprimes.length; ++i) + if (x[0] == lowprimes[i]) return true; + return false; + } + if (x.isEven()) return false; + i = 1; + while (i < lowprimes.length) { + var m = lowprimes[i], + j = i + 1; + while (j < lowprimes.length && m < lplim) m *= lowprimes[j++]; + m = x.modInt(m); + while (i < j) if (m % lowprimes[i++] == 0) return false; + } + return x.millerRabin(t); + } + + // (protected) true if probably prime (HAC 4.24, Miller-Rabin) + function bnpMillerRabin(t) { + var n1 = this.subtract(BigInteger.ONE); + var k = n1.getLowestSetBit(); + if (k <= 0) return false; + var r = n1.shiftRight(k); + t = (t + 1) >> 1; + if (t > lowprimes.length) t = lowprimes.length; + var a = nbi(); + for (var i = 0; i < t; ++i) { + //Pick bases at random, instead of starting at 2 + a.fromInt(lowprimes[Math.floor(Math.random() * lowprimes.length)]); + var y = a.modPow(r, this); + if (y.compareTo(BigInteger.ONE) != 0 && y.compareTo(n1) != 0) { + var j = 1; + while (j++ < k && y.compareTo(n1) != 0) { + y = y.modPowInt(2, this); + if (y.compareTo(BigInteger.ONE) == 0) return false; + } + if (y.compareTo(n1) != 0) return false; + } + } + return true; + } + + // protected + BigInteger.prototype.chunkSize = bnpChunkSize; + BigInteger.prototype.toRadix = bnpToRadix; + BigInteger.prototype.fromRadix = bnpFromRadix; + BigInteger.prototype.fromNumber = bnpFromNumber; + BigInteger.prototype.bitwiseTo = bnpBitwiseTo; + BigInteger.prototype.changeBit = bnpChangeBit; + BigInteger.prototype.addTo = bnpAddTo; + BigInteger.prototype.dMultiply = bnpDMultiply; + BigInteger.prototype.dAddOffset = bnpDAddOffset; + BigInteger.prototype.multiplyLowerTo = bnpMultiplyLowerTo; + BigInteger.prototype.multiplyUpperTo = bnpMultiplyUpperTo; + BigInteger.prototype.modInt = bnpModInt; + BigInteger.prototype.millerRabin = bnpMillerRabin; + + // public + BigInteger.prototype.clone = bnClone; + BigInteger.prototype.intValue = bnIntValue; + BigInteger.prototype.byteValue = bnByteValue; + BigInteger.prototype.shortValue = bnShortValue; + BigInteger.prototype.signum = bnSigNum; + BigInteger.prototype.toByteArray = bnToByteArray; + BigInteger.prototype.equals = bnEquals; + BigInteger.prototype.min = bnMin; + BigInteger.prototype.max = bnMax; + BigInteger.prototype.and = bnAnd; + BigInteger.prototype.or = bnOr; + BigInteger.prototype.xor = bnXor; + BigInteger.prototype.andNot = bnAndNot; + BigInteger.prototype.not = bnNot; + BigInteger.prototype.shiftLeft = bnShiftLeft; + BigInteger.prototype.shiftRight = bnShiftRight; + BigInteger.prototype.getLowestSetBit = bnGetLowestSetBit; + BigInteger.prototype.bitCount = bnBitCount; + BigInteger.prototype.testBit = bnTestBit; + BigInteger.prototype.setBit = bnSetBit; + BigInteger.prototype.clearBit = bnClearBit; + BigInteger.prototype.flipBit = bnFlipBit; + BigInteger.prototype.add = bnAdd; + BigInteger.prototype.subtract = bnSubtract; + BigInteger.prototype.multiply = bnMultiply; + BigInteger.prototype.divide = bnDivide; + BigInteger.prototype.remainder = bnRemainder; + BigInteger.prototype.divideAndRemainder = bnDivideAndRemainder; + BigInteger.prototype.modPow = bnModPow; + BigInteger.prototype.modInverse = bnModInverse; + BigInteger.prototype.pow = bnPow; + BigInteger.prototype.gcd = bnGCD; + BigInteger.prototype.isProbablePrime = bnIsProbablePrime; + + // JSBN-specific extension + BigInteger.prototype.square = bnSquare; + + // Expose the Barrett function + BigInteger.prototype.Barrett = Barrett; + + // BigInteger interfaces not implemented in jsbn: + + // BigInteger(int signum, byte[] magnitude) + // double doubleValue() + // float floatValue() + // int hashCode() + // long longValue() + // static BigInteger valueOf(long val) + + // Imported from bitcoinjs-lib + + /** + * Turns a byte array into a big integer. + * + * This function will interpret a byte array as a big integer in big + * endian notation and ignore leading zeros. + */ + + BigInteger.fromByteArrayUnsigned = function (ba) { + + if (!ba.length) { + return new BigInteger.valueOf(0); + } else if (ba[0] & 0x80) { + // Prepend a zero so the BigInteger class doesn't mistake this + // for a negative integer. + return new BigInteger([0].concat(ba)); + } else { + return new BigInteger(ba); + } + }; + + /** + * Parse a signed big integer byte representation. + * + * For details on the format please see BigInteger.toByteArraySigned. + */ + + BigInteger.fromByteArraySigned = function (ba) { + // Check for negative value + if (ba[0] & 0x80) { + // Remove sign bit + ba[0] &= 0x7f; + + return BigInteger.fromByteArrayUnsigned(ba).negate(); + } else { + return BigInteger.fromByteArrayUnsigned(ba); + } + }; + + /** + * Returns a byte array representation of the big integer. + * + * This returns the absolute of the contained value in big endian + * form. A value of zero results in an empty array. + */ + + BigInteger.prototype.toByteArrayUnsigned = function () { + var ba = this.abs().toByteArray(); + + // Empty array, nothing to do + if (!ba.length) { + return ba; + } + + // remove leading 0 + if (ba[0] === 0) { + ba = ba.slice(1); + } + + // all values must be positive + for (var i = 0; i < ba.length; ++i) { + ba[i] = (ba[i] < 0) ? ba[i] + 256 : ba[i]; + } + + return ba; + }; + + /* + * Converts big integer to signed byte representation. + * + * The format for this value uses the most significant bit as a sign + * bit. If the most significant bit is already occupied by the + * absolute value, an extra byte is prepended and the sign bit is set + * there. + * + * Examples: + * + * 0 => 0x00 + * 1 => 0x01 + * -1 => 0x81 + * 127 => 0x7f + * -127 => 0xff + * 128 => 0x0080 + * -128 => 0x8080 + * 255 => 0x00ff + * -255 => 0x80ff + * 16300 => 0x3fac + * -16300 => 0xbfac + * 62300 => 0x00f35c + * -62300 => 0x80f35c + */ + + BigInteger.prototype.toByteArraySigned = function () { + var val = this.toByteArrayUnsigned(); + var neg = this.s < 0; + + // if the first bit is set, we always unshift + // either unshift 0x80 or 0x00 + if (val[0] & 0x80) { + val.unshift((neg) ? 0x80 : 0x00); + } + // if the first bit isn't set, set it if negative + else if (neg) { + val[0] |= 0x80; + } + + return val; + }; + + // Random number generator - requires a PRNG backend, e.g. prng4.js + + // For best results, put code like + // + // in your main HTML document. + + var rng_state; + var rng_pool; + var rng_pptr; + + // Mix in a 32-bit integer into the pool + function rng_seed_int(x) { + rng_pool[rng_pptr++] ^= x & 255; + rng_pool[rng_pptr++] ^= (x >> 8) & 255; + rng_pool[rng_pptr++] ^= (x >> 16) & 255; + rng_pool[rng_pptr++] ^= (x >> 24) & 255; + if (rng_pptr >= rng_psize) rng_pptr -= rng_psize; + } + + // Mix in the current time (w/milliseconds) into the pool + function rng_seed_time() { + rng_seed_int(new Date().getTime()); + } + + // Initialize the pool with junk if needed. + if (rng_pool == null) { + rng_pool = new Array(); + rng_pptr = 0; + var t; + if (typeof window !== 'undefined' && window.crypto) { + if (window.crypto.getRandomValues) { + // Use webcrypto if available + var ua = new Uint8Array(32); + window.crypto.getRandomValues(ua); + for (t = 0; t < 32; ++t) rng_pool[rng_pptr++] = ua[t]; + } else if ( + navigator.appName == 'Netscape' && + navigator.appVersion < '5' + ) { + // Extract entropy (256 bits) from NS4 RNG if available + var z = window.crypto.random(32); + for (t = 0; t < z.length; ++t) + rng_pool[rng_pptr++] = z.charCodeAt(t) & 255; + } + } + while (rng_pptr < rng_psize) { + // extract some randomness from Math.random() + t = Math.floor(65536 * Math.random()); + rng_pool[rng_pptr++] = t >>> 8; + rng_pool[rng_pptr++] = t & 255; + } + rng_pptr = 0; + rng_seed_time(); + //rng_seed_int(window.screenX); + //rng_seed_int(window.screenY); + } + + function rng_get_byte() { + if (rng_state == null) { + rng_seed_time(); + rng_state = prng_newstate(); + rng_state.init(rng_pool); + for (rng_pptr = 0; rng_pptr < rng_pool.length; ++rng_pptr) + rng_pool[rng_pptr] = 0; + rng_pptr = 0; + //rng_pool = null; + } + // TODO: allow reseeding after first request + return rng_state.next(); + } + + function rng_get_bytes(ba) { + var i; + for (i = 0; i < ba.length; ++i) ba[i] = rng_get_byte(); + } + + function SecureRandom() { } + + SecureRandom.prototype.nextBytes = rng_get_bytes; + + // prng4.js - uses Arcfour as a PRNG + + function Arcfour() { + this.i = 0; + this.j = 0; + this.S = new Array(); + } + + // Initialize arcfour context from key, an array of ints, each from [0..255] + function ARC4init(key) { + var i, j, t; + for (i = 0; i < 256; ++i) this.S[i] = i; + j = 0; + for (i = 0; i < 256; ++i) { + j = (j + this.S[i] + key[i % key.length]) & 255; + t = this.S[i]; + this.S[i] = this.S[j]; + this.S[j] = t; + } + this.i = 0; + this.j = 0; + } + + function ARC4next() { + var t; + this.i = (this.i + 1) & 255; + this.j = (this.j + this.S[this.i]) & 255; + t = this.S[this.i]; + this.S[this.i] = this.S[this.j]; + this.S[this.j] = t; + return this.S[(t + this.S[this.i]) & 255]; + } + + Arcfour.prototype.init = ARC4init; + Arcfour.prototype.next = ARC4next; + + // Plug in your RNG constructor here + function prng_newstate() { + return new Arcfour(); + } + + // Pool size must be a multiple of 4 and greater than 32. + // An array of bytes the size of the pool will be passed to init() + var rng_psize = 256; + + + + + /*! + * Basic Javascript Elliptic Curve implementation + * Ported loosely from BouncyCastle's Java EC code + * Only Fp curves implemented for now + * + * Copyright Tom Wu, bitaddress.org BSD License. + * http://www-cs-students.stanford.edu/~tjw/jsbn/LICENSE + */ + + // Constructor function of Global EllipticCurve object + var ec = function () { }; + + + // ---------------- + // ECFieldElementFp constructor + // q instanceof BigInteger + // x instanceof BigInteger + ec.FieldElementFp = function (q, x) { + this.x = x; + // TODO if(x.compareTo(q) >= 0) error + this.q = q; + }; + + ec.FieldElementFp.prototype.equals = function (other) { + if (other == this) return true; + return (this.q.equals(other.q) && this.x.equals(other.x)); + }; + + ec.FieldElementFp.prototype.toBigInteger = function () { + return this.x; + }; + + ec.FieldElementFp.prototype.negate = function () { + return new ec.FieldElementFp(this.q, this.x.negate().mod(this.q)); + }; + + ec.FieldElementFp.prototype.add = function (b) { + return new ec.FieldElementFp(this.q, this.x.add(b.toBigInteger()).mod(this.q)); + }; + + ec.FieldElementFp.prototype.subtract = function (b) { + return new ec.FieldElementFp(this.q, this.x.subtract(b.toBigInteger()).mod(this.q)); + }; + + ec.FieldElementFp.prototype.multiply = function (b) { + return new ec.FieldElementFp(this.q, this.x.multiply(b.toBigInteger()).mod(this.q)); + }; + + ec.FieldElementFp.prototype.square = function () { + return new ec.FieldElementFp(this.q, this.x.square().mod(this.q)); + }; + + ec.FieldElementFp.prototype.divide = function (b) { + return new ec.FieldElementFp(this.q, this.x.multiply(b.toBigInteger().modInverse(this.q)).mod(this.q)); + }; + + ec.FieldElementFp.prototype.getByteLength = function () { + return Math.floor((this.toBigInteger().bitLength() + 7) / 8); + }; + + // D.1.4 91 + /** + * return a sqrt root - the routine verifies that the calculation + * returns the right value - if none exists it returns null. + * + * Copyright (c) 2000 - 2011 The Legion Of The Bouncy Castle (http://www.bouncycastle.org) + * Ported to JavaScript by bitaddress.org + */ + ec.FieldElementFp.prototype.sqrt = function () { + if (!this.q.testBit(0)) throw new Error("even value of q"); + + // p mod 4 == 3 + if (this.q.testBit(1)) { + // z = g^(u+1) + p, p = 4u + 3 + var z = new ec.FieldElementFp(this.q, this.x.modPow(this.q.shiftRight(2).add(BigInteger.ONE), this.q)); + return z.square().equals(this) ? z : null; + } + + // p mod 4 == 1 + var qMinusOne = this.q.subtract(BigInteger.ONE); + var legendreExponent = qMinusOne.shiftRight(1); + if (!(this.x.modPow(legendreExponent, this.q).equals(BigInteger.ONE))) return null; + var u = qMinusOne.shiftRight(2); + var k = u.shiftLeft(1).add(BigInteger.ONE); + var Q = this.x; + var fourQ = Q.shiftLeft(2).mod(this.q); + var U, V; + + do { + var rand = new SecureRandom(); + var P; + do { + P = new BigInteger(this.q.bitLength(), rand); + } + while (P.compareTo(this.q) >= 0 || !(P.multiply(P).subtract(fourQ).modPow(legendreExponent, this.q).equals(qMinusOne))); + + var result = ec.FieldElementFp.fastLucasSequence(this.q, P, Q, k); + + U = result[0]; + V = result[1]; + if (V.multiply(V).mod(this.q).equals(fourQ)) { + // Integer division by 2, mod q + if (V.testBit(0)) { + V = V.add(this.q); + } + V = V.shiftRight(1); + return new ec.FieldElementFp(this.q, V); + } + } + while (U.equals(BigInteger.ONE) || U.equals(qMinusOne)); + + return null; + }; + + /* + * Copyright (c) 2000 - 2011 The Legion Of The Bouncy Castle (http://www.bouncycastle.org) + * Ported to JavaScript by bitaddress.org + */ + ec.FieldElementFp.fastLucasSequence = function (p, P, Q, k) { + // TODO Research and apply "common-multiplicand multiplication here" + + var n = k.bitLength(); + var s = k.getLowestSetBit(); + var Uh = BigInteger.ONE; + var Vl = BigInteger.TWO; + var Vh = P; + var Ql = BigInteger.ONE; + var Qh = BigInteger.ONE; + + for (var j = n - 1; j >= s + 1; --j) { + Ql = Ql.multiply(Qh).mod(p); + if (k.testBit(j)) { + Qh = Ql.multiply(Q).mod(p); + Uh = Uh.multiply(Vh).mod(p); + Vl = Vh.multiply(Vl).subtract(P.multiply(Ql)).mod(p); + Vh = Vh.multiply(Vh).subtract(Qh.shiftLeft(1)).mod(p); + } + else { + Qh = Ql; + Uh = Uh.multiply(Vl).subtract(Ql).mod(p); + Vh = Vh.multiply(Vl).subtract(P.multiply(Ql)).mod(p); + Vl = Vl.multiply(Vl).subtract(Ql.shiftLeft(1)).mod(p); + } + } + + Ql = Ql.multiply(Qh).mod(p); + Qh = Ql.multiply(Q).mod(p); + Uh = Uh.multiply(Vl).subtract(Ql).mod(p); + Vl = Vh.multiply(Vl).subtract(P.multiply(Ql)).mod(p); + Ql = Ql.multiply(Qh).mod(p); + + for (var j = 1; j <= s; ++j) { + Uh = Uh.multiply(Vl).mod(p); + Vl = Vl.multiply(Vl).subtract(Ql.shiftLeft(1)).mod(p); + Ql = Ql.multiply(Ql).mod(p); + } + + return [Uh, Vl]; + }; + + // ---------------- + // ECPointFp constructor + ec.PointFp = function (curve, x, y, z, compressed) { + this.curve = curve; + this.x = x; + this.y = y; + // Projective coordinates: either zinv == null or z * zinv == 1 + // z and zinv are just BigIntegers, not fieldElements + if (z == null) { + this.z = BigInteger.ONE; + } + else { + this.z = z; + } + this.zinv = null; + // compression flag + this.compressed = !!compressed; + }; + + ec.PointFp.prototype.getX = function () { + if (this.zinv == null) { + this.zinv = this.z.modInverse(this.curve.q); + } + var r = this.x.toBigInteger().multiply(this.zinv); + this.curve.reduce(r); + return this.curve.fromBigInteger(r); + }; + + ec.PointFp.prototype.getY = function () { + if (this.zinv == null) { + this.zinv = this.z.modInverse(this.curve.q); + } + var r = this.y.toBigInteger().multiply(this.zinv); + this.curve.reduce(r); + return this.curve.fromBigInteger(r); + }; + + ec.PointFp.prototype.equals = function (other) { + if (other == this) return true; + if (this.isInfinity()) return other.isInfinity(); + if (other.isInfinity()) return this.isInfinity(); + var u, v; + // u = Y2 * Z1 - Y1 * Z2 + u = other.y.toBigInteger().multiply(this.z).subtract(this.y.toBigInteger().multiply(other.z)).mod(this.curve.q); + if (!u.equals(BigInteger.ZERO)) return false; + // v = X2 * Z1 - X1 * Z2 + v = other.x.toBigInteger().multiply(this.z).subtract(this.x.toBigInteger().multiply(other.z)).mod(this.curve.q); + return v.equals(BigInteger.ZERO); + }; + + ec.PointFp.prototype.isInfinity = function () { + if ((this.x == null) && (this.y == null)) return true; + return this.z.equals(BigInteger.ZERO) && !this.y.toBigInteger().equals(BigInteger.ZERO); + }; + + ec.PointFp.prototype.negate = function () { + return new ec.PointFp(this.curve, this.x, this.y.negate(), this.z); + }; + + ec.PointFp.prototype.add = function (b) { + if (this.isInfinity()) return b; + if (b.isInfinity()) return this; + + // u = Y2 * Z1 - Y1 * Z2 + var u = b.y.toBigInteger().multiply(this.z).subtract(this.y.toBigInteger().multiply(b.z)).mod(this.curve.q); + // v = X2 * Z1 - X1 * Z2 + var v = b.x.toBigInteger().multiply(this.z).subtract(this.x.toBigInteger().multiply(b.z)).mod(this.curve.q); + + + if (BigInteger.ZERO.equals(v)) { + if (BigInteger.ZERO.equals(u)) { + return this.twice(); // this == b, so double + } + return this.curve.getInfinity(); // this = -b, so infinity + } + + var THREE = new BigInteger("3"); + var x1 = this.x.toBigInteger(); + var y1 = this.y.toBigInteger(); + var x2 = b.x.toBigInteger(); + var y2 = b.y.toBigInteger(); + + var v2 = v.square(); + var v3 = v2.multiply(v); + var x1v2 = x1.multiply(v2); + var zu2 = u.square().multiply(this.z); + + // x3 = v * (z2 * (z1 * u^2 - 2 * x1 * v^2) - v^3) + var x3 = zu2.subtract(x1v2.shiftLeft(1)).multiply(b.z).subtract(v3).multiply(v).mod(this.curve.q); + // y3 = z2 * (3 * x1 * u * v^2 - y1 * v^3 - z1 * u^3) + u * v^3 + var y3 = x1v2.multiply(THREE).multiply(u).subtract(y1.multiply(v3)).subtract(zu2.multiply(u)).multiply(b.z).add(u.multiply(v3)).mod(this.curve.q); + // z3 = v^3 * z1 * z2 + var z3 = v3.multiply(this.z).multiply(b.z).mod(this.curve.q); + + return new ec.PointFp(this.curve, this.curve.fromBigInteger(x3), this.curve.fromBigInteger(y3), z3); + }; + + ec.PointFp.prototype.twice = function () { + if (this.isInfinity()) return this; + if (this.y.toBigInteger().signum() == 0) return this.curve.getInfinity(); + + // TODO: optimized handling of constants + var THREE = new BigInteger("3"); + var x1 = this.x.toBigInteger(); + var y1 = this.y.toBigInteger(); + + var y1z1 = y1.multiply(this.z); + var y1sqz1 = y1z1.multiply(y1).mod(this.curve.q); + var a = this.curve.a.toBigInteger(); + + // w = 3 * x1^2 + a * z1^2 + var w = x1.square().multiply(THREE); + if (!BigInteger.ZERO.equals(a)) { + w = w.add(this.z.square().multiply(a)); + } + w = w.mod(this.curve.q); + //this.curve.reduce(w); + // x3 = 2 * y1 * z1 * (w^2 - 8 * x1 * y1^2 * z1) + var x3 = w.square().subtract(x1.shiftLeft(3).multiply(y1sqz1)).shiftLeft(1).multiply(y1z1).mod(this.curve.q); + // y3 = 4 * y1^2 * z1 * (3 * w * x1 - 2 * y1^2 * z1) - w^3 + var y3 = w.multiply(THREE).multiply(x1).subtract(y1sqz1.shiftLeft(1)).shiftLeft(2).multiply(y1sqz1).subtract(w.square().multiply(w)).mod(this.curve.q); + // z3 = 8 * (y1 * z1)^3 + var z3 = y1z1.square().multiply(y1z1).shiftLeft(3).mod(this.curve.q); + + return new ec.PointFp(this.curve, this.curve.fromBigInteger(x3), this.curve.fromBigInteger(y3), z3); + }; + + // Simple NAF (Non-Adjacent Form) multiplication algorithm + // TODO: modularize the multiplication algorithm + ec.PointFp.prototype.multiply = function (k) { + if (this.isInfinity()) return this; + if (k.signum() == 0) return this.curve.getInfinity(); + + var e = k; + var h = e.multiply(new BigInteger("3")); + + var neg = this.negate(); + var R = this; + + var i; + for (i = h.bitLength() - 2; i > 0; --i) { + R = R.twice(); + + var hBit = h.testBit(i); + var eBit = e.testBit(i); + + if (hBit != eBit) { + R = R.add(hBit ? this : neg); + } + } + + return R; + }; + + // Compute this*j + x*k (simultaneous multiplication) + ec.PointFp.prototype.multiplyTwo = function (j, x, k) { + var i; + if (j.bitLength() > k.bitLength()) + i = j.bitLength() - 1; + else + i = k.bitLength() - 1; + + var R = this.curve.getInfinity(); + var both = this.add(x); + while (i >= 0) { + R = R.twice(); + if (j.testBit(i)) { + if (k.testBit(i)) { + R = R.add(both); + } + else { + R = R.add(this); + } + } + else { + if (k.testBit(i)) { + R = R.add(x); + } + } + --i; + } + + return R; + }; + + // patched by bitaddress.org and Casascius for use with Bitcoin.ECKey + // patched by coretechs to support compressed public keys + ec.PointFp.prototype.getEncoded = function (compressed) { + var x = this.getX().toBigInteger(); + var y = this.getY().toBigInteger(); + var len = 32; // integerToBytes will zero pad if integer is less than 32 bytes. 32 bytes length is required by the Bitcoin protocol. + var enc = ec.integerToBytes(x, len); + + // when compressed prepend byte depending if y point is even or odd + if (compressed) { + if (y.isEven()) { + enc.unshift(0x02); + } + else { + enc.unshift(0x03); + } + } + else { + enc.unshift(0x04); + enc = enc.concat(ec.integerToBytes(y, len)); // uncompressed public key appends the bytes of the y point + } + return enc; + }; + + ec.PointFp.decodeFrom = function (curve, enc) { + var type = enc[0]; + var dataLen = enc.length - 1; + + // Extract x and y as byte arrays + var xBa = enc.slice(1, 1 + dataLen / 2); + var yBa = enc.slice(1 + dataLen / 2, 1 + dataLen); + + // Prepend zero byte to prevent interpretation as negative integer + xBa.unshift(0); + yBa.unshift(0); + + // Convert to BigIntegers + var x = new BigInteger(xBa); + var y = new BigInteger(yBa); + + // Return point + return new ec.PointFp(curve, curve.fromBigInteger(x), curve.fromBigInteger(y)); + }; + + ec.PointFp.prototype.add2D = function (b) { + if (this.isInfinity()) return b; + if (b.isInfinity()) return this; + + if (this.x.equals(b.x)) { + if (this.y.equals(b.y)) { + // this = b, i.e. this must be doubled + return this.twice(); + } + // this = -b, i.e. the result is the point at infinity + return this.curve.getInfinity(); + } + + var x_x = b.x.subtract(this.x); + var y_y = b.y.subtract(this.y); + var gamma = y_y.divide(x_x); + + var x3 = gamma.square().subtract(this.x).subtract(b.x); + var y3 = gamma.multiply(this.x.subtract(x3)).subtract(this.y); + + return new ec.PointFp(this.curve, x3, y3); + }; + + ec.PointFp.prototype.twice2D = function () { + if (this.isInfinity()) return this; + if (this.y.toBigInteger().signum() == 0) { + // if y1 == 0, then (x1, y1) == (x1, -y1) + // and hence this = -this and thus 2(x1, y1) == infinity + return this.curve.getInfinity(); + } + + var TWO = this.curve.fromBigInteger(BigInteger.valueOf(2)); + var THREE = this.curve.fromBigInteger(BigInteger.valueOf(3)); + var gamma = this.x.square().multiply(THREE).add(this.curve.a).divide(this.y.multiply(TWO)); + + var x3 = gamma.square().subtract(this.x.multiply(TWO)); + var y3 = gamma.multiply(this.x.subtract(x3)).subtract(this.y); + + return new ec.PointFp(this.curve, x3, y3); + }; + + ec.PointFp.prototype.multiply2D = function (k) { + if (this.isInfinity()) return this; + if (k.signum() == 0) return this.curve.getInfinity(); + + var e = k; + var h = e.multiply(new BigInteger("3")); + + var neg = this.negate(); + var R = this; + + var i; + for (i = h.bitLength() - 2; i > 0; --i) { + R = R.twice(); + + var hBit = h.testBit(i); + var eBit = e.testBit(i); + + if (hBit != eBit) { + R = R.add2D(hBit ? this : neg); + } + } + + return R; + }; + + ec.PointFp.prototype.isOnCurve = function () { + var x = this.getX().toBigInteger(); + var y = this.getY().toBigInteger(); + var a = this.curve.getA().toBigInteger(); + var b = this.curve.getB().toBigInteger(); + var n = this.curve.getQ(); + var lhs = y.multiply(y).mod(n); + var rhs = x.multiply(x).multiply(x).add(a.multiply(x)).add(b).mod(n); + return lhs.equals(rhs); + }; + + ec.PointFp.prototype.toString = function () { + return '(' + this.getX().toBigInteger().toString() + ',' + this.getY().toBigInteger().toString() + ')'; + }; + + /** + * Validate an elliptic curve point. + * + * See SEC 1, section 3.2.2.1: Elliptic Curve Public Key Validation Primitive + */ + ec.PointFp.prototype.validate = function () { + var n = this.curve.getQ(); + + // Check Q != O + if (this.isInfinity()) { + throw new Error("Point is at infinity."); + } + + // Check coordinate bounds + var x = this.getX().toBigInteger(); + var y = this.getY().toBigInteger(); + if (x.compareTo(BigInteger.ONE) < 0 || x.compareTo(n.subtract(BigInteger.ONE)) > 0) { + throw new Error('x coordinate out of bounds'); + } + if (y.compareTo(BigInteger.ONE) < 0 || y.compareTo(n.subtract(BigInteger.ONE)) > 0) { + throw new Error('y coordinate out of bounds'); + } + + // Check y^2 = x^3 + ax + b (mod n) + if (!this.isOnCurve()) { + throw new Error("Point is not on the curve."); + } + + // Check nQ = 0 (Q is a scalar multiple of G) + if (this.multiply(n).isInfinity()) { + // TODO: This check doesn't work - fix. + throw new Error("Point is not a scalar multiple of G."); + } + + return true; + }; + + + + + // ---------------- + // ECCurveFp constructor + ec.CurveFp = function (q, a, b) { + this.q = q; + this.a = this.fromBigInteger(a); + this.b = this.fromBigInteger(b); + this.infinity = new ec.PointFp(this, null, null); + this.reducer = new Barrett(this.q); + } + + ec.CurveFp.prototype.getQ = function () { + return this.q; + }; + + ec.CurveFp.prototype.getA = function () { + return this.a; + }; + + ec.CurveFp.prototype.getB = function () { + return this.b; + }; + + ec.CurveFp.prototype.equals = function (other) { + if (other == this) return true; + return (this.q.equals(other.q) && this.a.equals(other.a) && this.b.equals(other.b)); + }; + + ec.CurveFp.prototype.getInfinity = function () { + return this.infinity; + }; + + ec.CurveFp.prototype.fromBigInteger = function (x) { + return new ec.FieldElementFp(this.q, x); + }; + + ec.CurveFp.prototype.reduce = function (x) { + this.reducer.reduce(x); + }; + + // for now, work with hex strings because they're easier in JS + // compressed support added by bitaddress.org + ec.CurveFp.prototype.decodePointHex = function (s) { + var firstByte = parseInt(s.substr(0, 2), 16); + switch (firstByte) { // first byte + case 0: + return this.infinity; + case 2: // compressed + case 3: // compressed + var yTilde = firstByte & 1; + var xHex = s.substr(2, s.length - 2); + var X1 = new BigInteger(xHex, 16); + return this.decompressPoint(yTilde, X1); + case 4: // uncompressed + case 6: // hybrid + case 7: // hybrid + var len = (s.length - 2) / 2; + var xHex = s.substr(2, len); + var yHex = s.substr(len + 2, len); + + return new ec.PointFp(this, + this.fromBigInteger(new BigInteger(xHex, 16)), + this.fromBigInteger(new BigInteger(yHex, 16))); + + default: // unsupported + return null; + } + }; + + ec.CurveFp.prototype.encodePointHex = function (p) { + if (p.isInfinity()) return "00"; + var xHex = p.getX().toBigInteger().toString(16); + var yHex = p.getY().toBigInteger().toString(16); + var oLen = this.getQ().toString(16).length; + if ((oLen % 2) != 0) oLen++; + while (xHex.length < oLen) { + xHex = "0" + xHex; + } + while (yHex.length < oLen) { + yHex = "0" + yHex; + } + return "04" + xHex + yHex; + }; + + /* + * Copyright (c) 2000 - 2011 The Legion Of The Bouncy Castle (http://www.bouncycastle.org) + * Ported to JavaScript by bitaddress.org + * + * Number yTilde + * BigInteger X1 + */ + ec.CurveFp.prototype.decompressPoint = function (yTilde, X1) { + var x = this.fromBigInteger(X1); + var alpha = x.multiply(x.square().add(this.getA())).add(this.getB()); + var beta = alpha.sqrt(); + // if we can't find a sqrt we haven't got a point on the curve - run! + if (beta == null) throw new Error("Invalid point compression"); + var betaValue = beta.toBigInteger(); + var bit0 = betaValue.testBit(0) ? 1 : 0; + if (bit0 != yTilde) { + // Use the other root + beta = this.fromBigInteger(this.getQ().subtract(betaValue)); + } + return new ec.PointFp(this, x, beta, null, true); + }; + + + ec.fromHex = function (s) { return new BigInteger(s, 16); }; + + ec.integerToBytes = function (i, len) { + var bytes = i.toByteArrayUnsigned(); + if (len < bytes.length) { + bytes = bytes.slice(bytes.length - len); + } else while (len > bytes.length) { + bytes.unshift(0); + } + return bytes; + }; + + + // Named EC curves + // ---------------- + // X9ECParameters constructor + ec.X9Parameters = function (curve, g, n, h) { + this.curve = curve; + this.g = g; + this.n = n; + this.h = h; + } + ec.X9Parameters.prototype.getCurve = function () { return this.curve; }; + ec.X9Parameters.prototype.getG = function () { return this.g; }; + ec.X9Parameters.prototype.getN = function () { return this.n; }; + ec.X9Parameters.prototype.getH = function () { return this.h; }; + + // secp256k1 is the Curve used by Bitcoin + ec.secNamedCurves = { + // used by Bitcoin + "secp256k1": function () { + // p = 2^256 - 2^32 - 2^9 - 2^8 - 2^7 - 2^6 - 2^4 - 1 + var p = ec.fromHex("FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEFFFFFC2F"); + var a = BigInteger.ZERO; + var b = ec.fromHex("7"); + var n = ec.fromHex("FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141"); + var h = BigInteger.ONE; + var curve = new ec.CurveFp(p, a, b); + var G = curve.decodePointHex("04" + + "79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798" + + "483ADA7726A3C4655DA4FBFC0E1108A8FD17B448A68554199C47D08FFB10D4B8"); + return new ec.X9Parameters(curve, G, n, h); + } + }; + + // secp256k1 called by Bitcoin's ECKEY + ec.getSECCurveByName = function (name) { + if (ec.secNamedCurves[name] == undefined) return null; + return ec.secNamedCurves[name](); + } + + if (typeof exports !== 'undefined') { + exports = module.exports = { + default: ec, + EllipticCurve: ec, + BigInteger: BigInteger + }; + } else { + this.ecbn = { + EllipticCurve: ec, + BigInteger: BigInteger + }; + } + +}).call(this); \ No newline at end of file diff --git a/qortal-ui-crypto/api/bitcoin/jsbn.js b/qortal-ui-crypto/api/bitcoin/jsbn.js new file mode 100644 index 00000000..0e306853 --- /dev/null +++ b/qortal-ui-crypto/api/bitcoin/jsbn.js @@ -0,0 +1,1940 @@ +(function () { + // Copyright (c) 2005 Tom Wu + // All Rights Reserved. + // See "LICENSE" for details. + + // Basic JavaScript BN library - subset useful for RSA encryption. + + // Bits per digit + var dbits; + + // JavaScript engine analysis + var canary = 0xdeadbeefcafe; + var j_lm = (canary & 0xffffff) == 0xefcafe; + + // (public) Constructor + function BigInteger(a, b, c) { + if (a != null) + if ('number' == typeof a) this.fromNumber(a, b, c); + else if (b == null && 'string' != typeof a) this.fromString(a, 256); + else this.fromString(a, b); + } + + // return new, unset BigInteger + function nbi() { + return new BigInteger(null); + } + + // am: Compute w_j += (x*this_i), propagate carries, + // c is initial carry, returns final carry. + // c < 3*dvalue, x < 2*dvalue, this_i < dvalue + // We need to select the fastest one that works in this environment. + + // am1: use a single mult and divide to get the high bits, + // max digit bits should be 26 because + // max internal value = 2*dvalue^2-2*dvalue (< 2^53) + function am1(i, x, w, j, c, n) { + while (--n >= 0) { + var v = x * this[i++] + w[j] + c; + c = Math.floor(v / 0x4000000); + w[j++] = v & 0x3ffffff; + } + return c; + } + // am2 avoids a big mult-and-extract completely. + // Max digit bits should be <= 30 because we do bitwise ops + // on values up to 2*hdvalue^2-hdvalue-1 (< 2^31) + function am2(i, x, w, j, c, n) { + var xl = x & 0x7fff, + xh = x >> 15; + while (--n >= 0) { + var l = this[i] & 0x7fff; + var h = this[i++] >> 15; + var m = xh * l + h * xl; + l = xl * l + ((m & 0x7fff) << 15) + w[j] + (c & 0x3fffffff); + c = (l >>> 30) + (m >>> 15) + xh * h + (c >>> 30); + w[j++] = l & 0x3fffffff; + } + return c; + } + // Alternately, set max digit bits to 28 since some + // browsers slow down when dealing with 32-bit numbers. + function am3(i, x, w, j, c, n) { + var xl = x & 0x3fff, + xh = x >> 14; + while (--n >= 0) { + var l = this[i] & 0x3fff; + var h = this[i++] >> 14; + var m = xh * l + h * xl; + l = xl * l + ((m & 0x3fff) << 14) + w[j] + c; + c = (l >> 28) + (m >> 14) + xh * h; + w[j++] = l & 0xfffffff; + } + return c; + } + var inBrowser = typeof navigator !== 'undefined'; + if (inBrowser && j_lm && navigator.appName == 'Microsoft Internet Explorer') { + BigInteger.prototype.am = am2; + dbits = 30; + } else if (inBrowser && j_lm && navigator.appName != 'Netscape') { + BigInteger.prototype.am = am1; + dbits = 26; + } else { + // Mozilla/Netscape seems to prefer am3 + BigInteger.prototype.am = am3; + dbits = 28; + } + + BigInteger.prototype.DB = dbits; + BigInteger.prototype.DM = (1 << dbits) - 1; + BigInteger.prototype.DV = 1 << dbits; + + var BI_FP = 52; + BigInteger.prototype.FV = Math.pow(2, BI_FP); + BigInteger.prototype.F1 = BI_FP - dbits; + BigInteger.prototype.F2 = 2 * dbits - BI_FP; + + // Digit conversions + var BI_RM = '0123456789abcdefghijklmnopqrstuvwxyz'; + var BI_RC = new Array(); + var rr, vv; + rr = '0'.charCodeAt(0); + for (vv = 0; vv <= 9; ++vv) BI_RC[rr++] = vv; + rr = 'a'.charCodeAt(0); + for (vv = 10; vv < 36; ++vv) BI_RC[rr++] = vv; + rr = 'A'.charCodeAt(0); + for (vv = 10; vv < 36; ++vv) BI_RC[rr++] = vv; + + function int2char(n) { + return BI_RM.charAt(n); + } + function intAt(s, i) { + var c = BI_RC[s.charCodeAt(i)]; + return c == null ? -1 : c; + } + + // (protected) copy this to r + function bnpCopyTo(r) { + for (var i = this.t - 1; i >= 0; --i) r[i] = this[i]; + r.t = this.t; + r.s = this.s; + } + + // (protected) set from integer value x, -DV <= x < DV + function bnpFromInt(x) { + this.t = 1; + this.s = x < 0 ? -1 : 0; + if (x > 0) this[0] = x; + else if (x < -1) this[0] = x + this.DV; + else this.t = 0; + } + + // return bigint initialized to value + function nbv(i) { + var r = nbi(); + r.fromInt(i); + return r; + } + + // (protected) set from string and radix + function bnpFromString(s, b) { + // Auto-detect string notations + if (!b && s.length >= 2 && s[0] === '0') { + var isDetected = true; + switch (s[1]) { + case 'x': // Hexadecimal notation + b = 16; + break; + case 'b': // Binary notation + b = 2; + break; + case 'o': // Octal notation + b = 8; + break; + default: + isDetected = false; + } + + // Remove the notation string if any has been detected + if (isDetected) { + s = s.substr(2); + } + } + + var k; + if (b == 16) k = 4; + else if (b == 8) k = 3; + else if (b == 256) k = 8; + // byte array + else if (b == 2) k = 1; + else if (b == 32) k = 5; + else if (b == 4) k = 2; + else { + this.fromRadix(s, b); + return; + } + this.t = 0; + this.s = 0; + var i = s.length, + mi = false, + sh = 0; + while (--i >= 0) { + var x = k == 8 ? s[i] & 0xff : intAt(s, i); + if (x < 0) { + if (s.charAt(i) == '-') mi = true; + continue; + } + mi = false; + if (sh == 0) this[this.t++] = x; + else if (sh + k > this.DB) { + this[this.t - 1] |= (x & ((1 << (this.DB - sh)) - 1)) << sh; + this[this.t++] = x >> (this.DB - sh); + } else this[this.t - 1] |= x << sh; + sh += k; + if (sh >= this.DB) sh -= this.DB; + } + if (k == 8 && (s[0] & 0x80) != 0) { + this.s = -1; + if (sh > 0) this[this.t - 1] |= ((1 << (this.DB - sh)) - 1) << sh; + } + this.clamp(); + if (mi) BigInteger.ZERO.subTo(this, this); + } + + // (protected) clamp off excess high words + function bnpClamp() { + var c = this.s & this.DM; + while (this.t > 0 && this[this.t - 1] == c) --this.t; + } + + // (public) return string representation in given radix + function bnToString(b) { + if (this.s < 0) return '-' + this.negate().toString(b); + var k; + if (b == 16) k = 4; + else if (b == 8) k = 3; + else if (b == 2) k = 1; + else if (b == 32) k = 5; + else if (b == 4) k = 2; + else return this.toRadix(b); + var km = (1 << k) - 1, + d, + m = false, + r = '', + i = this.t; + var p = this.DB - ((i * this.DB) % k); + if (i-- > 0) { + if (p < this.DB && (d = this[i] >> p) > 0) { + m = true; + r = int2char(d); + } + while (i >= 0) { + if (p < k) { + d = (this[i] & ((1 << p) - 1)) << (k - p); + d |= this[--i] >> (p += this.DB - k); + } else { + d = (this[i] >> (p -= k)) & km; + if (p <= 0) { + p += this.DB; + --i; + } + } + if (d > 0) m = true; + if (m) r += int2char(d); + } + } + return m ? r : '0'; + } + + // (public) -this + function bnNegate() { + var r = nbi(); + BigInteger.ZERO.subTo(this, r); + return r; + } + + // (public) |this| + function bnAbs() { + return this.s < 0 ? this.negate() : this; + } + + // (public) return + if this > a, - if this < a, 0 if equal + function bnCompareTo(a) { + var r = this.s - a.s; + if (r != 0) return r; + var i = this.t; + r = i - a.t; + if (r != 0) return this.s < 0 ? -r : r; + while (--i >= 0) if ((r = this[i] - a[i]) != 0) return r; + return 0; + } + + // returns bit length of the integer x + function nbits(x) { + var r = 1, + t; + if ((t = x >>> 16) != 0) { + x = t; + r += 16; + } + if ((t = x >> 8) != 0) { + x = t; + r += 8; + } + if ((t = x >> 4) != 0) { + x = t; + r += 4; + } + if ((t = x >> 2) != 0) { + x = t; + r += 2; + } + if ((t = x >> 1) != 0) { + x = t; + r += 1; + } + return r; + } + + // (public) return the number of bits in "this" + function bnBitLength() { + if (this.t <= 0) return 0; + return ( + this.DB * (this.t - 1) + nbits(this[this.t - 1] ^ (this.s & this.DM)) + ); + } + + // (protected) r = this << n*DB + function bnpDLShiftTo(n, r) { + var i; + for (i = this.t - 1; i >= 0; --i) r[i + n] = this[i]; + for (i = n - 1; i >= 0; --i) r[i] = 0; + r.t = this.t + n; + r.s = this.s; + } + + // (protected) r = this >> n*DB + function bnpDRShiftTo(n, r) { + for (var i = n; i < this.t; ++i) r[i - n] = this[i]; + r.t = Math.max(this.t - n, 0); + r.s = this.s; + } + + // (protected) r = this << n + function bnpLShiftTo(n, r) { + var bs = n % this.DB; + var cbs = this.DB - bs; + var bm = (1 << cbs) - 1; + var ds = Math.floor(n / this.DB), + c = (this.s << bs) & this.DM, + i; + for (i = this.t - 1; i >= 0; --i) { + r[i + ds + 1] = (this[i] >> cbs) | c; + c = (this[i] & bm) << bs; + } + for (i = ds - 1; i >= 0; --i) r[i] = 0; + r[ds] = c; + r.t = this.t + ds + 1; + r.s = this.s; + r.clamp(); + } + + // (protected) r = this >> n + function bnpRShiftTo(n, r) { + r.s = this.s; + var ds = Math.floor(n / this.DB); + if (ds >= this.t) { + r.t = 0; + return; + } + var bs = n % this.DB; + var cbs = this.DB - bs; + var bm = (1 << bs) - 1; + r[0] = this[ds] >> bs; + for (var i = ds + 1; i < this.t; ++i) { + r[i - ds - 1] |= (this[i] & bm) << cbs; + r[i - ds] = this[i] >> bs; + } + if (bs > 0) r[this.t - ds - 1] |= (this.s & bm) << cbs; + r.t = this.t - ds; + r.clamp(); + } + + // (protected) r = this - a + function bnpSubTo(a, r) { + var i = 0, + c = 0, + m = Math.min(a.t, this.t); + while (i < m) { + c += this[i] - a[i]; + r[i++] = c & this.DM; + c >>= this.DB; + } + if (a.t < this.t) { + c -= a.s; + while (i < this.t) { + c += this[i]; + r[i++] = c & this.DM; + c >>= this.DB; + } + c += this.s; + } else { + c += this.s; + while (i < a.t) { + c -= a[i]; + r[i++] = c & this.DM; + c >>= this.DB; + } + c -= a.s; + } + r.s = c < 0 ? -1 : 0; + if (c < -1) r[i++] = this.DV + c; + else if (c > 0) r[i++] = c; + r.t = i; + r.clamp(); + } + + // (protected) r = this * a, r != this,a (HAC 14.12) + // "this" should be the larger one if appropriate. + function bnpMultiplyTo(a, r) { + var x = this.abs(), + y = a.abs(); + var i = x.t; + r.t = i + y.t; + while (--i >= 0) r[i] = 0; + for (i = 0; i < y.t; ++i) r[i + x.t] = x.am(0, y[i], r, i, 0, x.t); + r.s = 0; + r.clamp(); + if (this.s != a.s) BigInteger.ZERO.subTo(r, r); + } + + // (protected) r = this^2, r != this (HAC 14.16) + function bnpSquareTo(r) { + var x = this.abs(); + var i = (r.t = 2 * x.t); + while (--i >= 0) r[i] = 0; + for (i = 0; i < x.t - 1; ++i) { + var c = x.am(i, x[i], r, 2 * i, 0, 1); + if ( + (r[i + x.t] += x.am(i + 1, 2 * x[i], r, 2 * i + 1, c, x.t - i - 1)) >= + x.DV + ) { + r[i + x.t] -= x.DV; + r[i + x.t + 1] = 1; + } + } + if (r.t > 0) r[r.t - 1] += x.am(i, x[i], r, 2 * i, 0, 1); + r.s = 0; + r.clamp(); + } + + // (protected) divide this by m, quotient and remainder to q, r (HAC 14.20) + // r != q, this != m. q or r may be null. + function bnpDivRemTo(m, q, r) { + var pm = m.abs(); + if (pm.t <= 0) return; + var pt = this.abs(); + if (pt.t < pm.t) { + if (q != null) q.fromInt(0); + if (r != null) this.copyTo(r); + return; + } + if (r == null) r = nbi(); + var y = nbi(), + ts = this.s, + ms = m.s; + var nsh = this.DB - nbits(pm[pm.t - 1]); // normalize modulus + if (nsh > 0) { + pm.lShiftTo(nsh, y); + pt.lShiftTo(nsh, r); + } else { + pm.copyTo(y); + pt.copyTo(r); + } + var ys = y.t; + var y0 = y[ys - 1]; + if (y0 == 0) return; + var yt = y0 * (1 << this.F1) + (ys > 1 ? y[ys - 2] >> this.F2 : 0); + var d1 = this.FV / yt, + d2 = (1 << this.F1) / yt, + e = 1 << this.F2; + var i = r.t, + j = i - ys, + t = q == null ? nbi() : q; + y.dlShiftTo(j, t); + if (r.compareTo(t) >= 0) { + r[r.t++] = 1; + r.subTo(t, r); + } + BigInteger.ONE.dlShiftTo(ys, t); + t.subTo(y, y); // "negative" y so we can replace sub with am later + while (y.t < ys) y[y.t++] = 0; + while (--j >= 0) { + // Estimate quotient digit + var qd = + r[--i] == y0 ? this.DM : Math.floor(r[i] * d1 + (r[i - 1] + e) * d2); + if ((r[i] += y.am(0, qd, r, j, 0, ys)) < qd) { + // Try it out + y.dlShiftTo(j, t); + r.subTo(t, r); + while (r[i] < --qd) r.subTo(t, r); + } + } + if (q != null) { + r.drShiftTo(ys, q); + if (ts != ms) BigInteger.ZERO.subTo(q, q); + } + r.t = ys; + r.clamp(); + if (nsh > 0) r.rShiftTo(nsh, r); // Denormalize remainder + if (ts < 0) BigInteger.ZERO.subTo(r, r); + } + + // (public) this mod a + function bnMod(a) { + var r = nbi(); + this.abs().divRemTo(a, null, r); + if (this.s < 0 && r.compareTo(BigInteger.ZERO) > 0) a.subTo(r, r); + return r; + } + + // Modular reduction using "classic" algorithm + function Classic(m) { + this.m = m; + } + function cConvert(x) { + if (x.s < 0 || x.compareTo(this.m) >= 0) return x.mod(this.m); + else return x; + } + function cRevert(x) { + return x; + } + function cReduce(x) { + x.divRemTo(this.m, null, x); + } + function cMulTo(x, y, r) { + x.multiplyTo(y, r); + this.reduce(r); + } + function cSqrTo(x, r) { + x.squareTo(r); + this.reduce(r); + } + + Classic.prototype.convert = cConvert; + Classic.prototype.revert = cRevert; + Classic.prototype.reduce = cReduce; + Classic.prototype.mulTo = cMulTo; + Classic.prototype.sqrTo = cSqrTo; + + // (protected) return "-1/this % 2^DB"; useful for Mont. reduction + // justification: + // xy == 1 (mod m) + // xy = 1+km + // xy(2-xy) = (1+km)(1-km) + // x[y(2-xy)] = 1-k^2m^2 + // x[y(2-xy)] == 1 (mod m^2) + // if y is 1/x mod m, then y(2-xy) is 1/x mod m^2 + // should reduce x and y(2-xy) by m^2 at each step to keep size bounded. + // JS multiply "overflows" differently from C/C++, so care is needed here. + function bnpInvDigit() { + if (this.t < 1) return 0; + var x = this[0]; + if ((x & 1) == 0) return 0; + var y = x & 3; // y == 1/x mod 2^2 + y = (y * (2 - (x & 0xf) * y)) & 0xf; // y == 1/x mod 2^4 + y = (y * (2 - (x & 0xff) * y)) & 0xff; // y == 1/x mod 2^8 + y = (y * (2 - (((x & 0xffff) * y) & 0xffff))) & 0xffff; // y == 1/x mod 2^16 + // last step - calculate inverse mod DV directly; + // assumes 16 < DB <= 32 and assumes ability to handle 48-bit ints + y = (y * (2 - ((x * y) % this.DV))) % this.DV; // y == 1/x mod 2^dbits + // we really want the negative inverse, and -DV < y < DV + return y > 0 ? this.DV - y : -y; + } + + // Montgomery reduction + function Montgomery(m) { + this.m = m; + this.mp = m.invDigit(); + this.mpl = this.mp & 0x7fff; + this.mph = this.mp >> 15; + this.um = (1 << (m.DB - 15)) - 1; + this.mt2 = 2 * m.t; + } + + // xR mod m + function montConvert(x) { + var r = nbi(); + x.abs().dlShiftTo(this.m.t, r); + r.divRemTo(this.m, null, r); + if (x.s < 0 && r.compareTo(BigInteger.ZERO) > 0) this.m.subTo(r, r); + return r; + } + + // x/R mod m + function montRevert(x) { + var r = nbi(); + x.copyTo(r); + this.reduce(r); + return r; + } + + // x = x/R mod m (HAC 14.32) + function montReduce(x) { + while ( + x.t <= this.mt2 // pad x so am has enough room later + ) + x[x.t++] = 0; + for (var i = 0; i < this.m.t; ++i) { + // faster way of calculating u0 = x[i]*mp mod DV + var j = x[i] & 0x7fff; + var u0 = + (j * this.mpl + + (((j * this.mph + (x[i] >> 15) * this.mpl) & this.um) << 15)) & + x.DM; + // use am to combine the multiply-shift-add into one call + j = i + this.m.t; + x[j] += this.m.am(0, u0, x, i, 0, this.m.t); + // propagate carry + while (x[j] >= x.DV) { + x[j] -= x.DV; + x[++j]++; + } + } + x.clamp(); + x.drShiftTo(this.m.t, x); + if (x.compareTo(this.m) >= 0) x.subTo(this.m, x); + } + + // r = "x^2/R mod m"; x != r + function montSqrTo(x, r) { + x.squareTo(r); + this.reduce(r); + } + + // r = "xy/R mod m"; x,y != r + function montMulTo(x, y, r) { + x.multiplyTo(y, r); + this.reduce(r); + } + + Montgomery.prototype.convert = montConvert; + Montgomery.prototype.revert = montRevert; + Montgomery.prototype.reduce = montReduce; + Montgomery.prototype.mulTo = montMulTo; + Montgomery.prototype.sqrTo = montSqrTo; + + // (protected) true iff this is even + function bnpIsEven() { + return (this.t > 0 ? this[0] & 1 : this.s) == 0; + } + + // (protected) this^e, e < 2^32, doing sqr and mul with "r" (HAC 14.79) + function bnpExp(e, z) { + if (e > 0xffffffff || e < 1) return BigInteger.ONE; + var r = nbi(), + r2 = nbi(), + g = z.convert(this), + i = nbits(e) - 1; + g.copyTo(r); + while (--i >= 0) { + z.sqrTo(r, r2); + if ((e & (1 << i)) > 0) z.mulTo(r2, g, r); + else { + var t = r; + r = r2; + r2 = t; + } + } + return z.revert(r); + } + + // (public) this^e % m, 0 <= e < 2^32 + function bnModPowInt(e, m) { + var z; + if (e < 256 || m.isEven()) z = new Classic(m); + else z = new Montgomery(m); + return this.exp(e, z); + } + + // protected + BigInteger.prototype.copyTo = bnpCopyTo; + BigInteger.prototype.fromInt = bnpFromInt; + BigInteger.prototype.fromString = bnpFromString; + BigInteger.prototype.clamp = bnpClamp; + BigInteger.prototype.dlShiftTo = bnpDLShiftTo; + BigInteger.prototype.drShiftTo = bnpDRShiftTo; + BigInteger.prototype.lShiftTo = bnpLShiftTo; + BigInteger.prototype.rShiftTo = bnpRShiftTo; + BigInteger.prototype.subTo = bnpSubTo; + BigInteger.prototype.multiplyTo = bnpMultiplyTo; + BigInteger.prototype.squareTo = bnpSquareTo; + BigInteger.prototype.divRemTo = bnpDivRemTo; + BigInteger.prototype.invDigit = bnpInvDigit; + BigInteger.prototype.isEven = bnpIsEven; + BigInteger.prototype.exp = bnpExp; + + // public + BigInteger.prototype.toString = bnToString; + BigInteger.prototype.negate = bnNegate; + BigInteger.prototype.abs = bnAbs; + BigInteger.prototype.compareTo = bnCompareTo; + BigInteger.prototype.bitLength = bnBitLength; + BigInteger.prototype.mod = bnMod; + BigInteger.prototype.modPowInt = bnModPowInt; + + // "constants" + BigInteger.ZERO = nbv(0); + BigInteger.ONE = nbv(1); + BigInteger.valueOf = nbv; + + // Copyright (c) 2005-2009 Tom Wu + // All Rights Reserved. + // See "LICENSE" for details. + + // Extended JavaScript BN functions, required for RSA private ops. + + // Version 1.1: new BigInteger("0", 10) returns "proper" zero + // Version 1.2: square() API, isProbablePrime fix + + // (public) + function bnClone() { + var r = nbi(); + this.copyTo(r); + return r; + } + + // (public) return value as integer + function bnIntValue() { + if (this.s < 0) { + if (this.t == 1) return this[0] - this.DV; + else if (this.t == 0) return -1; + } else if (this.t == 1) return this[0]; + else if (this.t == 0) return 0; + // assumes 16 < DB < 32 + return ((this[1] & ((1 << (32 - this.DB)) - 1)) << this.DB) | this[0]; + } + + // (public) return value as byte + function bnByteValue() { + return this.t == 0 ? this.s : (this[0] << 24) >> 24; + } + + // (public) return value as short (assumes DB>=16) + function bnShortValue() { + return this.t == 0 ? this.s : (this[0] << 16) >> 16; + } + + // (protected) return x s.t. r^x < DV + function bnpChunkSize(r) { + return Math.floor((Math.LN2 * this.DB) / Math.log(r)); + } + + // (public) 0 if this == 0, 1 if this > 0 + function bnSigNum() { + if (this.s < 0) return -1; + else if (this.t <= 0 || (this.t == 1 && this[0] <= 0)) return 0; + else return 1; + } + + // (protected) convert to radix string + function bnpToRadix(b) { + if (b == null) b = 10; + if (this.signum() == 0 || b < 2 || b > 36) return '0'; + var cs = this.chunkSize(b); + var a = Math.pow(b, cs); + var d = nbv(a), + y = nbi(), + z = nbi(), + r = ''; + this.divRemTo(d, y, z); + while (y.signum() > 0) { + r = (a + z.intValue()).toString(b).substr(1) + r; + y.divRemTo(d, y, z); + } + return z.intValue().toString(b) + r; + } + + // (protected) convert from radix string + function bnpFromRadix(s, b) { + this.fromInt(0); + if (b == null) b = 10; + var cs = this.chunkSize(b); + var d = Math.pow(b, cs), + mi = false, + j = 0, + w = 0; + for (var i = 0; i < s.length; ++i) { + var x = intAt(s, i); + if (x < 0) { + if (s.charAt(i) == '-' && this.signum() == 0) mi = true; + continue; + } + w = b * w + x; + if (++j >= cs) { + this.dMultiply(d); + this.dAddOffset(w, 0); + j = 0; + w = 0; + } + } + if (j > 0) { + this.dMultiply(Math.pow(b, j)); + this.dAddOffset(w, 0); + } + if (mi) BigInteger.ZERO.subTo(this, this); + } + + // (protected) alternate constructor + function bnpFromNumber(a, b, c) { + if ('number' == typeof b) { + // new BigInteger(int,int,RNG) + if (a < 2) this.fromInt(1); + else { + this.fromNumber(a, c); + if (!this.testBit(a - 1)) + // force MSB set + this.bitwiseTo(BigInteger.ONE.shiftLeft(a - 1), op_or, this); + if (this.isEven()) this.dAddOffset(1, 0); // force odd + while (!this.isProbablePrime(b)) { + this.dAddOffset(2, 0); + if (this.bitLength() > a) + this.subTo(BigInteger.ONE.shiftLeft(a - 1), this); + } + } + } else { + // new BigInteger(int,RNG) + var x = new Array(), + t = a & 7; + x.length = (a >> 3) + 1; + b.nextBytes(x); + if (t > 0) x[0] &= (1 << t) - 1; + else x[0] = 0; + this.fromString(x, 256); + } + } + + // (public) convert to bigendian byte array + function bnToByteArray() { + var i = this.t, + r = new Array(); + r[0] = this.s; + var p = this.DB - ((i * this.DB) % 8), + d, + k = 0; + if (i-- > 0) { + if (p < this.DB && (d = this[i] >> p) != (this.s & this.DM) >> p) + r[k++] = d | (this.s << (this.DB - p)); + while (i >= 0) { + if (p < 8) { + d = (this[i] & ((1 << p) - 1)) << (8 - p); + d |= this[--i] >> (p += this.DB - 8); + } else { + d = (this[i] >> (p -= 8)) & 0xff; + if (p <= 0) { + p += this.DB; + --i; + } + } + if ((d & 0x80) != 0) d |= -256; + if (k == 0 && (this.s & 0x80) != (d & 0x80)) ++k; + if (k > 0 || d != this.s) r[k++] = d; + } + } + return r; + } + + function bnEquals(a) { + return this.compareTo(a) == 0; + } + function bnMin(a) { + return this.compareTo(a) < 0 ? this : a; + } + function bnMax(a) { + return this.compareTo(a) > 0 ? this : a; + } + + // (protected) r = this op a (bitwise) + function bnpBitwiseTo(a, op, r) { + var i, + f, + m = Math.min(a.t, this.t); + for (i = 0; i < m; ++i) r[i] = op(this[i], a[i]); + if (a.t < this.t) { + f = a.s & this.DM; + for (i = m; i < this.t; ++i) r[i] = op(this[i], f); + r.t = this.t; + } else { + f = this.s & this.DM; + for (i = m; i < a.t; ++i) r[i] = op(f, a[i]); + r.t = a.t; + } + r.s = op(this.s, a.s); + r.clamp(); + } + + // (public) this & a + function op_and(x, y) { + return x & y; + } + function bnAnd(a) { + var r = nbi(); + this.bitwiseTo(a, op_and, r); + return r; + } + + // (public) this | a + function op_or(x, y) { + return x | y; + } + function bnOr(a) { + var r = nbi(); + this.bitwiseTo(a, op_or, r); + return r; + } + + // (public) this ^ a + function op_xor(x, y) { + return x ^ y; + } + function bnXor(a) { + var r = nbi(); + this.bitwiseTo(a, op_xor, r); + return r; + } + + // (public) this & ~a + function op_andnot(x, y) { + return x & ~y; + } + function bnAndNot(a) { + var r = nbi(); + this.bitwiseTo(a, op_andnot, r); + return r; + } + + // (public) ~this + function bnNot() { + var r = nbi(); + for (var i = 0; i < this.t; ++i) r[i] = this.DM & ~this[i]; + r.t = this.t; + r.s = ~this.s; + return r; + } + + // (public) this << n + function bnShiftLeft(n) { + var r = nbi(); + if (n < 0) this.rShiftTo(-n, r); + else this.lShiftTo(n, r); + return r; + } + + // (public) this >> n + function bnShiftRight(n) { + var r = nbi(); + if (n < 0) this.lShiftTo(-n, r); + else this.rShiftTo(n, r); + return r; + } + + // return index of lowest 1-bit in x, x < 2^31 + function lbit(x) { + if (x == 0) return -1; + var r = 0; + if ((x & 0xffff) == 0) { + x >>= 16; + r += 16; + } + if ((x & 0xff) == 0) { + x >>= 8; + r += 8; + } + if ((x & 0xf) == 0) { + x >>= 4; + r += 4; + } + if ((x & 3) == 0) { + x >>= 2; + r += 2; + } + if ((x & 1) == 0) ++r; + return r; + } + + // (public) returns index of lowest 1-bit (or -1 if none) + function bnGetLowestSetBit() { + for (var i = 0; i < this.t; ++i) + if (this[i] != 0) return i * this.DB + lbit(this[i]); + if (this.s < 0) return this.t * this.DB; + return -1; + } + + // return number of 1 bits in x + function cbit(x) { + var r = 0; + while (x != 0) { + x &= x - 1; + ++r; + } + return r; + } + + // (public) return number of set bits + function bnBitCount() { + var r = 0, + x = this.s & this.DM; + for (var i = 0; i < this.t; ++i) r += cbit(this[i] ^ x); + return r; + } + + // (public) true iff nth bit is set + function bnTestBit(n) { + var j = Math.floor(n / this.DB); + if (j >= this.t) return this.s != 0; + return (this[j] & (1 << n % this.DB)) != 0; + } + + // (protected) this op (1<>= this.DB; + } + if (a.t < this.t) { + c += a.s; + while (i < this.t) { + c += this[i]; + r[i++] = c & this.DM; + c >>= this.DB; + } + c += this.s; + } else { + c += this.s; + while (i < a.t) { + c += a[i]; + r[i++] = c & this.DM; + c >>= this.DB; + } + c += a.s; + } + r.s = c < 0 ? -1 : 0; + if (c > 0) r[i++] = c; + else if (c < -1) r[i++] = this.DV + c; + r.t = i; + r.clamp(); + } + + // (public) this + a + function bnAdd(a) { + var r = nbi(); + this.addTo(a, r); + return r; + } + + // (public) this - a + function bnSubtract(a) { + var r = nbi(); + this.subTo(a, r); + return r; + } + + // (public) this * a + function bnMultiply(a) { + var r = nbi(); + this.multiplyTo(a, r); + return r; + } + + // (public) this^2 + function bnSquare() { + var r = nbi(); + this.squareTo(r); + return r; + } + + // (public) this / a + function bnDivide(a) { + var r = nbi(); + this.divRemTo(a, r, null); + return r; + } + + // (public) this % a + function bnRemainder(a) { + var r = nbi(); + this.divRemTo(a, null, r); + return r; + } + + // (public) [this/a,this%a] + function bnDivideAndRemainder(a) { + var q = nbi(), + r = nbi(); + this.divRemTo(a, q, r); + return new Array(q, r); + } + + // (protected) this *= n, this >= 0, 1 < n < DV + function bnpDMultiply(n) { + this[this.t] = this.am(0, n - 1, this, 0, 0, this.t); + ++this.t; + this.clamp(); + } + + // (protected) this += n << w words, this >= 0 + function bnpDAddOffset(n, w) { + if (n == 0) return; + while (this.t <= w) this[this.t++] = 0; + this[w] += n; + while (this[w] >= this.DV) { + this[w] -= this.DV; + if (++w >= this.t) this[this.t++] = 0; + ++this[w]; + } + } + + // A "null" reducer + function NullExp() { } + function nNop(x) { + return x; + } + function nMulTo(x, y, r) { + x.multiplyTo(y, r); + } + function nSqrTo(x, r) { + x.squareTo(r); + } + + NullExp.prototype.convert = nNop; + NullExp.prototype.revert = nNop; + NullExp.prototype.mulTo = nMulTo; + NullExp.prototype.sqrTo = nSqrTo; + + // (public) this^e + function bnPow(e) { + return this.exp(e, new NullExp()); + } + + // (protected) r = lower n words of "this * a", a.t <= n + // "this" should be the larger one if appropriate. + function bnpMultiplyLowerTo(a, n, r) { + var i = Math.min(this.t + a.t, n); + r.s = 0; // assumes a,this >= 0 + r.t = i; + while (i > 0) r[--i] = 0; + var j; + for (j = r.t - this.t; i < j; ++i) + r[i + this.t] = this.am(0, a[i], r, i, 0, this.t); + for (j = Math.min(a.t, n); i < j; ++i) this.am(0, a[i], r, i, 0, n - i); + r.clamp(); + } + + // (protected) r = "this * a" without lower n words, n > 0 + // "this" should be the larger one if appropriate. + function bnpMultiplyUpperTo(a, n, r) { + --n; + var i = (r.t = this.t + a.t - n); + r.s = 0; // assumes a,this >= 0 + while (--i >= 0) r[i] = 0; + for (i = Math.max(n - this.t, 0); i < a.t; ++i) + r[this.t + i - n] = this.am(n - i, a[i], r, 0, 0, this.t + i - n); + r.clamp(); + r.drShiftTo(1, r); + } + + // Barrett modular reduction + function Barrett(m) { + // setup Barrett + this.r2 = nbi(); + this.q3 = nbi(); + BigInteger.ONE.dlShiftTo(2 * m.t, this.r2); + this.mu = this.r2.divide(m); + this.m = m; + } + + function barrettConvert(x) { + if (x.s < 0 || x.t > 2 * this.m.t) return x.mod(this.m); + else if (x.compareTo(this.m) < 0) return x; + else { + var r = nbi(); + x.copyTo(r); + this.reduce(r); + return r; + } + } + + function barrettRevert(x) { + return x; + } + + // x = x mod m (HAC 14.42) + function barrettReduce(x) { + x.drShiftTo(this.m.t - 1, this.r2); + if (x.t > this.m.t + 1) { + x.t = this.m.t + 1; + x.clamp(); + } + this.mu.multiplyUpperTo(this.r2, this.m.t + 1, this.q3); + this.m.multiplyLowerTo(this.q3, this.m.t + 1, this.r2); + while (x.compareTo(this.r2) < 0) x.dAddOffset(1, this.m.t + 1); + x.subTo(this.r2, x); + while (x.compareTo(this.m) >= 0) x.subTo(this.m, x); + } + + // r = x^2 mod m; x != r + function barrettSqrTo(x, r) { + x.squareTo(r); + this.reduce(r); + } + + // r = x*y mod m; x,y != r + function barrettMulTo(x, y, r) { + x.multiplyTo(y, r); + this.reduce(r); + } + + Barrett.prototype.convert = barrettConvert; + Barrett.prototype.revert = barrettRevert; + Barrett.prototype.reduce = barrettReduce; + Barrett.prototype.mulTo = barrettMulTo; + Barrett.prototype.sqrTo = barrettSqrTo; + + // (public) this^e % m (HAC 14.85) + function bnModPow(e, m) { + var i = e.bitLength(), + k, + r = nbv(1), + z; + if (i <= 0) return r; + else if (i < 18) k = 1; + else if (i < 48) k = 3; + else if (i < 144) k = 4; + else if (i < 768) k = 5; + else k = 6; + if (i < 8) z = new Classic(m); + else if (m.isEven()) z = new Barrett(m); + else z = new Montgomery(m); + + // precomputation + var g = new Array(), + n = 3, + k1 = k - 1, + km = (1 << k) - 1; + g[1] = z.convert(this); + if (k > 1) { + var g2 = nbi(); + z.sqrTo(g[1], g2); + while (n <= km) { + g[n] = nbi(); + z.mulTo(g2, g[n - 2], g[n]); + n += 2; + } + } + + var j = e.t - 1, + w, + is1 = true, + r2 = nbi(), + t; + i = nbits(e[j]) - 1; + while (j >= 0) { + if (i >= k1) w = (e[j] >> (i - k1)) & km; + else { + w = (e[j] & ((1 << (i + 1)) - 1)) << (k1 - i); + if (j > 0) w |= e[j - 1] >> (this.DB + i - k1); + } + + n = k; + while ((w & 1) == 0) { + w >>= 1; + --n; + } + if ((i -= n) < 0) { + i += this.DB; + --j; + } + if (is1) { + // ret == 1, don't bother squaring or multiplying it + g[w].copyTo(r); + is1 = false; + } else { + while (n > 1) { + z.sqrTo(r, r2); + z.sqrTo(r2, r); + n -= 2; + } + if (n > 0) z.sqrTo(r, r2); + else { + t = r; + r = r2; + r2 = t; + } + z.mulTo(r2, g[w], r); + } + + while (j >= 0 && (e[j] & (1 << i)) == 0) { + z.sqrTo(r, r2); + t = r; + r = r2; + r2 = t; + if (--i < 0) { + i = this.DB - 1; + --j; + } + } + } + return z.revert(r); + } + + // (public) gcd(this,a) (HAC 14.54) + function bnGCD(a) { + var x = this.s < 0 ? this.negate() : this.clone(); + var y = a.s < 0 ? a.negate() : a.clone(); + if (x.compareTo(y) < 0) { + var t = x; + x = y; + y = t; + } + var i = x.getLowestSetBit(), + g = y.getLowestSetBit(); + if (g < 0) return x; + if (i < g) g = i; + if (g > 0) { + x.rShiftTo(g, x); + y.rShiftTo(g, y); + } + while (x.signum() > 0) { + if ((i = x.getLowestSetBit()) > 0) x.rShiftTo(i, x); + if ((i = y.getLowestSetBit()) > 0) y.rShiftTo(i, y); + if (x.compareTo(y) >= 0) { + x.subTo(y, x); + x.rShiftTo(1, x); + } else { + y.subTo(x, y); + y.rShiftTo(1, y); + } + } + if (g > 0) y.lShiftTo(g, y); + return y; + } + + // (protected) this % n, n < 2^26 + function bnpModInt(n) { + if (n <= 0) return 0; + var d = this.DV % n, + r = this.s < 0 ? n - 1 : 0; + if (this.t > 0) + if (d == 0) r = this[0] % n; + else for (var i = this.t - 1; i >= 0; --i) r = (d * r + this[i]) % n; + return r; + } + + // (public) 1/this % m (HAC 14.61) + function bnModInverse(m) { + var ac = m.isEven(); + if ((this.isEven() && ac) || m.signum() == 0) return BigInteger.ZERO; + var u = m.clone(), + v = this.clone(); + var a = nbv(1), + b = nbv(0), + c = nbv(0), + d = nbv(1); + while (u.signum() != 0) { + while (u.isEven()) { + u.rShiftTo(1, u); + if (ac) { + if (!a.isEven() || !b.isEven()) { + a.addTo(this, a); + b.subTo(m, b); + } + a.rShiftTo(1, a); + } else if (!b.isEven()) b.subTo(m, b); + b.rShiftTo(1, b); + } + while (v.isEven()) { + v.rShiftTo(1, v); + if (ac) { + if (!c.isEven() || !d.isEven()) { + c.addTo(this, c); + d.subTo(m, d); + } + c.rShiftTo(1, c); + } else if (!d.isEven()) d.subTo(m, d); + d.rShiftTo(1, d); + } + if (u.compareTo(v) >= 0) { + u.subTo(v, u); + if (ac) a.subTo(c, a); + b.subTo(d, b); + } else { + v.subTo(u, v); + if (ac) c.subTo(a, c); + d.subTo(b, d); + } + } + if (v.compareTo(BigInteger.ONE) != 0) return BigInteger.ZERO; + if (d.compareTo(m) >= 0) return d.subtract(m); + if (d.signum() < 0) d.addTo(m, d); + else return d; + if (d.signum() < 0) return d.add(m); + else return d; + } + + var lowprimes = [ + 2, + 3, + 5, + 7, + 11, + 13, + 17, + 19, + 23, + 29, + 31, + 37, + 41, + 43, + 47, + 53, + 59, + 61, + 67, + 71, + 73, + 79, + 83, + 89, + 97, + 101, + 103, + 107, + 109, + 113, + 127, + 131, + 137, + 139, + 149, + 151, + 157, + 163, + 167, + 173, + 179, + 181, + 191, + 193, + 197, + 199, + 211, + 223, + 227, + 229, + 233, + 239, + 241, + 251, + 257, + 263, + 269, + 271, + 277, + 281, + 283, + 293, + 307, + 311, + 313, + 317, + 331, + 337, + 347, + 349, + 353, + 359, + 367, + 373, + 379, + 383, + 389, + 397, + 401, + 409, + 419, + 421, + 431, + 433, + 439, + 443, + 449, + 457, + 461, + 463, + 467, + 479, + 487, + 491, + 499, + 503, + 509, + 521, + 523, + 541, + 547, + 557, + 563, + 569, + 571, + 577, + 587, + 593, + 599, + 601, + 607, + 613, + 617, + 619, + 631, + 641, + 643, + 647, + 653, + 659, + 661, + 673, + 677, + 683, + 691, + 701, + 709, + 719, + 727, + 733, + 739, + 743, + 751, + 757, + 761, + 769, + 773, + 787, + 797, + 809, + 811, + 821, + 823, + 827, + 829, + 839, + 853, + 857, + 859, + 863, + 877, + 881, + 883, + 887, + 907, + 911, + 919, + 929, + 937, + 941, + 947, + 953, + 967, + 971, + 977, + 983, + 991, + 997, + ]; + var lplim = (1 << 26) / lowprimes[lowprimes.length - 1]; + + // (public) test primality with certainty >= 1-.5^t + function bnIsProbablePrime(t) { + var i, + x = this.abs(); + if (x.t == 1 && x[0] <= lowprimes[lowprimes.length - 1]) { + for (i = 0; i < lowprimes.length; ++i) + if (x[0] == lowprimes[i]) return true; + return false; + } + if (x.isEven()) return false; + i = 1; + while (i < lowprimes.length) { + var m = lowprimes[i], + j = i + 1; + while (j < lowprimes.length && m < lplim) m *= lowprimes[j++]; + m = x.modInt(m); + while (i < j) if (m % lowprimes[i++] == 0) return false; + } + return x.millerRabin(t); + } + + // (protected) true if probably prime (HAC 4.24, Miller-Rabin) + function bnpMillerRabin(t) { + var n1 = this.subtract(BigInteger.ONE); + var k = n1.getLowestSetBit(); + if (k <= 0) return false; + var r = n1.shiftRight(k); + t = (t + 1) >> 1; + if (t > lowprimes.length) t = lowprimes.length; + var a = nbi(); + for (var i = 0; i < t; ++i) { + //Pick bases at random, instead of starting at 2 + a.fromInt(lowprimes[Math.floor(Math.random() * lowprimes.length)]); + var y = a.modPow(r, this); + if (y.compareTo(BigInteger.ONE) != 0 && y.compareTo(n1) != 0) { + var j = 1; + while (j++ < k && y.compareTo(n1) != 0) { + y = y.modPowInt(2, this); + if (y.compareTo(BigInteger.ONE) == 0) return false; + } + if (y.compareTo(n1) != 0) return false; + } + } + return true; + } + + // protected + BigInteger.prototype.chunkSize = bnpChunkSize; + BigInteger.prototype.toRadix = bnpToRadix; + BigInteger.prototype.fromRadix = bnpFromRadix; + BigInteger.prototype.fromNumber = bnpFromNumber; + BigInteger.prototype.bitwiseTo = bnpBitwiseTo; + BigInteger.prototype.changeBit = bnpChangeBit; + BigInteger.prototype.addTo = bnpAddTo; + BigInteger.prototype.dMultiply = bnpDMultiply; + BigInteger.prototype.dAddOffset = bnpDAddOffset; + BigInteger.prototype.multiplyLowerTo = bnpMultiplyLowerTo; + BigInteger.prototype.multiplyUpperTo = bnpMultiplyUpperTo; + BigInteger.prototype.modInt = bnpModInt; + BigInteger.prototype.millerRabin = bnpMillerRabin; + + // public + BigInteger.prototype.clone = bnClone; + BigInteger.prototype.intValue = bnIntValue; + BigInteger.prototype.byteValue = bnByteValue; + BigInteger.prototype.shortValue = bnShortValue; + BigInteger.prototype.signum = bnSigNum; + BigInteger.prototype.toByteArray = bnToByteArray; + BigInteger.prototype.equals = bnEquals; + BigInteger.prototype.min = bnMin; + BigInteger.prototype.max = bnMax; + BigInteger.prototype.and = bnAnd; + BigInteger.prototype.or = bnOr; + BigInteger.prototype.xor = bnXor; + BigInteger.prototype.andNot = bnAndNot; + BigInteger.prototype.not = bnNot; + BigInteger.prototype.shiftLeft = bnShiftLeft; + BigInteger.prototype.shiftRight = bnShiftRight; + BigInteger.prototype.getLowestSetBit = bnGetLowestSetBit; + BigInteger.prototype.bitCount = bnBitCount; + BigInteger.prototype.testBit = bnTestBit; + BigInteger.prototype.setBit = bnSetBit; + BigInteger.prototype.clearBit = bnClearBit; + BigInteger.prototype.flipBit = bnFlipBit; + BigInteger.prototype.add = bnAdd; + BigInteger.prototype.subtract = bnSubtract; + BigInteger.prototype.multiply = bnMultiply; + BigInteger.prototype.divide = bnDivide; + BigInteger.prototype.remainder = bnRemainder; + BigInteger.prototype.divideAndRemainder = bnDivideAndRemainder; + BigInteger.prototype.modPow = bnModPow; + BigInteger.prototype.modInverse = bnModInverse; + BigInteger.prototype.pow = bnPow; + BigInteger.prototype.gcd = bnGCD; + BigInteger.prototype.isProbablePrime = bnIsProbablePrime; + + // JSBN-specific extension + BigInteger.prototype.square = bnSquare; + + // Expose the Barrett function + BigInteger.prototype.Barrett = Barrett; + + // BigInteger interfaces not implemented in jsbn: + + // BigInteger(int signum, byte[] magnitude) + // double doubleValue() + // float floatValue() + // int hashCode() + // long longValue() + // static BigInteger valueOf(long val) + + // Imported from bitcoinjs-lib + + /** + * Turns a byte array into a big integer. + * + * This function will interpret a byte array as a big integer in big + * endian notation and ignore leading zeros. + */ + + BigInteger.fromByteArrayUnsigned = function (ba) { + + if (!ba.length) { + return new BigInteger.valueOf(0); + } else if (ba[0] & 0x80) { + // Prepend a zero so the BigInteger class doesn't mistake this + // for a negative integer. + return new BigInteger([0].concat(ba)); + } else { + return new BigInteger(ba); + } + }; + + /** + * Parse a signed big integer byte representation. + * + * For details on the format please see BigInteger.toByteArraySigned. + */ + + BigInteger.fromByteArraySigned = function (ba) { + // Check for negative value + if (ba[0] & 0x80) { + // Remove sign bit + ba[0] &= 0x7f; + + return BigInteger.fromByteArrayUnsigned(ba).negate(); + } else { + return BigInteger.fromByteArrayUnsigned(ba); + } + }; + + /** + * Returns a byte array representation of the big integer. + * + * This returns the absolute of the contained value in big endian + * form. A value of zero results in an empty array. + */ + + BigInteger.prototype.toByteArrayUnsigned = function () { + var ba = this.abs().toByteArray(); + + // Empty array, nothing to do + if (!ba.length) { + return ba; + } + + // remove leading 0 + if (ba[0] === 0) { + ba = ba.slice(1); + } + + // all values must be positive + for (var i = 0; i < ba.length; ++i) { + ba[i] = (ba[i] < 0) ? ba[i] + 256 : ba[i]; + } + + return ba; + }; + + /* + * Converts big integer to signed byte representation. + * + * The format for this value uses the most significant bit as a sign + * bit. If the most significant bit is already occupied by the + * absolute value, an extra byte is prepended and the sign bit is set + * there. + * + * Examples: + * + * 0 => 0x00 + * 1 => 0x01 + * -1 => 0x81 + * 127 => 0x7f + * -127 => 0xff + * 128 => 0x0080 + * -128 => 0x8080 + * 255 => 0x00ff + * -255 => 0x80ff + * 16300 => 0x3fac + * -16300 => 0xbfac + * 62300 => 0x00f35c + * -62300 => 0x80f35c + */ + + BigInteger.prototype.toByteArraySigned = function () { + var val = this.toByteArrayUnsigned(); + var neg = this.s < 0; + + // if the first bit is set, we always unshift + // either unshift 0x80 or 0x00 + if (val[0] & 0x80) { + val.unshift((neg) ? 0x80 : 0x00); + } + // if the first bit isn't set, set it if negative + else if (neg) { + val[0] |= 0x80; + } + + return val; + }; + + // Random number generator - requires a PRNG backend, e.g. prng4.js + + // For best results, put code like + // + // in your main HTML document. + + var rng_state; + var rng_pool; + var rng_pptr; + + // Mix in a 32-bit integer into the pool + function rng_seed_int(x) { + rng_pool[rng_pptr++] ^= x & 255; + rng_pool[rng_pptr++] ^= (x >> 8) & 255; + rng_pool[rng_pptr++] ^= (x >> 16) & 255; + rng_pool[rng_pptr++] ^= (x >> 24) & 255; + if (rng_pptr >= rng_psize) rng_pptr -= rng_psize; + } + + // Mix in the current time (w/milliseconds) into the pool + function rng_seed_time() { + rng_seed_int(new Date().getTime()); + } + + // Initialize the pool with junk if needed. + if (rng_pool == null) { + rng_pool = new Array(); + rng_pptr = 0; + var t; + if (typeof window !== 'undefined' && window.crypto) { + if (window.crypto.getRandomValues) { + // Use webcrypto if available + var ua = new Uint8Array(32); + window.crypto.getRandomValues(ua); + for (t = 0; t < 32; ++t) rng_pool[rng_pptr++] = ua[t]; + } else if ( + navigator.appName == 'Netscape' && + navigator.appVersion < '5' + ) { + // Extract entropy (256 bits) from NS4 RNG if available + var z = window.crypto.random(32); + for (t = 0; t < z.length; ++t) + rng_pool[rng_pptr++] = z.charCodeAt(t) & 255; + } + } + while (rng_pptr < rng_psize) { + // extract some randomness from Math.random() + t = Math.floor(65536 * Math.random()); + rng_pool[rng_pptr++] = t >>> 8; + rng_pool[rng_pptr++] = t & 255; + } + rng_pptr = 0; + rng_seed_time(); + //rng_seed_int(window.screenX); + //rng_seed_int(window.screenY); + } + + function rng_get_byte() { + if (rng_state == null) { + rng_seed_time(); + rng_state = prng_newstate(); + rng_state.init(rng_pool); + for (rng_pptr = 0; rng_pptr < rng_pool.length; ++rng_pptr) + rng_pool[rng_pptr] = 0; + rng_pptr = 0; + //rng_pool = null; + } + // TODO: allow reseeding after first request + return rng_state.next(); + } + + function rng_get_bytes(ba) { + var i; + for (i = 0; i < ba.length; ++i) ba[i] = rng_get_byte(); + } + + function SecureRandom() { } + + SecureRandom.prototype.nextBytes = rng_get_bytes; + + // prng4.js - uses Arcfour as a PRNG + + function Arcfour() { + this.i = 0; + this.j = 0; + this.S = new Array(); + } + + // Initialize arcfour context from key, an array of ints, each from [0..255] + function ARC4init(key) { + var i, j, t; + for (i = 0; i < 256; ++i) this.S[i] = i; + j = 0; + for (i = 0; i < 256; ++i) { + j = (j + this.S[i] + key[i % key.length]) & 255; + t = this.S[i]; + this.S[i] = this.S[j]; + this.S[j] = t; + } + this.i = 0; + this.j = 0; + } + + function ARC4next() { + var t; + this.i = (this.i + 1) & 255; + this.j = (this.j + this.S[this.i]) & 255; + t = this.S[this.i]; + this.S[this.i] = this.S[this.j]; + this.S[this.j] = t; + return this.S[(t + this.S[this.i]) & 255]; + } + + Arcfour.prototype.init = ARC4init; + Arcfour.prototype.next = ARC4next; + + // Plug in your RNG constructor here + function prng_newstate() { + return new Arcfour(); + } + + // Pool size must be a multiple of 4 and greater than 32. + // An array of bytes the size of the pool will be passed to init() + var rng_psize = 256; + + if (typeof exports !== 'undefined') { + exports = module.exports = { + default: BigInteger, + BigInteger: BigInteger, + SecureRandom: SecureRandom, + }; + } else { + this.jsbn = { + BigInteger: BigInteger, + SecureRandom: SecureRandom, + }; + } +}.call(this)); \ No newline at end of file diff --git a/qortal-ui-crypto/api/constants.js b/qortal-ui-crypto/api/constants.js new file mode 100644 index 00000000..1909fffc --- /dev/null +++ b/qortal-ui-crypto/api/constants.js @@ -0,0 +1,294 @@ +"use strict"; +// This needs a total makeover. + +// Qortal TX types + +const TX_TYPES = { + 1: "Genesis", + 2: "Payment", + + 3: "Name registration", + 4: "Name update", + 5: "Sell name", + 6: "Cancel sell name", + 7: "Buy name", + + 8: "Create poll", + 9: "Vote in poll", + + 10: "Arbitrary", + + 11: "Issue asset", + 12: "Transfer asset", + 13: "Create asset order", + 14: "Cancel asset order", + 15: "Multi-payment transaction", + + 16: "Deploy AT", + + 17: "Message", + + 18: "Chat", + 19: "Publicize", + 20: "Airdrop", + + 21: 'AT', + + 22: 'Create group', + 23: 'Update group', + 24: 'Add group admin', + 25: 'Remove group admin', + 26: 'Group ban', + 27: 'Cancel group ban', + 28: 'Group kick', + 29: 'Group invite', + 30: 'Cancel group invite', + 31: 'Join group', + 32: 'Leave group', + 33: 'Group approval', + 34: 'Set group', + + 35: 'Update asset', + + 36: 'Account flags', + + 37: 'Enable forging', + 38: 'Reward share', + 39: 'Account level', +} + +// Qortal errors +// OK(1), +// INVALID_ADDRESS(2), +// NEGATIVE_AMOUNT(3), +// NEGATIVE_FEE(4), +// NO_BALANCE(5), +// INVALID_REFERENCE(6), +// INVALID_NAME_LENGTH(7), +// INVALID_VALUE_LENGTH(8), +// NAME_ALREADY_REGISTERED(9), +// NAME_DOES_NOT_EXIST(10), +// INVALID_NAME_OWNER(11), +// NAME_ALREADY_FOR_SALE(12), +// NAME_NOT_FOR_SALE(13), +// BUYER_ALREADY_OWNER(14), +// INVALID_AMOUNT(15), +// INVALID_SELLER(16), +// NAME_NOT_LOWER_CASE(17), +// INVALID_DESCRIPTION_LENGTH(18), +// INVALID_OPTIONS_COUNT(19), +// INVALID_OPTION_LENGTH(20), +// DUPLICATE_OPTION(21), +// POLL_ALREADY_EXISTS(22), +// POLL_DOES_NOT_EXIST(24), +// POLL_OPTION_DOES_NOT_EXIST(25), +// ALREADY_VOTED_FOR_THAT_OPTION(26), +// INVALID_DATA_LENGTH(27), + +// INVALID_QUANTITY(28), +// ASSET_DOES_NOT_EXIST(29), +// INVALID_RETURN(30), +// HAVE_EQUALS_WANT(31), +// ORDER_DOES_NOT_EXIST(32), +// INVALID_ORDER_CREATOR(33), +// INVALID_PAYMENTS_COUNT(34), +// NEGATIVE_PRICE(35), +// INVALID_CREATION_BYTES(36), +// INVALID_TAGS_LENGTH(37), +// INVALID_AT_TYPE_LENGTH(38), + +// INVALID_AT_TRANSACTION(39), + +// INSUFFICIENT_FEE(40), +// ASSET_DOES_NOT_MATCH_AT(41), +// ASSET_ALREADY_EXISTS(43), +// MISSING_CREATOR(44), +// TIMESTAMP_TOO_OLD(45), +// TIMESTAMP_TOO_NEW(46), +// TOO_MANY_UNCONFIRMED(47), +// GROUP_ALREADY_EXISTS(48), +// GROUP_DOES_NOT_EXIST(49), +// INVALID_GROUP_OWNER(50), +// ALREADY_GROUP_MEMBER(51), +// GROUP_OWNER_CANNOT_LEAVE(52), +// NOT_GROUP_MEMBER(53), +// ALREADY_GROUP_ADMIN(54), +// NOT_GROUP_ADMIN(55), +// INVALID_LIFETIME(56), +// INVITE_UNKNOWN(57), +// BAN_EXISTS(58), +// BAN_UNKNOWN(59), +// BANNED_FROM_GROUP(60), +// JOIN_REQUEST_EXISTS(61), +// INVALID_GROUP_APPROVAL_THRESHOLD(62), +// GROUP_ID_MISMATCH(63), +// INVALID_GROUP_ID(64), +// TRANSACTION_UNKNOWN(65), +// TRANSACTION_ALREADY_CONFIRMED(66), +// INVALID_TX_GROUP_ID(67), +// TX_GROUP_ID_MISMATCH(68), +// MULTIPLE_NAMES_FORBIDDEN(69), +// INVALID_ASSET_OWNER(70), +// AT_IS_FINISHED(71), +// NO_FLAG_PERMISSION(72), +// NOT_MINTING_ACCOUNT(73), +// INVALID_REWARD_SHARE_PERCENT(77), +// PUBLIC_KEY_UNKNOWN(78), +// INVALID_PUBLIC_KEY(79), +// AT_UNKNOWN(80), +// AT_ALREADY_EXISTS(81), +// GROUP_APPROVAL_NOT_REQUIRED(82), +// GROUP_APPROVAL_DECIDED(83), +// MAXIMUM_REWARD_SHARES(84), +// TRANSACTION_ALREADY_EXISTS(85), +// NO_BLOCKCHAIN_LOCK(86), +// ORDER_ALREADY_CLOSED(87), +// CLOCK_NOT_SYNCED(88), +// ASSET_NOT_SPENDABLE(89), +// ACCOUNT_CANNOT_REWARD_SHARE(90), +// NOT_YET_RELEASED(1000); + +const ERROR_CODES = { + 1: "Valid OK", + 2: "Invalid address", + 3: "Negative amount", + 4: "Nagative fee", + 5: "No balance", + 6: "Invalid reference", + + 7: "Invalid time length", + 8: "Invalid value length", + 9: "Name already registered", + + 10: "Name does not exist", + 11: "Invalid name owner", + 12: "Name already for sale", + 13: "Name not for sale", + 14: "Name buyer already owner", + 15: "Invalid amount", + 16: "Invalid seller", + + 17: "Name not lowercase", + + 18: "Invalid description length", + 19: "Invalid options length", + 20: "Invalid option length", + 21: "Duplicate option", + 22: "Poll already created", + 23: "Poll already has votes", + 24: "Poll does not exist", + 25: "Option does not exist", + 26: "Already voted for that option", + 27: "Invalid data length", + + 28: "Invalid quantity", + 29: "Asset does not exist", + 30: "Invalid return", + 31: "Have equals want", + 32: "Order does not exist", + 33: "Invalid order creator", + 34: "Invalid payments length", + 35: "Negative price", + 36: "Invalid creation bytes", + 37: "Invalid tags length", + 38: "Invalid type length", + + 39: 'Invalid AT transaction', + + 40: "Insufficient fee", + + 41: "Asset does not match AT", + + 43: 'Asset already exists', + 44: 'Missing creator', + 45: 'Timestamp too old', + 46: 'Timestamp too new', + 47: 'Too many unconfirmed', + 48: 'Group already exists', + 49: 'Group does not exist', + 50: 'Invalid group owner', + 51: 'Already group memeber', + 52: 'Group owner can not leave', + 53: 'Not group member', + 54: 'Already group admin', + 55: 'Not group admin', + 56: 'Invalid lifetime', + 57: 'Invite unknown', + 58: 'Ban exists', // total crap mistakes by the nigerian scammer + 59: 'Ban unknown', // its fucking Ban not Ben + 60: 'Banned from group', + 61: 'Join request', + 62: 'Invalid group approval threshold', + 63: 'Group ID mismatch', + 64: 'Invalid group ID', + 65: 'Transaction unknown', + 66: 'Transaction already confirmed', + 67: 'Invalid TX group', + 68: 'TX group ID mismatch', + 69: 'Multiple names forbidden', + 70: 'Invalid asset owner', + 71: 'AT is finished', + 72: 'No flag permission', + 73: 'Not minting accout', + + 77: 'Invalid rewardshare percent', + 78: 'Public key unknown', + 79: 'Invalid public key', + 80: 'AT unknown', + 81: 'AT already exists', + 82: 'Group approval not required', + 83: 'Group approval decided', + 84: 'Maximum reward shares', + 85: 'Transaction already exists', + 86: 'No blockchain lock', + 87: 'Order already closed', + 88: 'Clock not synced', + 89: 'Asset not spendable', + 90: 'Account can not reward share', + + 1000: "Not yet released." +} + +const QORT_DECIMALS = 1e8 + +const PROXY_URL = "/proxy/" // Proxy for api calls + +const ADDRESS_VERSION = 58; // Q for Qora +// const ADDRESS_VERSION = 46; // K for Karma + +// Used as a salt for all qora addresses. Salts used for storing your private keys in local storage will be randomly generated +const STATIC_SALT = new Uint8Array([54, 190, 201, 206, 65, 29, 123, 129, 147, 231, 180, 166, 171, 45, 95, 165, 78, 200, 208, 194, 44, 207, 221, 146, 45, 238, 68, 68, 69, 102, 62, 6]) +const BCRYPT_ROUNDS = 10 // Remember that the total work spent on key derivation is BCRYPT_ROUNDS * KDF_THREADS +const BCRYPT_VERSION = "2a" +const STATIC_BCRYPT_SALT = `$${BCRYPT_VERSION}$${BCRYPT_ROUNDS}$IxVE941tXVUD4cW0TNVm.O` +// const PBKDF2_ROUNDS = Math.pow(2,17) // Deprecated + +const KDF_THREADS = 16 // 16 Threads seems like a good number :) . No you dumbass nigerian. Its not ! -_- + +export { TX_TYPES, ERROR_CODES, QORT_DECIMALS, PROXY_URL, STATIC_SALT, ADDRESS_VERSION, KDF_THREADS, STATIC_BCRYPT_SALT } + +//const TX_TYPES = { +// GENESIS_TRANSACTION: 1, +// PAYMENT_TRANSACTION: 2, +// +// REGISTER_NAME_TRANSACTION: 3, +// UPDATE_NAME_TRANSACTION: 4, +// SELL_NAME_TRANSACTION: 5, +// CANCEL_SELL_NAME_TRANSACTION: 6, +// BUY_NAME_TRANSACTION: 7, +// +// CREATE_POLL_TRANSACTION: 8, +// VOTE_ON_POLL_TRANSACTION: 9, +// +// ARBITRARY_TRANSACTION: 10, +// +// ISSUE_ASSET_TRANSACTION: 11, +// TRANSFER_ASSET_TRANSACTION: 12, +// CREATE_ORDER_TRANSACTION: 13, +// CANCEL_ORDER_TRANSACTION: 14, +// MULTI_PAYMENT_TRANSACTION: 15, +// +// DEPLOY_AT_TRANSACTION: 16, +// +// MESSAGE_TRANSACTION: 17 +//}; \ No newline at end of file diff --git a/qortal-ui-crypto/api/createTransaction.js b/qortal-ui-crypto/api/createTransaction.js new file mode 100644 index 00000000..3481f121 --- /dev/null +++ b/qortal-ui-crypto/api/createTransaction.js @@ -0,0 +1,32 @@ +import { transactionTypes as transactions } from './transactions/transactions.js' +import Base58 from './deps/Base58.js' +import { request } from './fetch-request' +import signChat from './transactions/chat/signChat.js' + + +export const createTransaction = (type, keyPair, params) => { + const tx = new transactions[type]() + tx.keyPair = keyPair + Object.keys(params).forEach(param => { + tx[param] = params[param] + }) + + return tx +} + +// Compute Chat Nonce +export const computeChatNonce = bytes => request('/chat/compute', { + method: 'POST', + body: Base58.encode(bytes) +}) + +// Sign Chat Transactions +export const signChatTransaction = (chatBytes, nonce, keyPair) => { + return signChat(chatBytes, nonce, keyPair) +} + +// Process Transactions +export const processTransaction = bytes => request('/transactions/process', { + method: 'POST', + body: Base58.encode(bytes) +}) diff --git a/qortal-ui-crypto/api/createWallet.js b/qortal-ui-crypto/api/createWallet.js new file mode 100644 index 00000000..e9433957 --- /dev/null +++ b/qortal-ui-crypto/api/createWallet.js @@ -0,0 +1,30 @@ + +import { kdf } from './kdf.js' +import PhraseWallet from './PhraseWallet.js' +import Base58 from './deps/Base58.js' +import { decryptStoredWallet } from './decryptStoredWallet.js' + +export const createWallet = async (sourceType, source, statusUpdateFn) => { + let version, seed + + switch (sourceType) { + case 'phrase': + version = 2 + seed = await kdf(source.seedPhrase, void 0, statusUpdateFn) + break + case 'seed': + version = 1 + seed = Base58.decode(source.seed) + break + case 'storedWallet': + case 'backedUpSeed': + version = source.wallet.version + seed = await decryptStoredWallet(source.password, source.wallet, statusUpdateFn) + break + default: + throw 'sourceType ' + sourceType + ' not recognized' + } + + const wallet = new PhraseWallet(seed, version) + return wallet +} diff --git a/qortal-ui-crypto/api/decryptStoredWallet.js b/qortal-ui-crypto/api/decryptStoredWallet.js new file mode 100644 index 00000000..e47a33b4 --- /dev/null +++ b/qortal-ui-crypto/api/decryptStoredWallet.js @@ -0,0 +1,23 @@ +import Base58 from './deps/Base58.js' +import { kdf } from './kdf.js' +import { HmacSha512, AES_CBC } from 'asmcrypto.js' + +export const decryptStoredWallet = async (password, wallet, statusFn = () => { }) => { + statusFn('Decoding saved data') + const encryptedSeedBytes = Base58.decode(wallet.encryptedSeed) + const iv = Base58.decode(wallet.iv) + const salt = Base58.decode(wallet.salt) + statusFn('Generating decryption key') + const key = await kdf(password, salt, statusFn) + const encryptionKey = key.slice(0, 32) + const macKey = key.slice(32, 63) + + statusFn('Checking key') + const mac = new HmacSha512(macKey).process(encryptedSeedBytes).finish().result + if (Base58.encode(mac) !== wallet.mac) { + throw new Error('Incorrect password') + } + statusFn('Decrypting') + const decryptedBytes = AES_CBC.decrypt(encryptedSeedBytes, encryptionKey, false, iv) + return decryptedBytes +} diff --git a/qortal-ui-crypto/api/deps/Base58.js b/qortal-ui-crypto/api/deps/Base58.js new file mode 100644 index 00000000..c0caaca4 --- /dev/null +++ b/qortal-ui-crypto/api/deps/Base58.js @@ -0,0 +1,108 @@ +// Generated by CoffeeScript 1.8.0 + +// == Changed for ES6 modules == // +//(function() { +//var ALPHABET, ALPHABET_MAP, Base58, i; + +//const Base58 = (typeof module !== "undefined" && module !== null ? module.exports : void 0) || (window.Base58 = {}); +const Base58 = {}; + +const ALPHABET = "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"; + +const ALPHABET_MAP = {}; + +let i = 0; + +while (i < ALPHABET.length) { +ALPHABET_MAP[ALPHABET.charAt(i)] = i; +i++; +} + +Base58.encode = function(buffer) { +buffer = new Uint8Array(buffer); +var carry, digits, j; +if (buffer.length === 0) { + return ""; +} +i = void 0; +j = void 0; +digits = [0]; +i = 0; +while (i < buffer.length) { + j = 0; + while (j < digits.length) { + digits[j] <<= 8; + j++; + } + digits[0] += buffer[i]; + carry = 0; + j = 0; + while (j < digits.length) { + digits[j] += carry; + carry = (digits[j] / 58) | 0; + digits[j] %= 58; + ++j; + } + while (carry) { + digits.push(carry % 58); + carry = (carry / 58) | 0; + } + i++; +} +i = 0; +while (buffer[i] === 0 && i < buffer.length - 1) { + digits.push(0); + i++; +} +return digits.reverse().map(function(digit) { + return ALPHABET[digit]; +}).join(""); +}; + +Base58.decode = function(string) { +var bytes, c, carry, j; +if (string.length === 0) { + return new (typeof Uint8Array !== "undefined" && Uint8Array !== null ? Uint8Array : Buffer)(0); +} +i = void 0; +j = void 0; +bytes = [0]; +i = 0; +while (i < string.length) { + c = string[i]; + if (!(c in ALPHABET_MAP)) { + throw "Base58.decode received unacceptable input. Character '" + c + "' is not in the Base58 alphabet."; + } + j = 0; + while (j < bytes.length) { + bytes[j] *= 58; + j++; + } + bytes[0] += ALPHABET_MAP[c]; + carry = 0; + j = 0; + while (j < bytes.length) { + bytes[j] += carry; + carry = bytes[j] >> 8; + bytes[j] &= 0xff; + ++j; + } + while (carry) { + bytes.push(carry & 0xff); + carry >>= 8; + } + i++; +} +i = 0; +while (string[i] === "1" && i < string.length - 1) { + bytes.push(0); + i++; +} +return new (typeof Uint8Array !== "undefined" && Uint8Array !== null ? Uint8Array : Buffer)(bytes.reverse()); +}; + + +// == Changed for ES6 modules == // +//}).call(this); + +export default Base58; \ No newline at end of file diff --git a/qortal-ui-crypto/api/deps/bcrypt.js b/qortal-ui-crypto/api/deps/bcrypt.js new file mode 100644 index 00000000..a50dbeeb --- /dev/null +++ b/qortal-ui-crypto/api/deps/bcrypt.js @@ -0,0 +1,1379 @@ +/* + Copyright (c) 2012 Nevins Bartolomeo + Copyright (c) 2012 Shane Girish + Copyright (c) 2014 Daniel Wirtz + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions + are met: + 1. Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + 2. Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + 3. The name of the author may not be used to endorse or promote products + derived from this software without specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR + IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. + IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, + INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT + NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF + THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +/** + * @license bcrypt.js (c) 2013 Daniel Wirtz + * Released under the Apache License, Version 2.0 + * see: https://github.com/dcodeIO/bcrypt.js for details + */ +(function(global, factory) { + + /* AMD */ if (typeof define === 'function' && define["amd"]) + define([], factory); + /* CommonJS */ else if (typeof require === 'function' && typeof module === "object" && module && module["exports"]) + module["exports"] = factory(); + /* Global */ else + (global["dcodeIO"] = global["dcodeIO"] || {})["bcrypt"] = factory(); + +}(this, function() { + "use strict"; + + /** + * bcrypt namespace. + * @type {Object.} + */ + var bcrypt = {}; + + /** + * The random implementation to use as a fallback. + * @type {?function(number):!Array.} + * @inner + */ + var randomFallback = null; + + /** + * Generates cryptographically secure random bytes. + * @function + * @param {number} len Bytes length + * @returns {!Array.} Random bytes + * @throws {Error} If no random implementation is available + * @inner + */ + function random(len) { + /* node */ if (typeof module !== 'undefined' && module && module['exports']) + try { + return require("crypto")['randomBytes'](len); + } catch (e) {} + /* WCA */ try { + var a; (self['crypto']||self['msCrypto'])['getRandomValues'](a = new Uint32Array(len)); + return Array.prototype.slice.call(a); + } catch (e) {} + /* fallback */ if (!randomFallback) + throw Error("Neither WebCryptoAPI nor a crypto module is available. Use bcrypt.setRandomFallback to set an alternative"); + return randomFallback(len); + } + + // Test if any secure randomness source is available + var randomAvailable = false; + try { + random(1); + randomAvailable = true; + } catch (e) {} + + // Default fallback, if any + randomFallback = null; + /** + * Sets the pseudo random number generator to use as a fallback if neither node's `crypto` module nor the Web Crypto + * API is available. Please note: It is highly important that the PRNG used is cryptographically secure and that it + * is seeded properly! + * @param {?function(number):!Array.} random Function taking the number of bytes to generate as its + * sole argument, returning the corresponding array of cryptographically secure random byte values. + * @see http://nodejs.org/api/crypto.html + * @see http://www.w3.org/TR/WebCryptoAPI/ + */ + bcrypt.setRandomFallback = function(random) { + randomFallback = random; + }; + + /** + * Synchronously generates a salt. + * @param {number=} rounds Number of rounds to use, defaults to 10 if omitted + * @param {number=} seed_length Not supported. + * @returns {string} Resulting salt + * @throws {Error} If a random fallback is required but not set + * @expose + */ + bcrypt.genSaltSync = function(rounds, seed_length) { + rounds = rounds || GENSALT_DEFAULT_LOG2_ROUNDS; + if (typeof rounds !== 'number') + throw Error("Illegal arguments: "+(typeof rounds)+", "+(typeof seed_length)); + if (rounds < 4) + rounds = 4; + else if (rounds > 31) + rounds = 31; + var salt = []; + salt.push("$2a$"); + if (rounds < 10) + salt.push("0"); + salt.push(rounds.toString()); + salt.push('$'); + salt.push(base64_encode(random(BCRYPT_SALT_LEN), BCRYPT_SALT_LEN)); // May throw + return salt.join(''); + }; + + /** + * Asynchronously generates a salt. + * @param {(number|function(Error, string=))=} rounds Number of rounds to use, defaults to 10 if omitted + * @param {(number|function(Error, string=))=} seed_length Not supported. + * @param {function(Error, string=)=} callback Callback receiving the error, if any, and the resulting salt + * @returns {!Promise} If `callback` has been omitted + * @throws {Error} If `callback` is present but not a function + * @expose + */ + bcrypt.genSalt = function(rounds, seed_length, callback) { + if (typeof seed_length === 'function') + callback = seed_length, + seed_length = undefined; // Not supported. + if (typeof rounds === 'function') + callback = rounds, + rounds = undefined; + if (typeof rounds === 'undefined') + rounds = GENSALT_DEFAULT_LOG2_ROUNDS; + else if (typeof rounds !== 'number') + throw Error("illegal arguments: "+(typeof rounds)); + + function _async(callback) { + nextTick(function() { // Pretty thin, but salting is fast enough + try { + callback(null, bcrypt.genSaltSync(rounds)); + } catch (err) { + callback(err); + } + }); + } + + if (callback) { + if (typeof callback !== 'function') + throw Error("Illegal callback: "+typeof(callback)); + _async(callback); + } else + return new Promise(function(resolve, reject) { + _async(function(err, res) { + if (err) { + reject(err); + return; + } + resolve(res); + }); + }); + }; + + /** + * Synchronously generates a hash for the given string. + * @param {string} s String to hash + * @param {(number|string)=} salt Salt length to generate or salt to use, default to 10 + * @returns {string} Resulting hash + * @expose + */ + bcrypt.hashSync = function(s, salt) { + if (typeof salt === 'undefined') + salt = GENSALT_DEFAULT_LOG2_ROUNDS; + if (typeof salt === 'number') + salt = bcrypt.genSaltSync(salt); + if (typeof s !== 'string' || typeof salt !== 'string') + throw Error("Illegal arguments: "+(typeof s)+', '+(typeof salt)); + return _hash(s, salt); + }; + + /** + * Asynchronously generates a hash for the given string. + * @param {string} s String to hash + * @param {number|string} salt Salt length to generate or salt to use + * @param {function(Error, string=)=} callback Callback receiving the error, if any, and the resulting hash + * @param {function(number)=} progressCallback Callback successively called with the percentage of rounds completed + * (0.0 - 1.0), maximally once per `MAX_EXECUTION_TIME = 100` ms. + * @returns {!Promise} If `callback` has been omitted + * @throws {Error} If `callback` is present but not a function + * @expose + */ + bcrypt.hash = function(s, salt, callback, progressCallback) { + + function _async(callback) { + if (typeof s === 'string' && typeof salt === 'number') + bcrypt.genSalt(salt, function(err, salt) { + _hash(s, salt, callback, progressCallback); + }); + else if (typeof s === 'string' && typeof salt === 'string') + _hash(s, salt, callback, progressCallback); + else + nextTick(callback.bind(this, Error("Illegal arguments: "+(typeof s)+', '+(typeof salt)))); + } + + if (callback) { + if (typeof callback !== 'function') + throw Error("Illegal callback: "+typeof(callback)); + _async(callback); + } else + return new Promise(function(resolve, reject) { + _async(function(err, res) { + if (err) { + reject(err); + return; + } + resolve(res); + }); + }); + }; + + /** + * Compares two strings of the same length in constant time. + * @param {string} known Must be of the correct length + * @param {string} unknown Must be the same length as `known` + * @returns {boolean} + * @inner + */ + function safeStringCompare(known, unknown) { + var right = 0, + wrong = 0; + for (var i=0, k=known.length; i} UTF8 bytes + * @inner + */ + function stringToBytes(str) { + var out = [], + i = 0; + utfx.encodeUTF16toUTF8(function() { + if (i >= str.length) return null; + return str.charCodeAt(i++); + }, function(b) { + out.push(b); + }); + return out; + } + + // A base64 implementation for the bcrypt algorithm. This is partly non-standard. + + /** + * bcrypt's own non-standard base64 dictionary. + * @type {!Array.} + * @const + * @inner + **/ + var BASE64_CODE = "./ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789".split(''); + + /** + * @type {!Array.} + * @const + * @inner + **/ + var BASE64_INDEX = [-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 0, + 1, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, -1, -1, -1, -1, -1, -1, + -1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, + 20, 21, 22, 23, 24, 25, 26, 27, -1, -1, -1, -1, -1, -1, 28, 29, 30, + 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, + 48, 49, 50, 51, 52, 53, -1, -1, -1, -1, -1]; + + /** + * @type {!function(...number):string} + * @inner + */ + var stringFromCharCode = String.fromCharCode; + + /** + * Encodes a byte array to base64 with up to len bytes of input. + * @param {!Array.} b Byte array + * @param {number} len Maximum input length + * @returns {string} + * @inner + */ + function base64_encode(b, len) { + var off = 0, + rs = [], + c1, c2; + if (len <= 0 || len > b.length) + throw Error("Illegal len: "+len); + while (off < len) { + c1 = b[off++] & 0xff; + rs.push(BASE64_CODE[(c1 >> 2) & 0x3f]); + c1 = (c1 & 0x03) << 4; + if (off >= len) { + rs.push(BASE64_CODE[c1 & 0x3f]); + break; + } + c2 = b[off++] & 0xff; + c1 |= (c2 >> 4) & 0x0f; + rs.push(BASE64_CODE[c1 & 0x3f]); + c1 = (c2 & 0x0f) << 2; + if (off >= len) { + rs.push(BASE64_CODE[c1 & 0x3f]); + break; + } + c2 = b[off++] & 0xff; + c1 |= (c2 >> 6) & 0x03; + rs.push(BASE64_CODE[c1 & 0x3f]); + rs.push(BASE64_CODE[c2 & 0x3f]); + } + return rs.join(''); + } + + /** + * Decodes a base64 encoded string to up to len bytes of output. + * @param {string} s String to decode + * @param {number} len Maximum output length + * @returns {!Array.} + * @inner + */ + function base64_decode(s, len) { + var off = 0, + slen = s.length, + olen = 0, + rs = [], + c1, c2, c3, c4, o, code; + if (len <= 0) + throw Error("Illegal len: "+len); + while (off < slen - 1 && olen < len) { + code = s.charCodeAt(off++); + c1 = code < BASE64_INDEX.length ? BASE64_INDEX[code] : -1; + code = s.charCodeAt(off++); + c2 = code < BASE64_INDEX.length ? BASE64_INDEX[code] : -1; + if (c1 == -1 || c2 == -1) + break; + o = (c1 << 2) >>> 0; + o |= (c2 & 0x30) >> 4; + rs.push(stringFromCharCode(o)); + if (++olen >= len || off >= slen) + break; + code = s.charCodeAt(off++); + c3 = code < BASE64_INDEX.length ? BASE64_INDEX[code] : -1; + if (c3 == -1) + break; + o = ((c2 & 0x0f) << 4) >>> 0; + o |= (c3 & 0x3c) >> 2; + rs.push(stringFromCharCode(o)); + if (++olen >= len || off >= slen) + break; + code = s.charCodeAt(off++); + c4 = code < BASE64_INDEX.length ? BASE64_INDEX[code] : -1; + o = ((c3 & 0x03) << 6) >>> 0; + o |= c4; + rs.push(stringFromCharCode(o)); + ++olen; + } + var res = []; + for (off = 0; off + * Released under the Apache License, Version 2.0 + * see: https://github.com/dcodeIO/utfx for details + */ + var utfx = function() { + "use strict"; + + /** + * utfx namespace. + * @inner + * @type {!Object.} + */ + var utfx = {}; + + /** + * Maximum valid code point. + * @type {number} + * @const + */ + utfx.MAX_CODEPOINT = 0x10FFFF; + + /** + * Encodes UTF8 code points to UTF8 bytes. + * @param {(!function():number|null) | number} src Code points source, either as a function returning the next code point + * respectively `null` if there are no more code points left or a single numeric code point. + * @param {!function(number)} dst Bytes destination as a function successively called with the next byte + */ + utfx.encodeUTF8 = function(src, dst) { + var cp = null; + if (typeof src === 'number') + cp = src, + src = function() { return null; }; + while (cp !== null || (cp = src()) !== null) { + if (cp < 0x80) + dst(cp&0x7F); + else if (cp < 0x800) + dst(((cp>>6)&0x1F)|0xC0), + dst((cp&0x3F)|0x80); + else if (cp < 0x10000) + dst(((cp>>12)&0x0F)|0xE0), + dst(((cp>>6)&0x3F)|0x80), + dst((cp&0x3F)|0x80); + else + dst(((cp>>18)&0x07)|0xF0), + dst(((cp>>12)&0x3F)|0x80), + dst(((cp>>6)&0x3F)|0x80), + dst((cp&0x3F)|0x80); + cp = null; + } + }; + + /** + * Decodes UTF8 bytes to UTF8 code points. + * @param {!function():number|null} src Bytes source as a function returning the next byte respectively `null` if there + * are no more bytes left. + * @param {!function(number)} dst Code points destination as a function successively called with each decoded code point. + * @throws {RangeError} If a starting byte is invalid in UTF8 + * @throws {Error} If the last sequence is truncated. Has an array property `bytes` holding the + * remaining bytes. + */ + utfx.decodeUTF8 = function(src, dst) { + var a, b, c, d, fail = function(b) { + b = b.slice(0, b.indexOf(null)); + var err = Error(b.toString()); + err.name = "TruncatedError"; + err['bytes'] = b; + throw err; + }; + while ((a = src()) !== null) { + if ((a&0x80) === 0) + dst(a); + else if ((a&0xE0) === 0xC0) + ((b = src()) === null) && fail([a, b]), + dst(((a&0x1F)<<6) | (b&0x3F)); + else if ((a&0xF0) === 0xE0) + ((b=src()) === null || (c=src()) === null) && fail([a, b, c]), + dst(((a&0x0F)<<12) | ((b&0x3F)<<6) | (c&0x3F)); + else if ((a&0xF8) === 0xF0) + ((b=src()) === null || (c=src()) === null || (d=src()) === null) && fail([a, b, c ,d]), + dst(((a&0x07)<<18) | ((b&0x3F)<<12) | ((c&0x3F)<<6) | (d&0x3F)); + else throw RangeError("Illegal starting byte: "+a); + } + }; + + /** + * Converts UTF16 characters to UTF8 code points. + * @param {!function():number|null} src Characters source as a function returning the next char code respectively + * `null` if there are no more characters left. + * @param {!function(number)} dst Code points destination as a function successively called with each converted code + * point. + */ + utfx.UTF16toUTF8 = function(src, dst) { + var c1, c2 = null; + while (true) { + if ((c1 = c2 !== null ? c2 : src()) === null) + break; + if (c1 >= 0xD800 && c1 <= 0xDFFF) { + if ((c2 = src()) !== null) { + if (c2 >= 0xDC00 && c2 <= 0xDFFF) { + dst((c1-0xD800)*0x400+c2-0xDC00+0x10000); + c2 = null; continue; + } + } + } + dst(c1); + } + if (c2 !== null) dst(c2); + }; + + /** + * Converts UTF8 code points to UTF16 characters. + * @param {(!function():number|null) | number} src Code points source, either as a function returning the next code point + * respectively `null` if there are no more code points left or a single numeric code point. + * @param {!function(number)} dst Characters destination as a function successively called with each converted char code. + * @throws {RangeError} If a code point is out of range + */ + utfx.UTF8toUTF16 = function(src, dst) { + var cp = null; + if (typeof src === 'number') + cp = src, src = function() { return null; }; + while (cp !== null || (cp = src()) !== null) { + if (cp <= 0xFFFF) + dst(cp); + else + cp -= 0x10000, + dst((cp>>10)+0xD800), + dst((cp%0x400)+0xDC00); + cp = null; + } + }; + + /** + * Converts and encodes UTF16 characters to UTF8 bytes. + * @param {!function():number|null} src Characters source as a function returning the next char code respectively `null` + * if there are no more characters left. + * @param {!function(number)} dst Bytes destination as a function successively called with the next byte. + */ + utfx.encodeUTF16toUTF8 = function(src, dst) { + utfx.UTF16toUTF8(src, function(cp) { + utfx.encodeUTF8(cp, dst); + }); + }; + + /** + * Decodes and converts UTF8 bytes to UTF16 characters. + * @param {!function():number|null} src Bytes source as a function returning the next byte respectively `null` if there + * are no more bytes left. + * @param {!function(number)} dst Characters destination as a function successively called with each converted char code. + * @throws {RangeError} If a starting byte is invalid in UTF8 + * @throws {Error} If the last sequence is truncated. Has an array property `bytes` holding the remaining bytes. + */ + utfx.decodeUTF8toUTF16 = function(src, dst) { + utfx.decodeUTF8(src, function(cp) { + utfx.UTF8toUTF16(cp, dst); + }); + }; + + /** + * Calculates the byte length of an UTF8 code point. + * @param {number} cp UTF8 code point + * @returns {number} Byte length + */ + utfx.calculateCodePoint = function(cp) { + return (cp < 0x80) ? 1 : (cp < 0x800) ? 2 : (cp < 0x10000) ? 3 : 4; + }; + + /** + * Calculates the number of UTF8 bytes required to store UTF8 code points. + * @param {(!function():number|null)} src Code points source as a function returning the next code point respectively + * `null` if there are no more code points left. + * @returns {number} The number of UTF8 bytes required + */ + utfx.calculateUTF8 = function(src) { + var cp, l=0; + while ((cp = src()) !== null) + l += utfx.calculateCodePoint(cp); + return l; + }; + + /** + * Calculates the number of UTF8 code points respectively UTF8 bytes required to store UTF16 char codes. + * @param {(!function():number|null)} src Characters source as a function returning the next char code respectively + * `null` if there are no more characters left. + * @returns {!Array.} The number of UTF8 code points at index 0 and the number of UTF8 bytes required at index 1. + */ + utfx.calculateUTF16asUTF8 = function(src) { + var n=0, l=0; + utfx.UTF16toUTF8(src, function(cp) { + ++n; l += utfx.calculateCodePoint(cp); + }); + return [n,l]; + }; + + return utfx; + }(); + + Date.now = Date.now || function() { return +new Date; }; + + /** + * @type {number} + * @const + * @inner + */ + var BCRYPT_SALT_LEN = 16; + + /** + * @type {number} + * @const + * @inner + */ + var GENSALT_DEFAULT_LOG2_ROUNDS = 10; + + /** + * @type {number} + * @const + * @inner + */ + var BLOWFISH_NUM_ROUNDS = 16; + + /** + * @type {number} + * @const + * @inner + */ + var MAX_EXECUTION_TIME = 100; + + /** + * @type {Array.} + * @const + * @inner + */ + var P_ORIG = [ + 0x243f6a88, 0x85a308d3, 0x13198a2e, 0x03707344, 0xa4093822, + 0x299f31d0, 0x082efa98, 0xec4e6c89, 0x452821e6, 0x38d01377, + 0xbe5466cf, 0x34e90c6c, 0xc0ac29b7, 0xc97c50dd, 0x3f84d5b5, + 0xb5470917, 0x9216d5d9, 0x8979fb1b + ]; + + /** + * @type {Array.} + * @const + * @inner + */ + var S_ORIG = [ + 0xd1310ba6, 0x98dfb5ac, 0x2ffd72db, 0xd01adfb7, 0xb8e1afed, + 0x6a267e96, 0xba7c9045, 0xf12c7f99, 0x24a19947, 0xb3916cf7, + 0x0801f2e2, 0x858efc16, 0x636920d8, 0x71574e69, 0xa458fea3, + 0xf4933d7e, 0x0d95748f, 0x728eb658, 0x718bcd58, 0x82154aee, + 0x7b54a41d, 0xc25a59b5, 0x9c30d539, 0x2af26013, 0xc5d1b023, + 0x286085f0, 0xca417918, 0xb8db38ef, 0x8e79dcb0, 0x603a180e, + 0x6c9e0e8b, 0xb01e8a3e, 0xd71577c1, 0xbd314b27, 0x78af2fda, + 0x55605c60, 0xe65525f3, 0xaa55ab94, 0x57489862, 0x63e81440, + 0x55ca396a, 0x2aab10b6, 0xb4cc5c34, 0x1141e8ce, 0xa15486af, + 0x7c72e993, 0xb3ee1411, 0x636fbc2a, 0x2ba9c55d, 0x741831f6, + 0xce5c3e16, 0x9b87931e, 0xafd6ba33, 0x6c24cf5c, 0x7a325381, + 0x28958677, 0x3b8f4898, 0x6b4bb9af, 0xc4bfe81b, 0x66282193, + 0x61d809cc, 0xfb21a991, 0x487cac60, 0x5dec8032, 0xef845d5d, + 0xe98575b1, 0xdc262302, 0xeb651b88, 0x23893e81, 0xd396acc5, + 0x0f6d6ff3, 0x83f44239, 0x2e0b4482, 0xa4842004, 0x69c8f04a, + 0x9e1f9b5e, 0x21c66842, 0xf6e96c9a, 0x670c9c61, 0xabd388f0, + 0x6a51a0d2, 0xd8542f68, 0x960fa728, 0xab5133a3, 0x6eef0b6c, + 0x137a3be4, 0xba3bf050, 0x7efb2a98, 0xa1f1651d, 0x39af0176, + 0x66ca593e, 0x82430e88, 0x8cee8619, 0x456f9fb4, 0x7d84a5c3, + 0x3b8b5ebe, 0xe06f75d8, 0x85c12073, 0x401a449f, 0x56c16aa6, + 0x4ed3aa62, 0x363f7706, 0x1bfedf72, 0x429b023d, 0x37d0d724, + 0xd00a1248, 0xdb0fead3, 0x49f1c09b, 0x075372c9, 0x80991b7b, + 0x25d479d8, 0xf6e8def7, 0xe3fe501a, 0xb6794c3b, 0x976ce0bd, + 0x04c006ba, 0xc1a94fb6, 0x409f60c4, 0x5e5c9ec2, 0x196a2463, + 0x68fb6faf, 0x3e6c53b5, 0x1339b2eb, 0x3b52ec6f, 0x6dfc511f, + 0x9b30952c, 0xcc814544, 0xaf5ebd09, 0xbee3d004, 0xde334afd, + 0x660f2807, 0x192e4bb3, 0xc0cba857, 0x45c8740f, 0xd20b5f39, + 0xb9d3fbdb, 0x5579c0bd, 0x1a60320a, 0xd6a100c6, 0x402c7279, + 0x679f25fe, 0xfb1fa3cc, 0x8ea5e9f8, 0xdb3222f8, 0x3c7516df, + 0xfd616b15, 0x2f501ec8, 0xad0552ab, 0x323db5fa, 0xfd238760, + 0x53317b48, 0x3e00df82, 0x9e5c57bb, 0xca6f8ca0, 0x1a87562e, + 0xdf1769db, 0xd542a8f6, 0x287effc3, 0xac6732c6, 0x8c4f5573, + 0x695b27b0, 0xbbca58c8, 0xe1ffa35d, 0xb8f011a0, 0x10fa3d98, + 0xfd2183b8, 0x4afcb56c, 0x2dd1d35b, 0x9a53e479, 0xb6f84565, + 0xd28e49bc, 0x4bfb9790, 0xe1ddf2da, 0xa4cb7e33, 0x62fb1341, + 0xcee4c6e8, 0xef20cada, 0x36774c01, 0xd07e9efe, 0x2bf11fb4, + 0x95dbda4d, 0xae909198, 0xeaad8e71, 0x6b93d5a0, 0xd08ed1d0, + 0xafc725e0, 0x8e3c5b2f, 0x8e7594b7, 0x8ff6e2fb, 0xf2122b64, + 0x8888b812, 0x900df01c, 0x4fad5ea0, 0x688fc31c, 0xd1cff191, + 0xb3a8c1ad, 0x2f2f2218, 0xbe0e1777, 0xea752dfe, 0x8b021fa1, + 0xe5a0cc0f, 0xb56f74e8, 0x18acf3d6, 0xce89e299, 0xb4a84fe0, + 0xfd13e0b7, 0x7cc43b81, 0xd2ada8d9, 0x165fa266, 0x80957705, + 0x93cc7314, 0x211a1477, 0xe6ad2065, 0x77b5fa86, 0xc75442f5, + 0xfb9d35cf, 0xebcdaf0c, 0x7b3e89a0, 0xd6411bd3, 0xae1e7e49, + 0x00250e2d, 0x2071b35e, 0x226800bb, 0x57b8e0af, 0x2464369b, + 0xf009b91e, 0x5563911d, 0x59dfa6aa, 0x78c14389, 0xd95a537f, + 0x207d5ba2, 0x02e5b9c5, 0x83260376, 0x6295cfa9, 0x11c81968, + 0x4e734a41, 0xb3472dca, 0x7b14a94a, 0x1b510052, 0x9a532915, + 0xd60f573f, 0xbc9bc6e4, 0x2b60a476, 0x81e67400, 0x08ba6fb5, + 0x571be91f, 0xf296ec6b, 0x2a0dd915, 0xb6636521, 0xe7b9f9b6, + 0xff34052e, 0xc5855664, 0x53b02d5d, 0xa99f8fa1, 0x08ba4799, + 0x6e85076a, 0x4b7a70e9, 0xb5b32944, 0xdb75092e, 0xc4192623, + 0xad6ea6b0, 0x49a7df7d, 0x9cee60b8, 0x8fedb266, 0xecaa8c71, + 0x699a17ff, 0x5664526c, 0xc2b19ee1, 0x193602a5, 0x75094c29, + 0xa0591340, 0xe4183a3e, 0x3f54989a, 0x5b429d65, 0x6b8fe4d6, + 0x99f73fd6, 0xa1d29c07, 0xefe830f5, 0x4d2d38e6, 0xf0255dc1, + 0x4cdd2086, 0x8470eb26, 0x6382e9c6, 0x021ecc5e, 0x09686b3f, + 0x3ebaefc9, 0x3c971814, 0x6b6a70a1, 0x687f3584, 0x52a0e286, + 0xb79c5305, 0xaa500737, 0x3e07841c, 0x7fdeae5c, 0x8e7d44ec, + 0x5716f2b8, 0xb03ada37, 0xf0500c0d, 0xf01c1f04, 0x0200b3ff, + 0xae0cf51a, 0x3cb574b2, 0x25837a58, 0xdc0921bd, 0xd19113f9, + 0x7ca92ff6, 0x94324773, 0x22f54701, 0x3ae5e581, 0x37c2dadc, + 0xc8b57634, 0x9af3dda7, 0xa9446146, 0x0fd0030e, 0xecc8c73e, + 0xa4751e41, 0xe238cd99, 0x3bea0e2f, 0x3280bba1, 0x183eb331, + 0x4e548b38, 0x4f6db908, 0x6f420d03, 0xf60a04bf, 0x2cb81290, + 0x24977c79, 0x5679b072, 0xbcaf89af, 0xde9a771f, 0xd9930810, + 0xb38bae12, 0xdccf3f2e, 0x5512721f, 0x2e6b7124, 0x501adde6, + 0x9f84cd87, 0x7a584718, 0x7408da17, 0xbc9f9abc, 0xe94b7d8c, + 0xec7aec3a, 0xdb851dfa, 0x63094366, 0xc464c3d2, 0xef1c1847, + 0x3215d908, 0xdd433b37, 0x24c2ba16, 0x12a14d43, 0x2a65c451, + 0x50940002, 0x133ae4dd, 0x71dff89e, 0x10314e55, 0x81ac77d6, + 0x5f11199b, 0x043556f1, 0xd7a3c76b, 0x3c11183b, 0x5924a509, + 0xf28fe6ed, 0x97f1fbfa, 0x9ebabf2c, 0x1e153c6e, 0x86e34570, + 0xeae96fb1, 0x860e5e0a, 0x5a3e2ab3, 0x771fe71c, 0x4e3d06fa, + 0x2965dcb9, 0x99e71d0f, 0x803e89d6, 0x5266c825, 0x2e4cc978, + 0x9c10b36a, 0xc6150eba, 0x94e2ea78, 0xa5fc3c53, 0x1e0a2df4, + 0xf2f74ea7, 0x361d2b3d, 0x1939260f, 0x19c27960, 0x5223a708, + 0xf71312b6, 0xebadfe6e, 0xeac31f66, 0xe3bc4595, 0xa67bc883, + 0xb17f37d1, 0x018cff28, 0xc332ddef, 0xbe6c5aa5, 0x65582185, + 0x68ab9802, 0xeecea50f, 0xdb2f953b, 0x2aef7dad, 0x5b6e2f84, + 0x1521b628, 0x29076170, 0xecdd4775, 0x619f1510, 0x13cca830, + 0xeb61bd96, 0x0334fe1e, 0xaa0363cf, 0xb5735c90, 0x4c70a239, + 0xd59e9e0b, 0xcbaade14, 0xeecc86bc, 0x60622ca7, 0x9cab5cab, + 0xb2f3846e, 0x648b1eaf, 0x19bdf0ca, 0xa02369b9, 0x655abb50, + 0x40685a32, 0x3c2ab4b3, 0x319ee9d5, 0xc021b8f7, 0x9b540b19, + 0x875fa099, 0x95f7997e, 0x623d7da8, 0xf837889a, 0x97e32d77, + 0x11ed935f, 0x16681281, 0x0e358829, 0xc7e61fd6, 0x96dedfa1, + 0x7858ba99, 0x57f584a5, 0x1b227263, 0x9b83c3ff, 0x1ac24696, + 0xcdb30aeb, 0x532e3054, 0x8fd948e4, 0x6dbc3128, 0x58ebf2ef, + 0x34c6ffea, 0xfe28ed61, 0xee7c3c73, 0x5d4a14d9, 0xe864b7e3, + 0x42105d14, 0x203e13e0, 0x45eee2b6, 0xa3aaabea, 0xdb6c4f15, + 0xfacb4fd0, 0xc742f442, 0xef6abbb5, 0x654f3b1d, 0x41cd2105, + 0xd81e799e, 0x86854dc7, 0xe44b476a, 0x3d816250, 0xcf62a1f2, + 0x5b8d2646, 0xfc8883a0, 0xc1c7b6a3, 0x7f1524c3, 0x69cb7492, + 0x47848a0b, 0x5692b285, 0x095bbf00, 0xad19489d, 0x1462b174, + 0x23820e00, 0x58428d2a, 0x0c55f5ea, 0x1dadf43e, 0x233f7061, + 0x3372f092, 0x8d937e41, 0xd65fecf1, 0x6c223bdb, 0x7cde3759, + 0xcbee7460, 0x4085f2a7, 0xce77326e, 0xa6078084, 0x19f8509e, + 0xe8efd855, 0x61d99735, 0xa969a7aa, 0xc50c06c2, 0x5a04abfc, + 0x800bcadc, 0x9e447a2e, 0xc3453484, 0xfdd56705, 0x0e1e9ec9, + 0xdb73dbd3, 0x105588cd, 0x675fda79, 0xe3674340, 0xc5c43465, + 0x713e38d8, 0x3d28f89e, 0xf16dff20, 0x153e21e7, 0x8fb03d4a, + 0xe6e39f2b, 0xdb83adf7, 0xe93d5a68, 0x948140f7, 0xf64c261c, + 0x94692934, 0x411520f7, 0x7602d4f7, 0xbcf46b2e, 0xd4a20068, + 0xd4082471, 0x3320f46a, 0x43b7d4b7, 0x500061af, 0x1e39f62e, + 0x97244546, 0x14214f74, 0xbf8b8840, 0x4d95fc1d, 0x96b591af, + 0x70f4ddd3, 0x66a02f45, 0xbfbc09ec, 0x03bd9785, 0x7fac6dd0, + 0x31cb8504, 0x96eb27b3, 0x55fd3941, 0xda2547e6, 0xabca0a9a, + 0x28507825, 0x530429f4, 0x0a2c86da, 0xe9b66dfb, 0x68dc1462, + 0xd7486900, 0x680ec0a4, 0x27a18dee, 0x4f3ffea2, 0xe887ad8c, + 0xb58ce006, 0x7af4d6b6, 0xaace1e7c, 0xd3375fec, 0xce78a399, + 0x406b2a42, 0x20fe9e35, 0xd9f385b9, 0xee39d7ab, 0x3b124e8b, + 0x1dc9faf7, 0x4b6d1856, 0x26a36631, 0xeae397b2, 0x3a6efa74, + 0xdd5b4332, 0x6841e7f7, 0xca7820fb, 0xfb0af54e, 0xd8feb397, + 0x454056ac, 0xba489527, 0x55533a3a, 0x20838d87, 0xfe6ba9b7, + 0xd096954b, 0x55a867bc, 0xa1159a58, 0xcca92963, 0x99e1db33, + 0xa62a4a56, 0x3f3125f9, 0x5ef47e1c, 0x9029317c, 0xfdf8e802, + 0x04272f70, 0x80bb155c, 0x05282ce3, 0x95c11548, 0xe4c66d22, + 0x48c1133f, 0xc70f86dc, 0x07f9c9ee, 0x41041f0f, 0x404779a4, + 0x5d886e17, 0x325f51eb, 0xd59bc0d1, 0xf2bcc18f, 0x41113564, + 0x257b7834, 0x602a9c60, 0xdff8e8a3, 0x1f636c1b, 0x0e12b4c2, + 0x02e1329e, 0xaf664fd1, 0xcad18115, 0x6b2395e0, 0x333e92e1, + 0x3b240b62, 0xeebeb922, 0x85b2a20e, 0xe6ba0d99, 0xde720c8c, + 0x2da2f728, 0xd0127845, 0x95b794fd, 0x647d0862, 0xe7ccf5f0, + 0x5449a36f, 0x877d48fa, 0xc39dfd27, 0xf33e8d1e, 0x0a476341, + 0x992eff74, 0x3a6f6eab, 0xf4f8fd37, 0xa812dc60, 0xa1ebddf8, + 0x991be14c, 0xdb6e6b0d, 0xc67b5510, 0x6d672c37, 0x2765d43b, + 0xdcd0e804, 0xf1290dc7, 0xcc00ffa3, 0xb5390f92, 0x690fed0b, + 0x667b9ffb, 0xcedb7d9c, 0xa091cf0b, 0xd9155ea3, 0xbb132f88, + 0x515bad24, 0x7b9479bf, 0x763bd6eb, 0x37392eb3, 0xcc115979, + 0x8026e297, 0xf42e312d, 0x6842ada7, 0xc66a2b3b, 0x12754ccc, + 0x782ef11c, 0x6a124237, 0xb79251e7, 0x06a1bbe6, 0x4bfb6350, + 0x1a6b1018, 0x11caedfa, 0x3d25bdd8, 0xe2e1c3c9, 0x44421659, + 0x0a121386, 0xd90cec6e, 0xd5abea2a, 0x64af674e, 0xda86a85f, + 0xbebfe988, 0x64e4c3fe, 0x9dbc8057, 0xf0f7c086, 0x60787bf8, + 0x6003604d, 0xd1fd8346, 0xf6381fb0, 0x7745ae04, 0xd736fccc, + 0x83426b33, 0xf01eab71, 0xb0804187, 0x3c005e5f, 0x77a057be, + 0xbde8ae24, 0x55464299, 0xbf582e61, 0x4e58f48f, 0xf2ddfda2, + 0xf474ef38, 0x8789bdc2, 0x5366f9c3, 0xc8b38e74, 0xb475f255, + 0x46fcd9b9, 0x7aeb2661, 0x8b1ddf84, 0x846a0e79, 0x915f95e2, + 0x466e598e, 0x20b45770, 0x8cd55591, 0xc902de4c, 0xb90bace1, + 0xbb8205d0, 0x11a86248, 0x7574a99e, 0xb77f19b6, 0xe0a9dc09, + 0x662d09a1, 0xc4324633, 0xe85a1f02, 0x09f0be8c, 0x4a99a025, + 0x1d6efe10, 0x1ab93d1d, 0x0ba5a4df, 0xa186f20f, 0x2868f169, + 0xdcb7da83, 0x573906fe, 0xa1e2ce9b, 0x4fcd7f52, 0x50115e01, + 0xa70683fa, 0xa002b5c4, 0x0de6d027, 0x9af88c27, 0x773f8641, + 0xc3604c06, 0x61a806b5, 0xf0177a28, 0xc0f586e0, 0x006058aa, + 0x30dc7d62, 0x11e69ed7, 0x2338ea63, 0x53c2dd94, 0xc2c21634, + 0xbbcbee56, 0x90bcb6de, 0xebfc7da1, 0xce591d76, 0x6f05e409, + 0x4b7c0188, 0x39720a3d, 0x7c927c24, 0x86e3725f, 0x724d9db9, + 0x1ac15bb4, 0xd39eb8fc, 0xed545578, 0x08fca5b5, 0xd83d7cd3, + 0x4dad0fc4, 0x1e50ef5e, 0xb161e6f8, 0xa28514d9, 0x6c51133c, + 0x6fd5c7e7, 0x56e14ec4, 0x362abfce, 0xddc6c837, 0xd79a3234, + 0x92638212, 0x670efa8e, 0x406000e0, 0x3a39ce37, 0xd3faf5cf, + 0xabc27737, 0x5ac52d1b, 0x5cb0679e, 0x4fa33742, 0xd3822740, + 0x99bc9bbe, 0xd5118e9d, 0xbf0f7315, 0xd62d1c7e, 0xc700c47b, + 0xb78c1b6b, 0x21a19045, 0xb26eb1be, 0x6a366eb4, 0x5748ab2f, + 0xbc946e79, 0xc6a376d2, 0x6549c2c8, 0x530ff8ee, 0x468dde7d, + 0xd5730a1d, 0x4cd04dc6, 0x2939bbdb, 0xa9ba4650, 0xac9526e8, + 0xbe5ee304, 0xa1fad5f0, 0x6a2d519a, 0x63ef8ce2, 0x9a86ee22, + 0xc089c2b8, 0x43242ef6, 0xa51e03aa, 0x9cf2d0a4, 0x83c061ba, + 0x9be96a4d, 0x8fe51550, 0xba645bd6, 0x2826a2f9, 0xa73a3ae1, + 0x4ba99586, 0xef5562e9, 0xc72fefd3, 0xf752f7da, 0x3f046f69, + 0x77fa0a59, 0x80e4a915, 0x87b08601, 0x9b09e6ad, 0x3b3ee593, + 0xe990fd5a, 0x9e34d797, 0x2cf0b7d9, 0x022b8b51, 0x96d5ac3a, + 0x017da67d, 0xd1cf3ed6, 0x7c7d2d28, 0x1f9f25cf, 0xadf2b89b, + 0x5ad6b472, 0x5a88f54c, 0xe029ac71, 0xe019a5e6, 0x47b0acfd, + 0xed93fa9b, 0xe8d3c48d, 0x283b57cc, 0xf8d56629, 0x79132e28, + 0x785f0191, 0xed756055, 0xf7960e44, 0xe3d35e8c, 0x15056dd4, + 0x88f46dba, 0x03a16125, 0x0564f0bd, 0xc3eb9e15, 0x3c9057a2, + 0x97271aec, 0xa93a072a, 0x1b3f6d9b, 0x1e6321f5, 0xf59c66fb, + 0x26dcf319, 0x7533d928, 0xb155fdf5, 0x03563482, 0x8aba3cbb, + 0x28517711, 0xc20ad9f8, 0xabcc5167, 0xccad925f, 0x4de81751, + 0x3830dc8e, 0x379d5862, 0x9320f991, 0xea7a90c2, 0xfb3e7bce, + 0x5121ce64, 0x774fbe32, 0xa8b6e37e, 0xc3293d46, 0x48de5369, + 0x6413e680, 0xa2ae0810, 0xdd6db224, 0x69852dfd, 0x09072166, + 0xb39a460a, 0x6445c0dd, 0x586cdecf, 0x1c20c8ae, 0x5bbef7dd, + 0x1b588d40, 0xccd2017f, 0x6bb4e3bb, 0xdda26a7e, 0x3a59ff45, + 0x3e350a44, 0xbcb4cdd5, 0x72eacea8, 0xfa6484bb, 0x8d6612ae, + 0xbf3c6f47, 0xd29be463, 0x542f5d9e, 0xaec2771b, 0xf64e6370, + 0x740e0d8d, 0xe75b1357, 0xf8721671, 0xaf537d5d, 0x4040cb08, + 0x4eb4e2cc, 0x34d2466a, 0x0115af84, 0xe1b00428, 0x95983a1d, + 0x06b89fb4, 0xce6ea048, 0x6f3f3b82, 0x3520ab82, 0x011a1d4b, + 0x277227f8, 0x611560b1, 0xe7933fdc, 0xbb3a792b, 0x344525bd, + 0xa08839e1, 0x51ce794b, 0x2f32c9b7, 0xa01fbac9, 0xe01cc87e, + 0xbcc7d1f6, 0xcf0111c3, 0xa1e8aac7, 0x1a908749, 0xd44fbd9a, + 0xd0dadecb, 0xd50ada38, 0x0339c32a, 0xc6913667, 0x8df9317c, + 0xe0b12b4f, 0xf79e59b7, 0x43f5bb3a, 0xf2d519ff, 0x27d9459c, + 0xbf97222c, 0x15e6fc2a, 0x0f91fc71, 0x9b941525, 0xfae59361, + 0xceb69ceb, 0xc2a86459, 0x12baa8d1, 0xb6c1075e, 0xe3056a0c, + 0x10d25065, 0xcb03a442, 0xe0ec6e0e, 0x1698db3b, 0x4c98a0be, + 0x3278e964, 0x9f1f9532, 0xe0d392df, 0xd3a0342b, 0x8971f21e, + 0x1b0a7441, 0x4ba3348c, 0xc5be7120, 0xc37632d8, 0xdf359f8d, + 0x9b992f2e, 0xe60b6f47, 0x0fe3f11d, 0xe54cda54, 0x1edad891, + 0xce6279cf, 0xcd3e7e6f, 0x1618b166, 0xfd2c1d05, 0x848fd2c5, + 0xf6fb2299, 0xf523f357, 0xa6327623, 0x93a83531, 0x56cccd02, + 0xacf08162, 0x5a75ebb5, 0x6e163697, 0x88d273cc, 0xde966292, + 0x81b949d0, 0x4c50901b, 0x71c65614, 0xe6c6c7bd, 0x327a140a, + 0x45e1d006, 0xc3f27b9a, 0xc9aa53fd, 0x62a80f00, 0xbb25bfe2, + 0x35bdd2f6, 0x71126905, 0xb2040222, 0xb6cbcf7c, 0xcd769c2b, + 0x53113ec0, 0x1640e3d3, 0x38abbd60, 0x2547adf0, 0xba38209c, + 0xf746ce76, 0x77afa1c5, 0x20756060, 0x85cbfe4e, 0x8ae88dd8, + 0x7aaaf9b0, 0x4cf9aa7e, 0x1948c25c, 0x02fb8a8c, 0x01c36ae4, + 0xd6ebe1f9, 0x90d4f869, 0xa65cdea0, 0x3f09252d, 0xc208e69f, + 0xb74e6132, 0xce77e25b, 0x578fdfe3, 0x3ac372e6 + ]; + + /** + * @type {Array.} + * @const + * @inner + */ + var C_ORIG = [ + 0x4f727068, 0x65616e42, 0x65686f6c, 0x64657253, 0x63727944, + 0x6f756274 + ]; + + /** + * @param {Array.} lr + * @param {number} off + * @param {Array.} P + * @param {Array.} S + * @returns {Array.} + * @inner + */ + function _encipher(lr, off, P, S) { // This is our bottleneck: 1714/1905 ticks / 90% - see profile.txt + var n, + l = lr[off], + r = lr[off + 1]; + + l ^= P[0]; + + /* + for (var i=0, k=BLOWFISH_NUM_ROUNDS-2; i<=k;) + // Feistel substitution on left word + n = S[l >>> 24], + n += S[0x100 | ((l >> 16) & 0xff)], + n ^= S[0x200 | ((l >> 8) & 0xff)], + n += S[0x300 | (l & 0xff)], + r ^= n ^ P[++i], + // Feistel substitution on right word + n = S[r >>> 24], + n += S[0x100 | ((r >> 16) & 0xff)], + n ^= S[0x200 | ((r >> 8) & 0xff)], + n += S[0x300 | (r & 0xff)], + l ^= n ^ P[++i]; + */ + + //The following is an unrolled version of the above loop. + //Iteration 0 + n = S[l >>> 24]; + n += S[0x100 | ((l >> 16) & 0xff)]; + n ^= S[0x200 | ((l >> 8) & 0xff)]; + n += S[0x300 | (l & 0xff)]; + r ^= n ^ P[1]; + n = S[r >>> 24]; + n += S[0x100 | ((r >> 16) & 0xff)]; + n ^= S[0x200 | ((r >> 8) & 0xff)]; + n += S[0x300 | (r & 0xff)]; + l ^= n ^ P[2]; + //Iteration 1 + n = S[l >>> 24]; + n += S[0x100 | ((l >> 16) & 0xff)]; + n ^= S[0x200 | ((l >> 8) & 0xff)]; + n += S[0x300 | (l & 0xff)]; + r ^= n ^ P[3]; + n = S[r >>> 24]; + n += S[0x100 | ((r >> 16) & 0xff)]; + n ^= S[0x200 | ((r >> 8) & 0xff)]; + n += S[0x300 | (r & 0xff)]; + l ^= n ^ P[4]; + //Iteration 2 + n = S[l >>> 24]; + n += S[0x100 | ((l >> 16) & 0xff)]; + n ^= S[0x200 | ((l >> 8) & 0xff)]; + n += S[0x300 | (l & 0xff)]; + r ^= n ^ P[5]; + n = S[r >>> 24]; + n += S[0x100 | ((r >> 16) & 0xff)]; + n ^= S[0x200 | ((r >> 8) & 0xff)]; + n += S[0x300 | (r & 0xff)]; + l ^= n ^ P[6]; + //Iteration 3 + n = S[l >>> 24]; + n += S[0x100 | ((l >> 16) & 0xff)]; + n ^= S[0x200 | ((l >> 8) & 0xff)]; + n += S[0x300 | (l & 0xff)]; + r ^= n ^ P[7]; + n = S[r >>> 24]; + n += S[0x100 | ((r >> 16) & 0xff)]; + n ^= S[0x200 | ((r >> 8) & 0xff)]; + n += S[0x300 | (r & 0xff)]; + l ^= n ^ P[8]; + //Iteration 4 + n = S[l >>> 24]; + n += S[0x100 | ((l >> 16) & 0xff)]; + n ^= S[0x200 | ((l >> 8) & 0xff)]; + n += S[0x300 | (l & 0xff)]; + r ^= n ^ P[9]; + n = S[r >>> 24]; + n += S[0x100 | ((r >> 16) & 0xff)]; + n ^= S[0x200 | ((r >> 8) & 0xff)]; + n += S[0x300 | (r & 0xff)]; + l ^= n ^ P[10]; + //Iteration 5 + n = S[l >>> 24]; + n += S[0x100 | ((l >> 16) & 0xff)]; + n ^= S[0x200 | ((l >> 8) & 0xff)]; + n += S[0x300 | (l & 0xff)]; + r ^= n ^ P[11]; + n = S[r >>> 24]; + n += S[0x100 | ((r >> 16) & 0xff)]; + n ^= S[0x200 | ((r >> 8) & 0xff)]; + n += S[0x300 | (r & 0xff)]; + l ^= n ^ P[12]; + //Iteration 6 + n = S[l >>> 24]; + n += S[0x100 | ((l >> 16) & 0xff)]; + n ^= S[0x200 | ((l >> 8) & 0xff)]; + n += S[0x300 | (l & 0xff)]; + r ^= n ^ P[13]; + n = S[r >>> 24]; + n += S[0x100 | ((r >> 16) & 0xff)]; + n ^= S[0x200 | ((r >> 8) & 0xff)]; + n += S[0x300 | (r & 0xff)]; + l ^= n ^ P[14]; + //Iteration 7 + n = S[l >>> 24]; + n += S[0x100 | ((l >> 16) & 0xff)]; + n ^= S[0x200 | ((l >> 8) & 0xff)]; + n += S[0x300 | (l & 0xff)]; + r ^= n ^ P[15]; + n = S[r >>> 24]; + n += S[0x100 | ((r >> 16) & 0xff)]; + n ^= S[0x200 | ((r >> 8) & 0xff)]; + n += S[0x300 | (r & 0xff)]; + l ^= n ^ P[16]; + + lr[off] = r ^ P[BLOWFISH_NUM_ROUNDS + 1]; + lr[off + 1] = l; + return lr; + } + + /** + * @param {Array.} data + * @param {number} offp + * @returns {{key: number, offp: number}} + * @inner + */ + function _streamtoword(data, offp) { + for (var i = 0, word = 0; i < 4; ++i) + word = (word << 8) | (data[offp] & 0xff), + offp = (offp + 1) % data.length; + return { key: word, offp: offp }; + } + + /** + * @param {Array.} key + * @param {Array.} P + * @param {Array.} S + * @inner + */ + function _key(key, P, S) { + var offset = 0, + lr = [0, 0], + plen = P.length, + slen = S.length, + sw; + for (var i = 0; i < plen; i++) + sw = _streamtoword(key, offset), + offset = sw.offp, + P[i] = P[i] ^ sw.key; + for (i = 0; i < plen; i += 2) + lr = _encipher(lr, 0, P, S), + P[i] = lr[0], + P[i + 1] = lr[1]; + for (i = 0; i < slen; i += 2) + lr = _encipher(lr, 0, P, S), + S[i] = lr[0], + S[i + 1] = lr[1]; + } + + /** + * Expensive key schedule Blowfish. + * @param {Array.} data + * @param {Array.} key + * @param {Array.} P + * @param {Array.} S + * @inner + */ + function _ekskey(data, key, P, S) { + var offp = 0, + lr = [0, 0], + plen = P.length, + slen = S.length, + sw; + for (var i = 0; i < plen; i++) + sw = _streamtoword(key, offp), + offp = sw.offp, + P[i] = P[i] ^ sw.key; + offp = 0; + for (i = 0; i < plen; i += 2) + sw = _streamtoword(data, offp), + offp = sw.offp, + lr[0] ^= sw.key, + sw = _streamtoword(data, offp), + offp = sw.offp, + lr[1] ^= sw.key, + lr = _encipher(lr, 0, P, S), + P[i] = lr[0], + P[i + 1] = lr[1]; + for (i = 0; i < slen; i += 2) + sw = _streamtoword(data, offp), + offp = sw.offp, + lr[0] ^= sw.key, + sw = _streamtoword(data, offp), + offp = sw.offp, + lr[1] ^= sw.key, + lr = _encipher(lr, 0, P, S), + S[i] = lr[0], + S[i + 1] = lr[1]; + } + + /** + * Internaly crypts a string. + * @param {Array.} b Bytes to crypt + * @param {Array.} salt Salt bytes to use + * @param {number} rounds Number of rounds + * @param {function(Error, Array.=)=} callback Callback receiving the error, if any, and the resulting bytes. If + * omitted, the operation will be performed synchronously. + * @param {function(number)=} progressCallback Callback called with the current progress + * @returns {!Array.|undefined} Resulting bytes if callback has been omitted, otherwise `undefined` + * @inner + */ + function _crypt(b, salt, rounds, callback, progressCallback) { + var cdata = C_ORIG.slice(), + clen = cdata.length, + err; + + // Validate + if (rounds < 4 || rounds > 31) { + err = Error("Illegal number of rounds (4-31): "+rounds); + if (callback) { + nextTick(callback.bind(this, err)); + return; + } else + throw err; + } + if (salt.length !== BCRYPT_SALT_LEN) { + err =Error("Illegal salt length: "+salt.length+" != "+BCRYPT_SALT_LEN); + if (callback) { + nextTick(callback.bind(this, err)); + return; + } else + throw err; + } + rounds = (1 << rounds) >>> 0; + + var P, S, i = 0, j; + + //Use typed arrays when available - huge speedup! + if (Int32Array) { + P = new Int32Array(P_ORIG); + S = new Int32Array(S_ORIG); + } else { + P = P_ORIG.slice(); + S = S_ORIG.slice(); + } + + _ekskey(salt, b, P, S); + + /** + * Calcualtes the next round. + * @returns {Array.|undefined} Resulting array if callback has been omitted, otherwise `undefined` + * @inner + */ + function next() { + if (progressCallback) + progressCallback(i / rounds); + if (i < rounds) { + var start = Date.now(); + for (; i < rounds;) { + i = i + 1; + _key(b, P, S); + _key(salt, P, S); + if (Date.now() - start > MAX_EXECUTION_TIME) + break; + } + } else { + for (i = 0; i < 64; i++) + for (j = 0; j < (clen >> 1); j++) + _encipher(cdata, j << 1, P, S); + var ret = []; + for (i = 0; i < clen; i++) + ret.push(((cdata[i] >> 24) & 0xff) >>> 0), + ret.push(((cdata[i] >> 16) & 0xff) >>> 0), + ret.push(((cdata[i] >> 8) & 0xff) >>> 0), + ret.push((cdata[i] & 0xff) >>> 0); + if (callback) { + callback(null, ret); + return; + } else + return ret; + } + if (callback) + nextTick(next); + } + + // Async + if (typeof callback !== 'undefined') { + next(); + + // Sync + } else { + var res; + while (true) + if (typeof(res = next()) !== 'undefined') + return res || []; + } + } + + /** + * Internally hashes a string. + * @param {string} s String to hash + * @param {?string} salt Salt to use, actually never null + * @param {function(Error, string=)=} callback Callback receiving the error, if any, and the resulting hash. If omitted, + * hashing is perormed synchronously. + * @param {function(number)=} progressCallback Callback called with the current progress + * @returns {string|undefined} Resulting hash if callback has been omitted, otherwise `undefined` + * @inner + */ + function _hash(s, salt, callback, progressCallback) { + var err; + if (typeof s !== 'string' || typeof salt !== 'string') { + err = Error("Invalid string / salt: Not a string"); + if (callback) { + nextTick(callback.bind(this, err)); + return; + } + else + throw err; + } + + // Validate the salt + var minor, offset; + if (salt.charAt(0) !== '$' || salt.charAt(1) !== '2') { + err = Error("Invalid salt version: "+salt.substring(0,2)); + if (callback) { + nextTick(callback.bind(this, err)); + return; + } + else + throw err; + } + if (salt.charAt(2) === '$') + minor = String.fromCharCode(0), + offset = 3; + else { + minor = salt.charAt(2); + if ((minor !== 'a' && minor !== 'b' && minor !== 'y') || salt.charAt(3) !== '$') { + err = Error("Invalid salt revision: "+salt.substring(2,4)); + if (callback) { + nextTick(callback.bind(this, err)); + return; + } else + throw err; + } + offset = 4; + } + + // Extract number of rounds + if (salt.charAt(offset + 2) > '$') { + err = Error("Missing salt rounds"); + if (callback) { + nextTick(callback.bind(this, err)); + return; + } else + throw err; + } + var r1 = parseInt(salt.substring(offset, offset + 1), 10) * 10, + r2 = parseInt(salt.substring(offset + 1, offset + 2), 10), + rounds = r1 + r2, + real_salt = salt.substring(offset + 3, offset + 25); + s += minor >= 'a' ? "\x00" : ""; + + var passwordb = stringToBytes(s), + saltb = base64_decode(real_salt, BCRYPT_SALT_LEN); + + /** + * Finishes hashing. + * @param {Array.} bytes Byte array + * @returns {string} + * @inner + */ + function finish(bytes) { + var res = []; + res.push("$2"); + if (minor >= 'a') + res.push(minor); + res.push("$"); + if (rounds < 10) + res.push("0"); + res.push(rounds.toString()); + res.push("$"); + res.push(base64_encode(saltb, saltb.length)); + res.push(base64_encode(bytes, C_ORIG.length * 4 - 1)); + return res.join(''); + } + + // Sync + if (typeof callback == 'undefined') + return finish(_crypt(passwordb, saltb, rounds)); + + // Async + else { + _crypt(passwordb, saltb, rounds, function(err, bytes) { + if (err) + callback(err, null); + else + callback(null, finish(bytes)); + }, progressCallback); + } + } + + /** + * Encodes a byte array to base64 with up to len bytes of input, using the custom bcrypt alphabet. + * @function + * @param {!Array.} b Byte array + * @param {number} len Maximum input length + * @returns {string} + * @expose + */ + bcrypt.encodeBase64 = base64_encode; + + /** + * Decodes a base64 encoded string to up to len bytes of output, using the custom bcrypt alphabet. + * @function + * @param {string} s String to decode + * @param {number} len Maximum output length + * @returns {!Array.} + * @expose + */ + bcrypt.decodeBase64 = base64_decode; + + return bcrypt; +})); diff --git a/qortal-ui-crypto/api/deps/broken-ripemd160.js b/qortal-ui-crypto/api/deps/broken-ripemd160.js new file mode 100644 index 00000000..9045ef21 --- /dev/null +++ b/qortal-ui-crypto/api/deps/broken-ripemd160.js @@ -0,0 +1,180 @@ +// "Generated from Java with JSweet 1.0.0 - http://www.jsweet.org"; +// BAD IMPLEMENTATION. BROKEN, BUT MUST KEEP CAUSE OF NETWORK +//const RIPEMD160 = (function () { +// == Convert to ES6 module for export == // +const RIPEMD160 = (function () { + function RIPEMD160() { + this.MDbuf = []; + this.MDbuf[0] = 1732584193; + this.MDbuf[1] = -271733879; + this.MDbuf[2] = -1732584194; + this.MDbuf[3] = 271733878; + this.MDbuf[4] = -1009589776; + this.working = new Int32Array(16); + + this.working_ptr = 0; + this.msglen = 0; + } + RIPEMD160.prototype.reset = function () { + this.MDbuf = []; + this.MDbuf[0] = 1732584193; + this.MDbuf[1] = -271733879; + this.MDbuf[2] = -1732584194; + this.MDbuf[3] = 271733878; + this.MDbuf[4] = -1009589776; + this.working = new Int32Array(16); + this.working_ptr = 0; + this.msglen = 0; + }; + RIPEMD160.prototype.compress = function (X) { + var index = 0; + var a; + var b; + var c; + var d; + var e; + var A; + var B; + var C; + var D; + var E; + var temp; + var s; + A = a = this.MDbuf[0]; + B = b = this.MDbuf[1]; + C = c = this.MDbuf[2]; + D = d = this.MDbuf[3]; + E = e = this.MDbuf[4]; + for (; index < 16; index++) { + temp = a + (b ^ c ^ d) + X[RIPEMD160.IndexArray[0][index]]; + a = e; + e = d; + d = (c << 10) | (c >>> 22); + c = b; + s = RIPEMD160.ArgArray[0][index]; + b = ((temp << s) | (temp >>> (32 - s))) + a; + temp = A + (B ^ (C | ~D)) + X[RIPEMD160.IndexArray[1][index]] + 1352829926; + A = E; + E = D; + D = (C << 10) | (C >>> 22); + C = B; + s = RIPEMD160.ArgArray[1][index]; + B = ((temp << s) | (temp >>> (32 - s))) + A; + } + for (; index < 32; index++) { + temp = a + ((b & c) | (~b & d)) + X[RIPEMD160.IndexArray[0][index]] + 1518500249; + a = e; + e = d; + d = (c << 10) | (c >>> 22); + c = b; + s = RIPEMD160.ArgArray[0][index]; + b = ((temp << s) | (temp >>> (32 - s))) + a; + temp = A + ((B & D) | (C & ~D)) + X[RIPEMD160.IndexArray[1][index]] + 1548603684; + A = E; + E = D; + D = (C << 10) | (C >>> 22); + C = B; + s = RIPEMD160.ArgArray[1][index]; + B = ((temp << s) | (temp >>> (32 - s))) + A; + } + for (; index < 48; index++) { + temp = a + ((b | ~c) ^ d) + X[RIPEMD160.IndexArray[0][index]] + 1859775393; + a = e; + e = d; + d = (c << 10) | (c >>> 22); + c = b; + s = RIPEMD160.ArgArray[0][index]; + b = ((temp << s) | (temp >>> (32 - s))) + a; + temp = A + ((B | ~C) ^ D) + X[RIPEMD160.IndexArray[1][index]] + 1836072691; + A = E; + E = D; + D = (C << 10) | (C >>> 22); + C = B; + s = RIPEMD160.ArgArray[1][index]; + B = ((temp << s) | (temp >>> (32 - s))) + A; + } + for (; index < 64; index++) { + temp = a + ((b & d) | (c & ~d)) + X[RIPEMD160.IndexArray[0][index]] + -1894007588; + a = e; + e = d; + d = (c << 10) | (c >>> 22); + c = b; + s = RIPEMD160.ArgArray[0][index]; + b = ((temp << s) | (temp >>> (32 - s))) + a; + temp = A + ((B & C) | (~B & D)) + X[RIPEMD160.IndexArray[1][index]] + 2053994217; + A = E; + E = D; + D = (C << 10) | (C >>> 22); + C = B; + s = RIPEMD160.ArgArray[1][index]; + B = ((temp << s) | (temp >>> (32 - s))) + A; + } + for (; index < 80; index++) { + temp = a + (b ^ (c | ~d)) + X[RIPEMD160.IndexArray[0][index]] + -1454113458; + a = e; + e = d; + d = (c << 10) | (c >>> 22); + c = b; + s = RIPEMD160.ArgArray[0][index]; + b = ((temp << s) | (temp >>> (32 - s))) + a; + temp = A + (B ^ C ^ D) + X[RIPEMD160.IndexArray[1][index]]; + A = E; + E = D; + D = (C << 10) | (C >>> 22); + C = B; + s = RIPEMD160.ArgArray[1][index]; + B = ((temp << s) | (temp >>> (32 - s))) + A; + } + D += c + this.MDbuf[1]; + this.MDbuf[1] = this.MDbuf[2] + d + E; + this.MDbuf[2] = this.MDbuf[3] + e + A; + this.MDbuf[3] = this.MDbuf[4] + a + B; + this.MDbuf[4] = this.MDbuf[0] + b + C; + this.MDbuf[0] = D; + }; + RIPEMD160.prototype.MDfinish = function (array, lswlen, mswlen) { + var X = array; + X[(lswlen >> 2) & 15] ^= 1 << (((lswlen & 3) << 3) + 7); + if (((lswlen & 63) > 55)) { + this.compress(X); + for (var i = 0; i < 14; i++) { + X[i] = 0; + } + } + X[14] = lswlen << 3; + X[15] = (lswlen >> 29) | (mswlen << 3); + this.compress(X); + }; + RIPEMD160.prototype.update = function (input) { + for (var i = 0; i < input.length; i++) { + this.working[this.working_ptr >> 2] ^= input[i] << ((this.working_ptr & 3) << 3); + this.working_ptr++; + if ((this.working_ptr == 64)) { + this.compress(this.working); + for (var j = 0; j < 16; j++) { + this.working[j] = 0; + } + this.working_ptr = 0; + } + } + this.msglen += input.length; + }; + RIPEMD160.prototype.digestBin = function () { + this.MDfinish(this.working, this.msglen, 0); + //var res = new Int8Array(); + var res = []; + for (var i = 0; i < 20; i++) { + res[i] = ((this.MDbuf[i >> 2] >>> ((i & 3) << 3)) & 255); + } + return new Uint8Array(res); + }; + RIPEMD160.prototype.digest = function (input) { + this.update(new Int8Array(input)); + return this.digestBin(); + }; + RIPEMD160.ArgArray = [[11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8, 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12, 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5, 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12, 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6], [8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6, 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11, 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5, 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8, 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11]]; + RIPEMD160.IndexArray = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8, 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12, 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2, 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13], [5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12, 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2, 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13, 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14, 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11]]; + return RIPEMD160; +})(); + +export default RIPEMD160 diff --git a/qortal-ui-crypto/api/deps/deps.js b/qortal-ui-crypto/api/deps/deps.js new file mode 100644 index 00000000..48eb8130 --- /dev/null +++ b/qortal-ui-crypto/api/deps/deps.js @@ -0,0 +1,3 @@ +export { default as Base58 } from './Base58.js' + +export { default as utils } from './utils.js' diff --git a/qortal-ui-crypto/api/deps/ed2curve.js b/qortal-ui-crypto/api/deps/ed2curve.js new file mode 100644 index 00000000..e7ede3d0 --- /dev/null +++ b/qortal-ui-crypto/api/deps/ed2curve.js @@ -0,0 +1,264 @@ +/* + * ed2curve: convert Ed25519 signing key pair into Curve25519 + * key pair suitable for Diffie-Hellman key exchange. + * + * Written by Dmitry Chestnykh in 2014. Public domain. + */ +/* jshint newcap: false */ + +/* +Change to es6 import/export +*/ + +import nacl from './nacl-fast.js' + +// (function(root, f) { +// 'use strict'; +// if (typeof module !== 'undefined' && module.exports) module.exports = f(require('tweetnacl')); +// else root.ed2curve = f(root.nacl); +// }(this, function(nacl) { +// 'use strict'; +// if (!nacl) throw new Error('tweetnacl not loaded'); + + // -- Operations copied from TweetNaCl.js. -- + + var gf = function(init) { + var i, r = new Float64Array(16); + if (init) for (i = 0; i < init.length; i++) r[i] = init[i]; + return r; + }; + + var gf0 = gf(), + gf1 = gf([1]), + D = gf([0x78a3, 0x1359, 0x4dca, 0x75eb, 0xd8ab, 0x4141, 0x0a4d, 0x0070, 0xe898, 0x7779, 0x4079, 0x8cc7, 0xfe73, 0x2b6f, 0x6cee, 0x5203]), + I = gf([0xa0b0, 0x4a0e, 0x1b27, 0xc4ee, 0xe478, 0xad2f, 0x1806, 0x2f43, 0xd7a7, 0x3dfb, 0x0099, 0x2b4d, 0xdf0b, 0x4fc1, 0x2480, 0x2b83]); + + function car25519(o) { + var c; + var i; + for (i = 0; i < 16; i++) { + o[i] += 65536; + c = Math.floor(o[i] / 65536); + o[(i+1)*(i<15?1:0)] += c - 1 + 37 * (c-1) * (i===15?1:0); + o[i] -= (c * 65536); + } + } + + function sel25519(p, q, b) { + var t, c = ~(b-1); + for (var i = 0; i < 16; i++) { + t = c & (p[i] ^ q[i]); + p[i] ^= t; + q[i] ^= t; + } + } + + function unpack25519(o, n) { + var i; + for (i = 0; i < 16; i++) o[i] = n[2*i] + (n[2*i+1] << 8); + o[15] &= 0x7fff; + } + + // addition + function A(o, a, b) { + var i; + for (i = 0; i < 16; i++) o[i] = (a[i] + b[i])|0; + } + + // subtraction + function Z(o, a, b) { + var i; + for (i = 0; i < 16; i++) o[i] = (a[i] - b[i])|0; + } + + // multiplication + function M(o, a, b) { + var i, j, t = new Float64Array(31); + for (i = 0; i < 31; i++) t[i] = 0; + for (i = 0; i < 16; i++) { + for (j = 0; j < 16; j++) { + t[i+j] += a[i] * b[j]; + } + } + for (i = 0; i < 15; i++) { + t[i] += 38 * t[i+16]; + } + for (i = 0; i < 16; i++) o[i] = t[i]; + car25519(o); + car25519(o); + } + + // squaring + function S(o, a) { + M(o, a, a); + } + + // inversion + function inv25519(o, i) { + var c = gf(); + var a; + for (a = 0; a < 16; a++) c[a] = i[a]; + for (a = 253; a >= 0; a--) { + S(c, c); + if(a !== 2 && a !== 4) M(c, c, i); + } + for (a = 0; a < 16; a++) o[a] = c[a]; + } + + function pack25519(o, n) { + var i, j, b; + var m = gf(), t = gf(); + for (i = 0; i < 16; i++) t[i] = n[i]; + car25519(t); + car25519(t); + car25519(t); + for (j = 0; j < 2; j++) { + m[0] = t[0] - 0xffed; + for (i = 1; i < 15; i++) { + m[i] = t[i] - 0xffff - ((m[i-1]>>16) & 1); + m[i-1] &= 0xffff; + } + m[15] = t[15] - 0x7fff - ((m[14]>>16) & 1); + b = (m[15]>>16) & 1; + m[14] &= 0xffff; + sel25519(t, m, 1-b); + } + for (i = 0; i < 16; i++) { + o[2*i] = t[i] & 0xff; + o[2*i+1] = t[i] >> 8; + } + } + + function par25519(a) { + var d = new Uint8Array(32); + pack25519(d, a); + return d[0] & 1; + } + + function vn(x, xi, y, yi, n) { + var i, d = 0; + for (i = 0; i < n; i++) d |= x[xi + i] ^ y[yi + i]; + return (1 & ((d - 1) >>> 8)) - 1; + } + + function crypto_verify_32(x, xi, y, yi) { + return vn(x, xi, y, yi, 32); + } + + function neq25519(a, b) { + var c = new Uint8Array(32), d = new Uint8Array(32); + pack25519(c, a); + pack25519(d, b); + return crypto_verify_32(c, 0, d, 0); + } + + function pow2523(o, i) { + var c = gf(); + var a; + for (a = 0; a < 16; a++) c[a] = i[a]; + for (a = 250; a >= 0; a--) { + S(c, c); + if (a !== 1) M(c, c, i); + } + for (a = 0; a < 16; a++) o[a] = c[a]; + } + + function set25519(r, a) { + var i; + for (i = 0; i < 16; i++) r[i] = a[i] | 0; + } + + function unpackneg(r, p) { + var t = gf(), chk = gf(), num = gf(), + den = gf(), den2 = gf(), den4 = gf(), + den6 = gf(); + + set25519(r[2], gf1); + unpack25519(r[1], p); + S(num, r[1]); + M(den, num, D); + Z(num, num, r[2]); + A(den, r[2], den); + + S(den2, den); + S(den4, den2); + M(den6, den4, den2); + M(t, den6, num); + M(t, t, den); + + pow2523(t, t); + M(t, t, num); + M(t, t, den); + M(t, t, den); + M(r[0], t, den); + + S(chk, r[0]); + M(chk, chk, den); + if (neq25519(chk, num)) M(r[0], r[0], I); + + S(chk, r[0]); + M(chk, chk, den); + if (neq25519(chk, num)) return -1; + + if (par25519(r[0]) === (p[31] >> 7)) Z(r[0], gf0, r[0]); + + M(r[3], r[0], r[1]); + return 0; + } + + // ---- + + // Converts Ed25519 public key to Curve25519 public key. + // montgomeryX = (edwardsY + 1)*inverse(1 - edwardsY) mod p + function convertPublicKey(pk) { + var z = new Uint8Array(32), + q = [gf(), gf(), gf(), gf()], + a = gf(), b = gf(); + + if (unpackneg(q, pk)) return null; // reject invalid key + + var y = q[1]; + + A(a, gf1, y); + Z(b, gf1, y); + inv25519(b, b); + M(a, a, b); + + pack25519(z, a); + return z; + } + + // Converts Ed25519 secret key to Curve25519 secret key. + function convertSecretKey(sk) { + var d = new Uint8Array(64), o = new Uint8Array(32), i; + nacl.lowlevel.crypto_hash(d, sk, 32); + d[0] &= 248; + d[31] &= 127; + d[31] |= 64; + for (i = 0; i < 32; i++) o[i] = d[i]; + for (i = 0; i < 64; i++) d[i] = 0; + return o; + } + + function convertKeyPair(edKeyPair) { + var publicKey = convertPublicKey(edKeyPair.publicKey); + if (!publicKey) return null; + return { + publicKey: publicKey, + secretKey: convertSecretKey(edKeyPair.secretKey) + }; + } + +// return { +// convertPublicKey: convertPublicKey, +// convertSecretKey: convertSecretKey, +// convertKeyPair: convertKeyPair, +// }; + +export default { + convertPublicKey: convertPublicKey, + convertSecretKey: convertSecretKey, + convertKeyPair: convertKeyPair, +} + +// })); diff --git a/qortal-ui-crypto/api/deps/nacl-fast.js b/qortal-ui-crypto/api/deps/nacl-fast.js new file mode 100644 index 00000000..917c6e7c --- /dev/null +++ b/qortal-ui-crypto/api/deps/nacl-fast.js @@ -0,0 +1,2422 @@ +// == CHANGE TO ES6 EXPORT == // +const nacl = {} +//(function(nacl) { +'use strict'; + +// Ported in 2014 by Dmitry Chestnykh and Devi Mandiri. +// Public domain. +// +// Implementation derived from TweetNaCl version 20140427. +// See for details: http://tweetnacl.cr.yp.to/ + +var gf = function(init) { + var i, r = new Float64Array(16); + if (init) for (i = 0; i < init.length; i++) r[i] = init[i]; + return r; +}; + +// Pluggable, initialized in high-level API below. +var randombytes = function(/* x, n */) { throw new Error('no PRNG'); }; + +var _0 = new Uint8Array(16); +var _9 = new Uint8Array(32); _9[0] = 9; + +var gf0 = gf(), + gf1 = gf([1]), + _121665 = gf([0xdb41, 1]), + D = gf([0x78a3, 0x1359, 0x4dca, 0x75eb, 0xd8ab, 0x4141, 0x0a4d, 0x0070, 0xe898, 0x7779, 0x4079, 0x8cc7, 0xfe73, 0x2b6f, 0x6cee, 0x5203]), + D2 = gf([0xf159, 0x26b2, 0x9b94, 0xebd6, 0xb156, 0x8283, 0x149a, 0x00e0, 0xd130, 0xeef3, 0x80f2, 0x198e, 0xfce7, 0x56df, 0xd9dc, 0x2406]), + X = gf([0xd51a, 0x8f25, 0x2d60, 0xc956, 0xa7b2, 0x9525, 0xc760, 0x692c, 0xdc5c, 0xfdd6, 0xe231, 0xc0a4, 0x53fe, 0xcd6e, 0x36d3, 0x2169]), + Y = gf([0x6658, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666]), + I = gf([0xa0b0, 0x4a0e, 0x1b27, 0xc4ee, 0xe478, 0xad2f, 0x1806, 0x2f43, 0xd7a7, 0x3dfb, 0x0099, 0x2b4d, 0xdf0b, 0x4fc1, 0x2480, 0x2b83]); + +function ts64(x, i, h, l) { + x[i] = (h >> 24) & 0xff; + x[i+1] = (h >> 16) & 0xff; + x[i+2] = (h >> 8) & 0xff; + x[i+3] = h & 0xff; + x[i+4] = (l >> 24) & 0xff; + x[i+5] = (l >> 16) & 0xff; + x[i+6] = (l >> 8) & 0xff; + x[i+7] = l & 0xff; +} + +function vn(x, xi, y, yi, n) { + var i,d = 0; + for (i = 0; i < n; i++) d |= x[xi+i]^y[yi+i]; + return (1 & ((d - 1) >>> 8)) - 1; +} + +function crypto_verify_16(x, xi, y, yi) { + return vn(x,xi,y,yi,16); +} + +function crypto_verify_32(x, xi, y, yi) { + return vn(x,xi,y,yi,32); +} + +function core_salsa20(o, p, k, c) { + var j0 = c[ 0] & 0xff | (c[ 1] & 0xff)<<8 | (c[ 2] & 0xff)<<16 | (c[ 3] & 0xff)<<24, + j1 = k[ 0] & 0xff | (k[ 1] & 0xff)<<8 | (k[ 2] & 0xff)<<16 | (k[ 3] & 0xff)<<24, + j2 = k[ 4] & 0xff | (k[ 5] & 0xff)<<8 | (k[ 6] & 0xff)<<16 | (k[ 7] & 0xff)<<24, + j3 = k[ 8] & 0xff | (k[ 9] & 0xff)<<8 | (k[10] & 0xff)<<16 | (k[11] & 0xff)<<24, + j4 = k[12] & 0xff | (k[13] & 0xff)<<8 | (k[14] & 0xff)<<16 | (k[15] & 0xff)<<24, + j5 = c[ 4] & 0xff | (c[ 5] & 0xff)<<8 | (c[ 6] & 0xff)<<16 | (c[ 7] & 0xff)<<24, + j6 = p[ 0] & 0xff | (p[ 1] & 0xff)<<8 | (p[ 2] & 0xff)<<16 | (p[ 3] & 0xff)<<24, + j7 = p[ 4] & 0xff | (p[ 5] & 0xff)<<8 | (p[ 6] & 0xff)<<16 | (p[ 7] & 0xff)<<24, + j8 = p[ 8] & 0xff | (p[ 9] & 0xff)<<8 | (p[10] & 0xff)<<16 | (p[11] & 0xff)<<24, + j9 = p[12] & 0xff | (p[13] & 0xff)<<8 | (p[14] & 0xff)<<16 | (p[15] & 0xff)<<24, + j10 = c[ 8] & 0xff | (c[ 9] & 0xff)<<8 | (c[10] & 0xff)<<16 | (c[11] & 0xff)<<24, + j11 = k[16] & 0xff | (k[17] & 0xff)<<8 | (k[18] & 0xff)<<16 | (k[19] & 0xff)<<24, + j12 = k[20] & 0xff | (k[21] & 0xff)<<8 | (k[22] & 0xff)<<16 | (k[23] & 0xff)<<24, + j13 = k[24] & 0xff | (k[25] & 0xff)<<8 | (k[26] & 0xff)<<16 | (k[27] & 0xff)<<24, + j14 = k[28] & 0xff | (k[29] & 0xff)<<8 | (k[30] & 0xff)<<16 | (k[31] & 0xff)<<24, + j15 = c[12] & 0xff | (c[13] & 0xff)<<8 | (c[14] & 0xff)<<16 | (c[15] & 0xff)<<24; + + var x0 = j0, x1 = j1, x2 = j2, x3 = j3, x4 = j4, x5 = j5, x6 = j6, x7 = j7, + x8 = j8, x9 = j9, x10 = j10, x11 = j11, x12 = j12, x13 = j13, x14 = j14, + x15 = j15, u; + + for (var i = 0; i < 20; i += 2) { + u = x0 + x12 | 0; + x4 ^= u<<7 | u>>>(32-7); + u = x4 + x0 | 0; + x8 ^= u<<9 | u>>>(32-9); + u = x8 + x4 | 0; + x12 ^= u<<13 | u>>>(32-13); + u = x12 + x8 | 0; + x0 ^= u<<18 | u>>>(32-18); + + u = x5 + x1 | 0; + x9 ^= u<<7 | u>>>(32-7); + u = x9 + x5 | 0; + x13 ^= u<<9 | u>>>(32-9); + u = x13 + x9 | 0; + x1 ^= u<<13 | u>>>(32-13); + u = x1 + x13 | 0; + x5 ^= u<<18 | u>>>(32-18); + + u = x10 + x6 | 0; + x14 ^= u<<7 | u>>>(32-7); + u = x14 + x10 | 0; + x2 ^= u<<9 | u>>>(32-9); + u = x2 + x14 | 0; + x6 ^= u<<13 | u>>>(32-13); + u = x6 + x2 | 0; + x10 ^= u<<18 | u>>>(32-18); + + u = x15 + x11 | 0; + x3 ^= u<<7 | u>>>(32-7); + u = x3 + x15 | 0; + x7 ^= u<<9 | u>>>(32-9); + u = x7 + x3 | 0; + x11 ^= u<<13 | u>>>(32-13); + u = x11 + x7 | 0; + x15 ^= u<<18 | u>>>(32-18); + + u = x0 + x3 | 0; + x1 ^= u<<7 | u>>>(32-7); + u = x1 + x0 | 0; + x2 ^= u<<9 | u>>>(32-9); + u = x2 + x1 | 0; + x3 ^= u<<13 | u>>>(32-13); + u = x3 + x2 | 0; + x0 ^= u<<18 | u>>>(32-18); + + u = x5 + x4 | 0; + x6 ^= u<<7 | u>>>(32-7); + u = x6 + x5 | 0; + x7 ^= u<<9 | u>>>(32-9); + u = x7 + x6 | 0; + x4 ^= u<<13 | u>>>(32-13); + u = x4 + x7 | 0; + x5 ^= u<<18 | u>>>(32-18); + + u = x10 + x9 | 0; + x11 ^= u<<7 | u>>>(32-7); + u = x11 + x10 | 0; + x8 ^= u<<9 | u>>>(32-9); + u = x8 + x11 | 0; + x9 ^= u<<13 | u>>>(32-13); + u = x9 + x8 | 0; + x10 ^= u<<18 | u>>>(32-18); + + u = x15 + x14 | 0; + x12 ^= u<<7 | u>>>(32-7); + u = x12 + x15 | 0; + x13 ^= u<<9 | u>>>(32-9); + u = x13 + x12 | 0; + x14 ^= u<<13 | u>>>(32-13); + u = x14 + x13 | 0; + x15 ^= u<<18 | u>>>(32-18); + } + x0 = x0 + j0 | 0; + x1 = x1 + j1 | 0; + x2 = x2 + j2 | 0; + x3 = x3 + j3 | 0; + x4 = x4 + j4 | 0; + x5 = x5 + j5 | 0; + x6 = x6 + j6 | 0; + x7 = x7 + j7 | 0; + x8 = x8 + j8 | 0; + x9 = x9 + j9 | 0; + x10 = x10 + j10 | 0; + x11 = x11 + j11 | 0; + x12 = x12 + j12 | 0; + x13 = x13 + j13 | 0; + x14 = x14 + j14 | 0; + x15 = x15 + j15 | 0; + + o[ 0] = x0 >>> 0 & 0xff; + o[ 1] = x0 >>> 8 & 0xff; + o[ 2] = x0 >>> 16 & 0xff; + o[ 3] = x0 >>> 24 & 0xff; + + o[ 4] = x1 >>> 0 & 0xff; + o[ 5] = x1 >>> 8 & 0xff; + o[ 6] = x1 >>> 16 & 0xff; + o[ 7] = x1 >>> 24 & 0xff; + + o[ 8] = x2 >>> 0 & 0xff; + o[ 9] = x2 >>> 8 & 0xff; + o[10] = x2 >>> 16 & 0xff; + o[11] = x2 >>> 24 & 0xff; + + o[12] = x3 >>> 0 & 0xff; + o[13] = x3 >>> 8 & 0xff; + o[14] = x3 >>> 16 & 0xff; + o[15] = x3 >>> 24 & 0xff; + + o[16] = x4 >>> 0 & 0xff; + o[17] = x4 >>> 8 & 0xff; + o[18] = x4 >>> 16 & 0xff; + o[19] = x4 >>> 24 & 0xff; + + o[20] = x5 >>> 0 & 0xff; + o[21] = x5 >>> 8 & 0xff; + o[22] = x5 >>> 16 & 0xff; + o[23] = x5 >>> 24 & 0xff; + + o[24] = x6 >>> 0 & 0xff; + o[25] = x6 >>> 8 & 0xff; + o[26] = x6 >>> 16 & 0xff; + o[27] = x6 >>> 24 & 0xff; + + o[28] = x7 >>> 0 & 0xff; + o[29] = x7 >>> 8 & 0xff; + o[30] = x7 >>> 16 & 0xff; + o[31] = x7 >>> 24 & 0xff; + + o[32] = x8 >>> 0 & 0xff; + o[33] = x8 >>> 8 & 0xff; + o[34] = x8 >>> 16 & 0xff; + o[35] = x8 >>> 24 & 0xff; + + o[36] = x9 >>> 0 & 0xff; + o[37] = x9 >>> 8 & 0xff; + o[38] = x9 >>> 16 & 0xff; + o[39] = x9 >>> 24 & 0xff; + + o[40] = x10 >>> 0 & 0xff; + o[41] = x10 >>> 8 & 0xff; + o[42] = x10 >>> 16 & 0xff; + o[43] = x10 >>> 24 & 0xff; + + o[44] = x11 >>> 0 & 0xff; + o[45] = x11 >>> 8 & 0xff; + o[46] = x11 >>> 16 & 0xff; + o[47] = x11 >>> 24 & 0xff; + + o[48] = x12 >>> 0 & 0xff; + o[49] = x12 >>> 8 & 0xff; + o[50] = x12 >>> 16 & 0xff; + o[51] = x12 >>> 24 & 0xff; + + o[52] = x13 >>> 0 & 0xff; + o[53] = x13 >>> 8 & 0xff; + o[54] = x13 >>> 16 & 0xff; + o[55] = x13 >>> 24 & 0xff; + + o[56] = x14 >>> 0 & 0xff; + o[57] = x14 >>> 8 & 0xff; + o[58] = x14 >>> 16 & 0xff; + o[59] = x14 >>> 24 & 0xff; + + o[60] = x15 >>> 0 & 0xff; + o[61] = x15 >>> 8 & 0xff; + o[62] = x15 >>> 16 & 0xff; + o[63] = x15 >>> 24 & 0xff; +} + +function core_hsalsa20(o,p,k,c) { + var j0 = c[ 0] & 0xff | (c[ 1] & 0xff)<<8 | (c[ 2] & 0xff)<<16 | (c[ 3] & 0xff)<<24, + j1 = k[ 0] & 0xff | (k[ 1] & 0xff)<<8 | (k[ 2] & 0xff)<<16 | (k[ 3] & 0xff)<<24, + j2 = k[ 4] & 0xff | (k[ 5] & 0xff)<<8 | (k[ 6] & 0xff)<<16 | (k[ 7] & 0xff)<<24, + j3 = k[ 8] & 0xff | (k[ 9] & 0xff)<<8 | (k[10] & 0xff)<<16 | (k[11] & 0xff)<<24, + j4 = k[12] & 0xff | (k[13] & 0xff)<<8 | (k[14] & 0xff)<<16 | (k[15] & 0xff)<<24, + j5 = c[ 4] & 0xff | (c[ 5] & 0xff)<<8 | (c[ 6] & 0xff)<<16 | (c[ 7] & 0xff)<<24, + j6 = p[ 0] & 0xff | (p[ 1] & 0xff)<<8 | (p[ 2] & 0xff)<<16 | (p[ 3] & 0xff)<<24, + j7 = p[ 4] & 0xff | (p[ 5] & 0xff)<<8 | (p[ 6] & 0xff)<<16 | (p[ 7] & 0xff)<<24, + j8 = p[ 8] & 0xff | (p[ 9] & 0xff)<<8 | (p[10] & 0xff)<<16 | (p[11] & 0xff)<<24, + j9 = p[12] & 0xff | (p[13] & 0xff)<<8 | (p[14] & 0xff)<<16 | (p[15] & 0xff)<<24, + j10 = c[ 8] & 0xff | (c[ 9] & 0xff)<<8 | (c[10] & 0xff)<<16 | (c[11] & 0xff)<<24, + j11 = k[16] & 0xff | (k[17] & 0xff)<<8 | (k[18] & 0xff)<<16 | (k[19] & 0xff)<<24, + j12 = k[20] & 0xff | (k[21] & 0xff)<<8 | (k[22] & 0xff)<<16 | (k[23] & 0xff)<<24, + j13 = k[24] & 0xff | (k[25] & 0xff)<<8 | (k[26] & 0xff)<<16 | (k[27] & 0xff)<<24, + j14 = k[28] & 0xff | (k[29] & 0xff)<<8 | (k[30] & 0xff)<<16 | (k[31] & 0xff)<<24, + j15 = c[12] & 0xff | (c[13] & 0xff)<<8 | (c[14] & 0xff)<<16 | (c[15] & 0xff)<<24; + + var x0 = j0, x1 = j1, x2 = j2, x3 = j3, x4 = j4, x5 = j5, x6 = j6, x7 = j7, + x8 = j8, x9 = j9, x10 = j10, x11 = j11, x12 = j12, x13 = j13, x14 = j14, + x15 = j15, u; + + for (var i = 0; i < 20; i += 2) { + u = x0 + x12 | 0; + x4 ^= u<<7 | u>>>(32-7); + u = x4 + x0 | 0; + x8 ^= u<<9 | u>>>(32-9); + u = x8 + x4 | 0; + x12 ^= u<<13 | u>>>(32-13); + u = x12 + x8 | 0; + x0 ^= u<<18 | u>>>(32-18); + + u = x5 + x1 | 0; + x9 ^= u<<7 | u>>>(32-7); + u = x9 + x5 | 0; + x13 ^= u<<9 | u>>>(32-9); + u = x13 + x9 | 0; + x1 ^= u<<13 | u>>>(32-13); + u = x1 + x13 | 0; + x5 ^= u<<18 | u>>>(32-18); + + u = x10 + x6 | 0; + x14 ^= u<<7 | u>>>(32-7); + u = x14 + x10 | 0; + x2 ^= u<<9 | u>>>(32-9); + u = x2 + x14 | 0; + x6 ^= u<<13 | u>>>(32-13); + u = x6 + x2 | 0; + x10 ^= u<<18 | u>>>(32-18); + + u = x15 + x11 | 0; + x3 ^= u<<7 | u>>>(32-7); + u = x3 + x15 | 0; + x7 ^= u<<9 | u>>>(32-9); + u = x7 + x3 | 0; + x11 ^= u<<13 | u>>>(32-13); + u = x11 + x7 | 0; + x15 ^= u<<18 | u>>>(32-18); + + u = x0 + x3 | 0; + x1 ^= u<<7 | u>>>(32-7); + u = x1 + x0 | 0; + x2 ^= u<<9 | u>>>(32-9); + u = x2 + x1 | 0; + x3 ^= u<<13 | u>>>(32-13); + u = x3 + x2 | 0; + x0 ^= u<<18 | u>>>(32-18); + + u = x5 + x4 | 0; + x6 ^= u<<7 | u>>>(32-7); + u = x6 + x5 | 0; + x7 ^= u<<9 | u>>>(32-9); + u = x7 + x6 | 0; + x4 ^= u<<13 | u>>>(32-13); + u = x4 + x7 | 0; + x5 ^= u<<18 | u>>>(32-18); + + u = x10 + x9 | 0; + x11 ^= u<<7 | u>>>(32-7); + u = x11 + x10 | 0; + x8 ^= u<<9 | u>>>(32-9); + u = x8 + x11 | 0; + x9 ^= u<<13 | u>>>(32-13); + u = x9 + x8 | 0; + x10 ^= u<<18 | u>>>(32-18); + + u = x15 + x14 | 0; + x12 ^= u<<7 | u>>>(32-7); + u = x12 + x15 | 0; + x13 ^= u<<9 | u>>>(32-9); + u = x13 + x12 | 0; + x14 ^= u<<13 | u>>>(32-13); + u = x14 + x13 | 0; + x15 ^= u<<18 | u>>>(32-18); + } + + o[ 0] = x0 >>> 0 & 0xff; + o[ 1] = x0 >>> 8 & 0xff; + o[ 2] = x0 >>> 16 & 0xff; + o[ 3] = x0 >>> 24 & 0xff; + + o[ 4] = x5 >>> 0 & 0xff; + o[ 5] = x5 >>> 8 & 0xff; + o[ 6] = x5 >>> 16 & 0xff; + o[ 7] = x5 >>> 24 & 0xff; + + o[ 8] = x10 >>> 0 & 0xff; + o[ 9] = x10 >>> 8 & 0xff; + o[10] = x10 >>> 16 & 0xff; + o[11] = x10 >>> 24 & 0xff; + + o[12] = x15 >>> 0 & 0xff; + o[13] = x15 >>> 8 & 0xff; + o[14] = x15 >>> 16 & 0xff; + o[15] = x15 >>> 24 & 0xff; + + o[16] = x6 >>> 0 & 0xff; + o[17] = x6 >>> 8 & 0xff; + o[18] = x6 >>> 16 & 0xff; + o[19] = x6 >>> 24 & 0xff; + + o[20] = x7 >>> 0 & 0xff; + o[21] = x7 >>> 8 & 0xff; + o[22] = x7 >>> 16 & 0xff; + o[23] = x7 >>> 24 & 0xff; + + o[24] = x8 >>> 0 & 0xff; + o[25] = x8 >>> 8 & 0xff; + o[26] = x8 >>> 16 & 0xff; + o[27] = x8 >>> 24 & 0xff; + + o[28] = x9 >>> 0 & 0xff; + o[29] = x9 >>> 8 & 0xff; + o[30] = x9 >>> 16 & 0xff; + o[31] = x9 >>> 24 & 0xff; +} + +function crypto_core_salsa20(out,inp,k,c) { + core_salsa20(out,inp,k,c); +} + +function crypto_core_hsalsa20(out,inp,k,c) { + core_hsalsa20(out,inp,k,c); +} + +var sigma = new Uint8Array([101, 120, 112, 97, 110, 100, 32, 51, 50, 45, 98, 121, 116, 101, 32, 107]); + // "expand 32-byte k" + +function crypto_stream_salsa20_xor(c,cpos,m,mpos,b,n,k) { + var z = new Uint8Array(16), x = new Uint8Array(64); + var u, i; + for (i = 0; i < 16; i++) z[i] = 0; + for (i = 0; i < 8; i++) z[i] = n[i]; + while (b >= 64) { + crypto_core_salsa20(x,z,k,sigma); + for (i = 0; i < 64; i++) c[cpos+i] = m[mpos+i] ^ x[i]; + u = 1; + for (i = 8; i < 16; i++) { + u = u + (z[i] & 0xff) | 0; + z[i] = u & 0xff; + u >>>= 8; + } + b -= 64; + cpos += 64; + mpos += 64; + } + if (b > 0) { + crypto_core_salsa20(x,z,k,sigma); + for (i = 0; i < b; i++) c[cpos+i] = m[mpos+i] ^ x[i]; + } + return 0; +} + +function crypto_stream_salsa20(c,cpos,b,n,k) { + var z = new Uint8Array(16), x = new Uint8Array(64); + var u, i; + for (i = 0; i < 16; i++) z[i] = 0; + for (i = 0; i < 8; i++) z[i] = n[i]; + while (b >= 64) { + crypto_core_salsa20(x,z,k,sigma); + for (i = 0; i < 64; i++) c[cpos+i] = x[i]; + u = 1; + for (i = 8; i < 16; i++) { + u = u + (z[i] & 0xff) | 0; + z[i] = u & 0xff; + u >>>= 8; + } + b -= 64; + cpos += 64; + } + if (b > 0) { + crypto_core_salsa20(x,z,k,sigma); + for (i = 0; i < b; i++) c[cpos+i] = x[i]; + } + return 0; +} + +function crypto_stream(c,cpos,d,n,k) { + var s = new Uint8Array(32); + crypto_core_hsalsa20(s,n,k,sigma); + var sn = new Uint8Array(8); + for (var i = 0; i < 8; i++) sn[i] = n[i+16]; + return crypto_stream_salsa20(c,cpos,d,sn,s); +} + +function crypto_stream_xor(c,cpos,m,mpos,d,n,k) { + var s = new Uint8Array(32); + crypto_core_hsalsa20(s,n,k,sigma); + var sn = new Uint8Array(8); + for (var i = 0; i < 8; i++) sn[i] = n[i+16]; + return crypto_stream_salsa20_xor(c,cpos,m,mpos,d,sn,s); +} + +/* +* Port of Andrew Moon's Poly1305-donna-16. Public domain. +* https://github.com/floodyberry/poly1305-donna +*/ + +var poly1305 = function(key) { + this.buffer = new Uint8Array(16); + this.r = new Uint16Array(10); + this.h = new Uint16Array(10); + this.pad = new Uint16Array(8); + this.leftover = 0; + this.fin = 0; + + var t0, t1, t2, t3, t4, t5, t6, t7; + + t0 = key[ 0] & 0xff | (key[ 1] & 0xff) << 8; this.r[0] = ( t0 ) & 0x1fff; + t1 = key[ 2] & 0xff | (key[ 3] & 0xff) << 8; this.r[1] = ((t0 >>> 13) | (t1 << 3)) & 0x1fff; + t2 = key[ 4] & 0xff | (key[ 5] & 0xff) << 8; this.r[2] = ((t1 >>> 10) | (t2 << 6)) & 0x1f03; + t3 = key[ 6] & 0xff | (key[ 7] & 0xff) << 8; this.r[3] = ((t2 >>> 7) | (t3 << 9)) & 0x1fff; + t4 = key[ 8] & 0xff | (key[ 9] & 0xff) << 8; this.r[4] = ((t3 >>> 4) | (t4 << 12)) & 0x00ff; + this.r[5] = ((t4 >>> 1)) & 0x1ffe; + t5 = key[10] & 0xff | (key[11] & 0xff) << 8; this.r[6] = ((t4 >>> 14) | (t5 << 2)) & 0x1fff; + t6 = key[12] & 0xff | (key[13] & 0xff) << 8; this.r[7] = ((t5 >>> 11) | (t6 << 5)) & 0x1f81; + t7 = key[14] & 0xff | (key[15] & 0xff) << 8; this.r[8] = ((t6 >>> 8) | (t7 << 8)) & 0x1fff; + this.r[9] = ((t7 >>> 5)) & 0x007f; + + this.pad[0] = key[16] & 0xff | (key[17] & 0xff) << 8; + this.pad[1] = key[18] & 0xff | (key[19] & 0xff) << 8; + this.pad[2] = key[20] & 0xff | (key[21] & 0xff) << 8; + this.pad[3] = key[22] & 0xff | (key[23] & 0xff) << 8; + this.pad[4] = key[24] & 0xff | (key[25] & 0xff) << 8; + this.pad[5] = key[26] & 0xff | (key[27] & 0xff) << 8; + this.pad[6] = key[28] & 0xff | (key[29] & 0xff) << 8; + this.pad[7] = key[30] & 0xff | (key[31] & 0xff) << 8; +}; + +poly1305.prototype.blocks = function(m, mpos, bytes) { + var hibit = this.fin ? 0 : (1 << 11); + var t0, t1, t2, t3, t4, t5, t6, t7, c; + var d0, d1, d2, d3, d4, d5, d6, d7, d8, d9; + + var h0 = this.h[0], + h1 = this.h[1], + h2 = this.h[2], + h3 = this.h[3], + h4 = this.h[4], + h5 = this.h[5], + h6 = this.h[6], + h7 = this.h[7], + h8 = this.h[8], + h9 = this.h[9]; + + var r0 = this.r[0], + r1 = this.r[1], + r2 = this.r[2], + r3 = this.r[3], + r4 = this.r[4], + r5 = this.r[5], + r6 = this.r[6], + r7 = this.r[7], + r8 = this.r[8], + r9 = this.r[9]; + + while (bytes >= 16) { + t0 = m[mpos+ 0] & 0xff | (m[mpos+ 1] & 0xff) << 8; h0 += ( t0 ) & 0x1fff; + t1 = m[mpos+ 2] & 0xff | (m[mpos+ 3] & 0xff) << 8; h1 += ((t0 >>> 13) | (t1 << 3)) & 0x1fff; + t2 = m[mpos+ 4] & 0xff | (m[mpos+ 5] & 0xff) << 8; h2 += ((t1 >>> 10) | (t2 << 6)) & 0x1fff; + t3 = m[mpos+ 6] & 0xff | (m[mpos+ 7] & 0xff) << 8; h3 += ((t2 >>> 7) | (t3 << 9)) & 0x1fff; + t4 = m[mpos+ 8] & 0xff | (m[mpos+ 9] & 0xff) << 8; h4 += ((t3 >>> 4) | (t4 << 12)) & 0x1fff; + h5 += ((t4 >>> 1)) & 0x1fff; + t5 = m[mpos+10] & 0xff | (m[mpos+11] & 0xff) << 8; h6 += ((t4 >>> 14) | (t5 << 2)) & 0x1fff; + t6 = m[mpos+12] & 0xff | (m[mpos+13] & 0xff) << 8; h7 += ((t5 >>> 11) | (t6 << 5)) & 0x1fff; + t7 = m[mpos+14] & 0xff | (m[mpos+15] & 0xff) << 8; h8 += ((t6 >>> 8) | (t7 << 8)) & 0x1fff; + h9 += ((t7 >>> 5)) | hibit; + + c = 0; + + d0 = c; + d0 += h0 * r0; + d0 += h1 * (5 * r9); + d0 += h2 * (5 * r8); + d0 += h3 * (5 * r7); + d0 += h4 * (5 * r6); + c = (d0 >>> 13); d0 &= 0x1fff; + d0 += h5 * (5 * r5); + d0 += h6 * (5 * r4); + d0 += h7 * (5 * r3); + d0 += h8 * (5 * r2); + d0 += h9 * (5 * r1); + c += (d0 >>> 13); d0 &= 0x1fff; + + d1 = c; + d1 += h0 * r1; + d1 += h1 * r0; + d1 += h2 * (5 * r9); + d1 += h3 * (5 * r8); + d1 += h4 * (5 * r7); + c = (d1 >>> 13); d1 &= 0x1fff; + d1 += h5 * (5 * r6); + d1 += h6 * (5 * r5); + d1 += h7 * (5 * r4); + d1 += h8 * (5 * r3); + d1 += h9 * (5 * r2); + c += (d1 >>> 13); d1 &= 0x1fff; + + d2 = c; + d2 += h0 * r2; + d2 += h1 * r1; + d2 += h2 * r0; + d2 += h3 * (5 * r9); + d2 += h4 * (5 * r8); + c = (d2 >>> 13); d2 &= 0x1fff; + d2 += h5 * (5 * r7); + d2 += h6 * (5 * r6); + d2 += h7 * (5 * r5); + d2 += h8 * (5 * r4); + d2 += h9 * (5 * r3); + c += (d2 >>> 13); d2 &= 0x1fff; + + d3 = c; + d3 += h0 * r3; + d3 += h1 * r2; + d3 += h2 * r1; + d3 += h3 * r0; + d3 += h4 * (5 * r9); + c = (d3 >>> 13); d3 &= 0x1fff; + d3 += h5 * (5 * r8); + d3 += h6 * (5 * r7); + d3 += h7 * (5 * r6); + d3 += h8 * (5 * r5); + d3 += h9 * (5 * r4); + c += (d3 >>> 13); d3 &= 0x1fff; + + d4 = c; + d4 += h0 * r4; + d4 += h1 * r3; + d4 += h2 * r2; + d4 += h3 * r1; + d4 += h4 * r0; + c = (d4 >>> 13); d4 &= 0x1fff; + d4 += h5 * (5 * r9); + d4 += h6 * (5 * r8); + d4 += h7 * (5 * r7); + d4 += h8 * (5 * r6); + d4 += h9 * (5 * r5); + c += (d4 >>> 13); d4 &= 0x1fff; + + d5 = c; + d5 += h0 * r5; + d5 += h1 * r4; + d5 += h2 * r3; + d5 += h3 * r2; + d5 += h4 * r1; + c = (d5 >>> 13); d5 &= 0x1fff; + d5 += h5 * r0; + d5 += h6 * (5 * r9); + d5 += h7 * (5 * r8); + d5 += h8 * (5 * r7); + d5 += h9 * (5 * r6); + c += (d5 >>> 13); d5 &= 0x1fff; + + d6 = c; + d6 += h0 * r6; + d6 += h1 * r5; + d6 += h2 * r4; + d6 += h3 * r3; + d6 += h4 * r2; + c = (d6 >>> 13); d6 &= 0x1fff; + d6 += h5 * r1; + d6 += h6 * r0; + d6 += h7 * (5 * r9); + d6 += h8 * (5 * r8); + d6 += h9 * (5 * r7); + c += (d6 >>> 13); d6 &= 0x1fff; + + d7 = c; + d7 += h0 * r7; + d7 += h1 * r6; + d7 += h2 * r5; + d7 += h3 * r4; + d7 += h4 * r3; + c = (d7 >>> 13); d7 &= 0x1fff; + d7 += h5 * r2; + d7 += h6 * r1; + d7 += h7 * r0; + d7 += h8 * (5 * r9); + d7 += h9 * (5 * r8); + c += (d7 >>> 13); d7 &= 0x1fff; + + d8 = c; + d8 += h0 * r8; + d8 += h1 * r7; + d8 += h2 * r6; + d8 += h3 * r5; + d8 += h4 * r4; + c = (d8 >>> 13); d8 &= 0x1fff; + d8 += h5 * r3; + d8 += h6 * r2; + d8 += h7 * r1; + d8 += h8 * r0; + d8 += h9 * (5 * r9); + c += (d8 >>> 13); d8 &= 0x1fff; + + d9 = c; + d9 += h0 * r9; + d9 += h1 * r8; + d9 += h2 * r7; + d9 += h3 * r6; + d9 += h4 * r5; + c = (d9 >>> 13); d9 &= 0x1fff; + d9 += h5 * r4; + d9 += h6 * r3; + d9 += h7 * r2; + d9 += h8 * r1; + d9 += h9 * r0; + c += (d9 >>> 13); d9 &= 0x1fff; + + c = (((c << 2) + c)) | 0; + c = (c + d0) | 0; + d0 = c & 0x1fff; + c = (c >>> 13); + d1 += c; + + h0 = d0; + h1 = d1; + h2 = d2; + h3 = d3; + h4 = d4; + h5 = d5; + h6 = d6; + h7 = d7; + h8 = d8; + h9 = d9; + + mpos += 16; + bytes -= 16; + } + this.h[0] = h0; + this.h[1] = h1; + this.h[2] = h2; + this.h[3] = h3; + this.h[4] = h4; + this.h[5] = h5; + this.h[6] = h6; + this.h[7] = h7; + this.h[8] = h8; + this.h[9] = h9; +}; + +poly1305.prototype.finish = function(mac, macpos) { + var g = new Uint16Array(10); + var c, mask, f, i; + + if (this.leftover) { + i = this.leftover; + this.buffer[i++] = 1; + for (; i < 16; i++) this.buffer[i] = 0; + this.fin = 1; + this.blocks(this.buffer, 0, 16); + } + + c = this.h[1] >>> 13; + this.h[1] &= 0x1fff; + for (i = 2; i < 10; i++) { + this.h[i] += c; + c = this.h[i] >>> 13; + this.h[i] &= 0x1fff; + } + this.h[0] += (c * 5); + c = this.h[0] >>> 13; + this.h[0] &= 0x1fff; + this.h[1] += c; + c = this.h[1] >>> 13; + this.h[1] &= 0x1fff; + this.h[2] += c; + + g[0] = this.h[0] + 5; + c = g[0] >>> 13; + g[0] &= 0x1fff; + for (i = 1; i < 10; i++) { + g[i] = this.h[i] + c; + c = g[i] >>> 13; + g[i] &= 0x1fff; + } + g[9] -= (1 << 13); + + mask = (g[9] >>> ((2 * 8) - 1)) - 1; + for (i = 0; i < 10; i++) g[i] &= mask; + mask = ~mask; + for (i = 0; i < 10; i++) this.h[i] = (this.h[i] & mask) | g[i]; + + this.h[0] = ((this.h[0] ) | (this.h[1] << 13) ) & 0xffff; + this.h[1] = ((this.h[1] >>> 3) | (this.h[2] << 10) ) & 0xffff; + this.h[2] = ((this.h[2] >>> 6) | (this.h[3] << 7) ) & 0xffff; + this.h[3] = ((this.h[3] >>> 9) | (this.h[4] << 4) ) & 0xffff; + this.h[4] = ((this.h[4] >>> 12) | (this.h[5] << 1) | (this.h[6] << 14)) & 0xffff; + this.h[5] = ((this.h[6] >>> 2) | (this.h[7] << 11) ) & 0xffff; + this.h[6] = ((this.h[7] >>> 5) | (this.h[8] << 8) ) & 0xffff; + this.h[7] = ((this.h[8] >>> 8) | (this.h[9] << 5) ) & 0xffff; + + f = this.h[0] + this.pad[0]; + this.h[0] = f & 0xffff; + for (i = 1; i < 8; i++) { + f = (((this.h[i] + this.pad[i]) | 0) + (f >>> 16)) | 0; + this.h[i] = f & 0xffff; + } + + mac[macpos+ 0] = (this.h[0] >>> 0) & 0xff; + mac[macpos+ 1] = (this.h[0] >>> 8) & 0xff; + mac[macpos+ 2] = (this.h[1] >>> 0) & 0xff; + mac[macpos+ 3] = (this.h[1] >>> 8) & 0xff; + mac[macpos+ 4] = (this.h[2] >>> 0) & 0xff; + mac[macpos+ 5] = (this.h[2] >>> 8) & 0xff; + mac[macpos+ 6] = (this.h[3] >>> 0) & 0xff; + mac[macpos+ 7] = (this.h[3] >>> 8) & 0xff; + mac[macpos+ 8] = (this.h[4] >>> 0) & 0xff; + mac[macpos+ 9] = (this.h[4] >>> 8) & 0xff; + mac[macpos+10] = (this.h[5] >>> 0) & 0xff; + mac[macpos+11] = (this.h[5] >>> 8) & 0xff; + mac[macpos+12] = (this.h[6] >>> 0) & 0xff; + mac[macpos+13] = (this.h[6] >>> 8) & 0xff; + mac[macpos+14] = (this.h[7] >>> 0) & 0xff; + mac[macpos+15] = (this.h[7] >>> 8) & 0xff; +}; + +poly1305.prototype.update = function(m, mpos, bytes) { + var i, want; + + if (this.leftover) { + want = (16 - this.leftover); + if (want > bytes) + want = bytes; + for (i = 0; i < want; i++) + this.buffer[this.leftover + i] = m[mpos+i]; + bytes -= want; + mpos += want; + this.leftover += want; + if (this.leftover < 16) + return; + this.blocks(this.buffer, 0, 16); + this.leftover = 0; + } + + if (bytes >= 16) { + want = bytes - (bytes % 16); + this.blocks(m, mpos, want); + mpos += want; + bytes -= want; + } + + if (bytes) { + for (i = 0; i < bytes; i++) + this.buffer[this.leftover + i] = m[mpos+i]; + this.leftover += bytes; + } +}; + +function crypto_onetimeauth(out, outpos, m, mpos, n, k) { + var s = new poly1305(k); + s.update(m, mpos, n); + s.finish(out, outpos); + return 0; +} + +function crypto_onetimeauth_verify(h, hpos, m, mpos, n, k) { + var x = new Uint8Array(16); + crypto_onetimeauth(x,0,m,mpos,n,k); + return crypto_verify_16(h,hpos,x,0); +} + +function crypto_secretbox(c,m,d,n,k) { + var i; + if (d < 32) return -1; + crypto_stream_xor(c,0,m,0,d,n,k); + crypto_onetimeauth(c, 16, c, 32, d - 32, c); + for (i = 0; i < 16; i++) c[i] = 0; + return 0; +} + +function crypto_secretbox_open(m,c,d,n,k) { + var i; + var x = new Uint8Array(32); + if (d < 32) return -1; + crypto_stream(x,0,32,n,k); + if (crypto_onetimeauth_verify(c, 16,c, 32,d - 32,x) !== 0) return -1; + crypto_stream_xor(m,0,c,0,d,n,k); + for (i = 0; i < 32; i++) m[i] = 0; + return 0; +} + +function set25519(r, a) { + var i; + for (i = 0; i < 16; i++) r[i] = a[i]|0; +} + +function car25519(o) { + var i, v, c = 1; + for (i = 0; i < 16; i++) { + v = o[i] + c + 65535; + c = Math.floor(v / 65536); + o[i] = v - c * 65536; + } + o[0] += c-1 + 37 * (c-1); +} + +function sel25519(p, q, b) { + var t, c = ~(b-1); + for (var i = 0; i < 16; i++) { + t = c & (p[i] ^ q[i]); + p[i] ^= t; + q[i] ^= t; + } +} + +function pack25519(o, n) { + var i, j, b; + var m = gf(), t = gf(); + for (i = 0; i < 16; i++) t[i] = n[i]; + car25519(t); + car25519(t); + car25519(t); + for (j = 0; j < 2; j++) { + m[0] = t[0] - 0xffed; + for (i = 1; i < 15; i++) { + m[i] = t[i] - 0xffff - ((m[i-1]>>16) & 1); + m[i-1] &= 0xffff; + } + m[15] = t[15] - 0x7fff - ((m[14]>>16) & 1); + b = (m[15]>>16) & 1; + m[14] &= 0xffff; + sel25519(t, m, 1-b); + } + for (i = 0; i < 16; i++) { + o[2*i] = t[i] & 0xff; + o[2*i+1] = t[i]>>8; + } +} + +function neq25519(a, b) { + var c = new Uint8Array(32), d = new Uint8Array(32); + pack25519(c, a); + pack25519(d, b); + return crypto_verify_32(c, 0, d, 0); +} + +function par25519(a) { + var d = new Uint8Array(32); + pack25519(d, a); + return d[0] & 1; +} + +function unpack25519(o, n) { + var i; + for (i = 0; i < 16; i++) o[i] = n[2*i] + (n[2*i+1] << 8); + o[15] &= 0x7fff; +} + +function A(o, a, b) { + for (var i = 0; i < 16; i++) o[i] = a[i] + b[i]; +} + +function Z(o, a, b) { + for (var i = 0; i < 16; i++) o[i] = a[i] - b[i]; +} + +function M(o, a, b) { + var v, c, + t0 = 0, t1 = 0, t2 = 0, t3 = 0, t4 = 0, t5 = 0, t6 = 0, t7 = 0, + t8 = 0, t9 = 0, t10 = 0, t11 = 0, t12 = 0, t13 = 0, t14 = 0, t15 = 0, + t16 = 0, t17 = 0, t18 = 0, t19 = 0, t20 = 0, t21 = 0, t22 = 0, t23 = 0, + t24 = 0, t25 = 0, t26 = 0, t27 = 0, t28 = 0, t29 = 0, t30 = 0, + b0 = b[0], + b1 = b[1], + b2 = b[2], + b3 = b[3], + b4 = b[4], + b5 = b[5], + b6 = b[6], + b7 = b[7], + b8 = b[8], + b9 = b[9], + b10 = b[10], + b11 = b[11], + b12 = b[12], + b13 = b[13], + b14 = b[14], + b15 = b[15]; + + v = a[0]; + t0 += v * b0; + t1 += v * b1; + t2 += v * b2; + t3 += v * b3; + t4 += v * b4; + t5 += v * b5; + t6 += v * b6; + t7 += v * b7; + t8 += v * b8; + t9 += v * b9; + t10 += v * b10; + t11 += v * b11; + t12 += v * b12; + t13 += v * b13; + t14 += v * b14; + t15 += v * b15; + v = a[1]; + t1 += v * b0; + t2 += v * b1; + t3 += v * b2; + t4 += v * b3; + t5 += v * b4; + t6 += v * b5; + t7 += v * b6; + t8 += v * b7; + t9 += v * b8; + t10 += v * b9; + t11 += v * b10; + t12 += v * b11; + t13 += v * b12; + t14 += v * b13; + t15 += v * b14; + t16 += v * b15; + v = a[2]; + t2 += v * b0; + t3 += v * b1; + t4 += v * b2; + t5 += v * b3; + t6 += v * b4; + t7 += v * b5; + t8 += v * b6; + t9 += v * b7; + t10 += v * b8; + t11 += v * b9; + t12 += v * b10; + t13 += v * b11; + t14 += v * b12; + t15 += v * b13; + t16 += v * b14; + t17 += v * b15; + v = a[3]; + t3 += v * b0; + t4 += v * b1; + t5 += v * b2; + t6 += v * b3; + t7 += v * b4; + t8 += v * b5; + t9 += v * b6; + t10 += v * b7; + t11 += v * b8; + t12 += v * b9; + t13 += v * b10; + t14 += v * b11; + t15 += v * b12; + t16 += v * b13; + t17 += v * b14; + t18 += v * b15; + v = a[4]; + t4 += v * b0; + t5 += v * b1; + t6 += v * b2; + t7 += v * b3; + t8 += v * b4; + t9 += v * b5; + t10 += v * b6; + t11 += v * b7; + t12 += v * b8; + t13 += v * b9; + t14 += v * b10; + t15 += v * b11; + t16 += v * b12; + t17 += v * b13; + t18 += v * b14; + t19 += v * b15; + v = a[5]; + t5 += v * b0; + t6 += v * b1; + t7 += v * b2; + t8 += v * b3; + t9 += v * b4; + t10 += v * b5; + t11 += v * b6; + t12 += v * b7; + t13 += v * b8; + t14 += v * b9; + t15 += v * b10; + t16 += v * b11; + t17 += v * b12; + t18 += v * b13; + t19 += v * b14; + t20 += v * b15; + v = a[6]; + t6 += v * b0; + t7 += v * b1; + t8 += v * b2; + t9 += v * b3; + t10 += v * b4; + t11 += v * b5; + t12 += v * b6; + t13 += v * b7; + t14 += v * b8; + t15 += v * b9; + t16 += v * b10; + t17 += v * b11; + t18 += v * b12; + t19 += v * b13; + t20 += v * b14; + t21 += v * b15; + v = a[7]; + t7 += v * b0; + t8 += v * b1; + t9 += v * b2; + t10 += v * b3; + t11 += v * b4; + t12 += v * b5; + t13 += v * b6; + t14 += v * b7; + t15 += v * b8; + t16 += v * b9; + t17 += v * b10; + t18 += v * b11; + t19 += v * b12; + t20 += v * b13; + t21 += v * b14; + t22 += v * b15; + v = a[8]; + t8 += v * b0; + t9 += v * b1; + t10 += v * b2; + t11 += v * b3; + t12 += v * b4; + t13 += v * b5; + t14 += v * b6; + t15 += v * b7; + t16 += v * b8; + t17 += v * b9; + t18 += v * b10; + t19 += v * b11; + t20 += v * b12; + t21 += v * b13; + t22 += v * b14; + t23 += v * b15; + v = a[9]; + t9 += v * b0; + t10 += v * b1; + t11 += v * b2; + t12 += v * b3; + t13 += v * b4; + t14 += v * b5; + t15 += v * b6; + t16 += v * b7; + t17 += v * b8; + t18 += v * b9; + t19 += v * b10; + t20 += v * b11; + t21 += v * b12; + t22 += v * b13; + t23 += v * b14; + t24 += v * b15; + v = a[10]; + t10 += v * b0; + t11 += v * b1; + t12 += v * b2; + t13 += v * b3; + t14 += v * b4; + t15 += v * b5; + t16 += v * b6; + t17 += v * b7; + t18 += v * b8; + t19 += v * b9; + t20 += v * b10; + t21 += v * b11; + t22 += v * b12; + t23 += v * b13; + t24 += v * b14; + t25 += v * b15; + v = a[11]; + t11 += v * b0; + t12 += v * b1; + t13 += v * b2; + t14 += v * b3; + t15 += v * b4; + t16 += v * b5; + t17 += v * b6; + t18 += v * b7; + t19 += v * b8; + t20 += v * b9; + t21 += v * b10; + t22 += v * b11; + t23 += v * b12; + t24 += v * b13; + t25 += v * b14; + t26 += v * b15; + v = a[12]; + t12 += v * b0; + t13 += v * b1; + t14 += v * b2; + t15 += v * b3; + t16 += v * b4; + t17 += v * b5; + t18 += v * b6; + t19 += v * b7; + t20 += v * b8; + t21 += v * b9; + t22 += v * b10; + t23 += v * b11; + t24 += v * b12; + t25 += v * b13; + t26 += v * b14; + t27 += v * b15; + v = a[13]; + t13 += v * b0; + t14 += v * b1; + t15 += v * b2; + t16 += v * b3; + t17 += v * b4; + t18 += v * b5; + t19 += v * b6; + t20 += v * b7; + t21 += v * b8; + t22 += v * b9; + t23 += v * b10; + t24 += v * b11; + t25 += v * b12; + t26 += v * b13; + t27 += v * b14; + t28 += v * b15; + v = a[14]; + t14 += v * b0; + t15 += v * b1; + t16 += v * b2; + t17 += v * b3; + t18 += v * b4; + t19 += v * b5; + t20 += v * b6; + t21 += v * b7; + t22 += v * b8; + t23 += v * b9; + t24 += v * b10; + t25 += v * b11; + t26 += v * b12; + t27 += v * b13; + t28 += v * b14; + t29 += v * b15; + v = a[15]; + t15 += v * b0; + t16 += v * b1; + t17 += v * b2; + t18 += v * b3; + t19 += v * b4; + t20 += v * b5; + t21 += v * b6; + t22 += v * b7; + t23 += v * b8; + t24 += v * b9; + t25 += v * b10; + t26 += v * b11; + t27 += v * b12; + t28 += v * b13; + t29 += v * b14; + t30 += v * b15; + + t0 += 38 * t16; + t1 += 38 * t17; + t2 += 38 * t18; + t3 += 38 * t19; + t4 += 38 * t20; + t5 += 38 * t21; + t6 += 38 * t22; + t7 += 38 * t23; + t8 += 38 * t24; + t9 += 38 * t25; + t10 += 38 * t26; + t11 += 38 * t27; + t12 += 38 * t28; + t13 += 38 * t29; + t14 += 38 * t30; + // t15 left as is + + // first car + c = 1; + v = t0 + c + 65535; c = Math.floor(v / 65536); t0 = v - c * 65536; + v = t1 + c + 65535; c = Math.floor(v / 65536); t1 = v - c * 65536; + v = t2 + c + 65535; c = Math.floor(v / 65536); t2 = v - c * 65536; + v = t3 + c + 65535; c = Math.floor(v / 65536); t3 = v - c * 65536; + v = t4 + c + 65535; c = Math.floor(v / 65536); t4 = v - c * 65536; + v = t5 + c + 65535; c = Math.floor(v / 65536); t5 = v - c * 65536; + v = t6 + c + 65535; c = Math.floor(v / 65536); t6 = v - c * 65536; + v = t7 + c + 65535; c = Math.floor(v / 65536); t7 = v - c * 65536; + v = t8 + c + 65535; c = Math.floor(v / 65536); t8 = v - c * 65536; + v = t9 + c + 65535; c = Math.floor(v / 65536); t9 = v - c * 65536; + v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536; + v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536; + v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536; + v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536; + v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536; + v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536; + t0 += c-1 + 37 * (c-1); + + // second car + c = 1; + v = t0 + c + 65535; c = Math.floor(v / 65536); t0 = v - c * 65536; + v = t1 + c + 65535; c = Math.floor(v / 65536); t1 = v - c * 65536; + v = t2 + c + 65535; c = Math.floor(v / 65536); t2 = v - c * 65536; + v = t3 + c + 65535; c = Math.floor(v / 65536); t3 = v - c * 65536; + v = t4 + c + 65535; c = Math.floor(v / 65536); t4 = v - c * 65536; + v = t5 + c + 65535; c = Math.floor(v / 65536); t5 = v - c * 65536; + v = t6 + c + 65535; c = Math.floor(v / 65536); t6 = v - c * 65536; + v = t7 + c + 65535; c = Math.floor(v / 65536); t7 = v - c * 65536; + v = t8 + c + 65535; c = Math.floor(v / 65536); t8 = v - c * 65536; + v = t9 + c + 65535; c = Math.floor(v / 65536); t9 = v - c * 65536; + v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536; + v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536; + v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536; + v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536; + v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536; + v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536; + t0 += c-1 + 37 * (c-1); + + o[ 0] = t0; + o[ 1] = t1; + o[ 2] = t2; + o[ 3] = t3; + o[ 4] = t4; + o[ 5] = t5; + o[ 6] = t6; + o[ 7] = t7; + o[ 8] = t8; + o[ 9] = t9; + o[10] = t10; + o[11] = t11; + o[12] = t12; + o[13] = t13; + o[14] = t14; + o[15] = t15; +} + +function S(o, a) { + M(o, a, a); +} + +function inv25519(o, i) { + var c = gf(); + var a; + for (a = 0; a < 16; a++) c[a] = i[a]; + for (a = 253; a >= 0; a--) { + S(c, c); + if(a !== 2 && a !== 4) M(c, c, i); + } + for (a = 0; a < 16; a++) o[a] = c[a]; +} + +function pow2523(o, i) { + var c = gf(); + var a; + for (a = 0; a < 16; a++) c[a] = i[a]; + for (a = 250; a >= 0; a--) { + S(c, c); + if(a !== 1) M(c, c, i); + } + for (a = 0; a < 16; a++) o[a] = c[a]; +} + +function crypto_scalarmult(q, n, p) { + var z = new Uint8Array(32); + var x = new Float64Array(80), r, i; + var a = gf(), b = gf(), c = gf(), + d = gf(), e = gf(), f = gf(); + for (i = 0; i < 31; i++) z[i] = n[i]; + z[31]=(n[31]&127)|64; + z[0]&=248; + unpack25519(x,p); + for (i = 0; i < 16; i++) { + b[i]=x[i]; + d[i]=a[i]=c[i]=0; + } + a[0]=d[0]=1; + for (i=254; i>=0; --i) { + r=(z[i>>>3]>>>(i&7))&1; + sel25519(a,b,r); + sel25519(c,d,r); + A(e,a,c); + Z(a,a,c); + A(c,b,d); + Z(b,b,d); + S(d,e); + S(f,a); + M(a,c,a); + M(c,b,e); + A(e,a,c); + Z(a,a,c); + S(b,a); + Z(c,d,f); + M(a,c,_121665); + A(a,a,d); + M(c,c,a); + M(a,d,f); + M(d,b,x); + S(b,e); + sel25519(a,b,r); + sel25519(c,d,r); + } + for (i = 0; i < 16; i++) { + x[i+16]=a[i]; + x[i+32]=c[i]; + x[i+48]=b[i]; + x[i+64]=d[i]; + } + var x32 = x.subarray(32); + var x16 = x.subarray(16); + inv25519(x32,x32); + M(x16,x16,x32); + pack25519(q,x16); + return 0; +} + +function crypto_scalarmult_base(q, n) { + return crypto_scalarmult(q, n, _9); +} + +function crypto_box_keypair(y, x) { + randombytes(x, 32); + return crypto_scalarmult_base(y, x); +} + +function crypto_box_beforenm(k, y, x) { + var s = new Uint8Array(32); + crypto_scalarmult(s, x, y); + return crypto_core_hsalsa20(k, _0, s, sigma); +} + +var crypto_box_afternm = crypto_secretbox; +var crypto_box_open_afternm = crypto_secretbox_open; + +function crypto_box(c, m, d, n, y, x) { + var k = new Uint8Array(32); + crypto_box_beforenm(k, y, x); + return crypto_box_afternm(c, m, d, n, k); +} + +function crypto_box_open(m, c, d, n, y, x) { + var k = new Uint8Array(32); + crypto_box_beforenm(k, y, x); + return crypto_box_open_afternm(m, c, d, n, k); +} + +var K = [ + 0x428a2f98, 0xd728ae22, 0x71374491, 0x23ef65cd, + 0xb5c0fbcf, 0xec4d3b2f, 0xe9b5dba5, 0x8189dbbc, + 0x3956c25b, 0xf348b538, 0x59f111f1, 0xb605d019, + 0x923f82a4, 0xaf194f9b, 0xab1c5ed5, 0xda6d8118, + 0xd807aa98, 0xa3030242, 0x12835b01, 0x45706fbe, + 0x243185be, 0x4ee4b28c, 0x550c7dc3, 0xd5ffb4e2, + 0x72be5d74, 0xf27b896f, 0x80deb1fe, 0x3b1696b1, + 0x9bdc06a7, 0x25c71235, 0xc19bf174, 0xcf692694, + 0xe49b69c1, 0x9ef14ad2, 0xefbe4786, 0x384f25e3, + 0x0fc19dc6, 0x8b8cd5b5, 0x240ca1cc, 0x77ac9c65, + 0x2de92c6f, 0x592b0275, 0x4a7484aa, 0x6ea6e483, + 0x5cb0a9dc, 0xbd41fbd4, 0x76f988da, 0x831153b5, + 0x983e5152, 0xee66dfab, 0xa831c66d, 0x2db43210, + 0xb00327c8, 0x98fb213f, 0xbf597fc7, 0xbeef0ee4, + 0xc6e00bf3, 0x3da88fc2, 0xd5a79147, 0x930aa725, + 0x06ca6351, 0xe003826f, 0x14292967, 0x0a0e6e70, + 0x27b70a85, 0x46d22ffc, 0x2e1b2138, 0x5c26c926, + 0x4d2c6dfc, 0x5ac42aed, 0x53380d13, 0x9d95b3df, + 0x650a7354, 0x8baf63de, 0x766a0abb, 0x3c77b2a8, + 0x81c2c92e, 0x47edaee6, 0x92722c85, 0x1482353b, + 0xa2bfe8a1, 0x4cf10364, 0xa81a664b, 0xbc423001, + 0xc24b8b70, 0xd0f89791, 0xc76c51a3, 0x0654be30, + 0xd192e819, 0xd6ef5218, 0xd6990624, 0x5565a910, + 0xf40e3585, 0x5771202a, 0x106aa070, 0x32bbd1b8, + 0x19a4c116, 0xb8d2d0c8, 0x1e376c08, 0x5141ab53, + 0x2748774c, 0xdf8eeb99, 0x34b0bcb5, 0xe19b48a8, + 0x391c0cb3, 0xc5c95a63, 0x4ed8aa4a, 0xe3418acb, + 0x5b9cca4f, 0x7763e373, 0x682e6ff3, 0xd6b2b8a3, + 0x748f82ee, 0x5defb2fc, 0x78a5636f, 0x43172f60, + 0x84c87814, 0xa1f0ab72, 0x8cc70208, 0x1a6439ec, + 0x90befffa, 0x23631e28, 0xa4506ceb, 0xde82bde9, + 0xbef9a3f7, 0xb2c67915, 0xc67178f2, 0xe372532b, + 0xca273ece, 0xea26619c, 0xd186b8c7, 0x21c0c207, + 0xeada7dd6, 0xcde0eb1e, 0xf57d4f7f, 0xee6ed178, + 0x06f067aa, 0x72176fba, 0x0a637dc5, 0xa2c898a6, + 0x113f9804, 0xbef90dae, 0x1b710b35, 0x131c471b, + 0x28db77f5, 0x23047d84, 0x32caab7b, 0x40c72493, + 0x3c9ebe0a, 0x15c9bebc, 0x431d67c4, 0x9c100d4c, + 0x4cc5d4be, 0xcb3e42b6, 0x597f299c, 0xfc657e2a, + 0x5fcb6fab, 0x3ad6faec, 0x6c44198c, 0x4a475817 +]; + +function crypto_hashblocks_hl(hh, hl, m, n) { + var wh = new Int32Array(16), wl = new Int32Array(16), + bh0, bh1, bh2, bh3, bh4, bh5, bh6, bh7, + bl0, bl1, bl2, bl3, bl4, bl5, bl6, bl7, + th, tl, i, j, h, l, a, b, c, d; + + var ah0 = hh[0], + ah1 = hh[1], + ah2 = hh[2], + ah3 = hh[3], + ah4 = hh[4], + ah5 = hh[5], + ah6 = hh[6], + ah7 = hh[7], + + al0 = hl[0], + al1 = hl[1], + al2 = hl[2], + al3 = hl[3], + al4 = hl[4], + al5 = hl[5], + al6 = hl[6], + al7 = hl[7]; + + var pos = 0; + while (n >= 128) { + for (i = 0; i < 16; i++) { + j = 8 * i + pos; + wh[i] = (m[j+0] << 24) | (m[j+1] << 16) | (m[j+2] << 8) | m[j+3]; + wl[i] = (m[j+4] << 24) | (m[j+5] << 16) | (m[j+6] << 8) | m[j+7]; + } + for (i = 0; i < 80; i++) { + bh0 = ah0; + bh1 = ah1; + bh2 = ah2; + bh3 = ah3; + bh4 = ah4; + bh5 = ah5; + bh6 = ah6; + bh7 = ah7; + + bl0 = al0; + bl1 = al1; + bl2 = al2; + bl3 = al3; + bl4 = al4; + bl5 = al5; + bl6 = al6; + bl7 = al7; + + // add + h = ah7; + l = al7; + + a = l & 0xffff; b = l >>> 16; + c = h & 0xffff; d = h >>> 16; + + // Sigma1 + h = ((ah4 >>> 14) | (al4 << (32-14))) ^ ((ah4 >>> 18) | (al4 << (32-18))) ^ ((al4 >>> (41-32)) | (ah4 << (32-(41-32)))); + l = ((al4 >>> 14) | (ah4 << (32-14))) ^ ((al4 >>> 18) | (ah4 << (32-18))) ^ ((ah4 >>> (41-32)) | (al4 << (32-(41-32)))); + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + // Ch + h = (ah4 & ah5) ^ (~ah4 & ah6); + l = (al4 & al5) ^ (~al4 & al6); + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + // K + h = K[i*2]; + l = K[i*2+1]; + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + // w + h = wh[i%16]; + l = wl[i%16]; + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + b += a >>> 16; + c += b >>> 16; + d += c >>> 16; + + th = c & 0xffff | d << 16; + tl = a & 0xffff | b << 16; + + // add + h = th; + l = tl; + + a = l & 0xffff; b = l >>> 16; + c = h & 0xffff; d = h >>> 16; + + // Sigma0 + h = ((ah0 >>> 28) | (al0 << (32-28))) ^ ((al0 >>> (34-32)) | (ah0 << (32-(34-32)))) ^ ((al0 >>> (39-32)) | (ah0 << (32-(39-32)))); + l = ((al0 >>> 28) | (ah0 << (32-28))) ^ ((ah0 >>> (34-32)) | (al0 << (32-(34-32)))) ^ ((ah0 >>> (39-32)) | (al0 << (32-(39-32)))); + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + // Maj + h = (ah0 & ah1) ^ (ah0 & ah2) ^ (ah1 & ah2); + l = (al0 & al1) ^ (al0 & al2) ^ (al1 & al2); + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + b += a >>> 16; + c += b >>> 16; + d += c >>> 16; + + bh7 = (c & 0xffff) | (d << 16); + bl7 = (a & 0xffff) | (b << 16); + + // add + h = bh3; + l = bl3; + + a = l & 0xffff; b = l >>> 16; + c = h & 0xffff; d = h >>> 16; + + h = th; + l = tl; + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + b += a >>> 16; + c += b >>> 16; + d += c >>> 16; + + bh3 = (c & 0xffff) | (d << 16); + bl3 = (a & 0xffff) | (b << 16); + + ah1 = bh0; + ah2 = bh1; + ah3 = bh2; + ah4 = bh3; + ah5 = bh4; + ah6 = bh5; + ah7 = bh6; + ah0 = bh7; + + al1 = bl0; + al2 = bl1; + al3 = bl2; + al4 = bl3; + al5 = bl4; + al6 = bl5; + al7 = bl6; + al0 = bl7; + + if (i%16 === 15) { + for (j = 0; j < 16; j++) { + // add + h = wh[j]; + l = wl[j]; + + a = l & 0xffff; b = l >>> 16; + c = h & 0xffff; d = h >>> 16; + + h = wh[(j+9)%16]; + l = wl[(j+9)%16]; + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + // sigma0 + th = wh[(j+1)%16]; + tl = wl[(j+1)%16]; + h = ((th >>> 1) | (tl << (32-1))) ^ ((th >>> 8) | (tl << (32-8))) ^ (th >>> 7); + l = ((tl >>> 1) | (th << (32-1))) ^ ((tl >>> 8) | (th << (32-8))) ^ ((tl >>> 7) | (th << (32-7))); + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + // sigma1 + th = wh[(j+14)%16]; + tl = wl[(j+14)%16]; + h = ((th >>> 19) | (tl << (32-19))) ^ ((tl >>> (61-32)) | (th << (32-(61-32)))) ^ (th >>> 6); + l = ((tl >>> 19) | (th << (32-19))) ^ ((th >>> (61-32)) | (tl << (32-(61-32)))) ^ ((tl >>> 6) | (th << (32-6))); + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + b += a >>> 16; + c += b >>> 16; + d += c >>> 16; + + wh[j] = (c & 0xffff) | (d << 16); + wl[j] = (a & 0xffff) | (b << 16); + } + } + } + + // add + h = ah0; + l = al0; + + a = l & 0xffff; b = l >>> 16; + c = h & 0xffff; d = h >>> 16; + + h = hh[0]; + l = hl[0]; + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + b += a >>> 16; + c += b >>> 16; + d += c >>> 16; + + hh[0] = ah0 = (c & 0xffff) | (d << 16); + hl[0] = al0 = (a & 0xffff) | (b << 16); + + h = ah1; + l = al1; + + a = l & 0xffff; b = l >>> 16; + c = h & 0xffff; d = h >>> 16; + + h = hh[1]; + l = hl[1]; + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + b += a >>> 16; + c += b >>> 16; + d += c >>> 16; + + hh[1] = ah1 = (c & 0xffff) | (d << 16); + hl[1] = al1 = (a & 0xffff) | (b << 16); + + h = ah2; + l = al2; + + a = l & 0xffff; b = l >>> 16; + c = h & 0xffff; d = h >>> 16; + + h = hh[2]; + l = hl[2]; + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + b += a >>> 16; + c += b >>> 16; + d += c >>> 16; + + hh[2] = ah2 = (c & 0xffff) | (d << 16); + hl[2] = al2 = (a & 0xffff) | (b << 16); + + h = ah3; + l = al3; + + a = l & 0xffff; b = l >>> 16; + c = h & 0xffff; d = h >>> 16; + + h = hh[3]; + l = hl[3]; + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + b += a >>> 16; + c += b >>> 16; + d += c >>> 16; + + hh[3] = ah3 = (c & 0xffff) | (d << 16); + hl[3] = al3 = (a & 0xffff) | (b << 16); + + h = ah4; + l = al4; + + a = l & 0xffff; b = l >>> 16; + c = h & 0xffff; d = h >>> 16; + + h = hh[4]; + l = hl[4]; + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + b += a >>> 16; + c += b >>> 16; + d += c >>> 16; + + hh[4] = ah4 = (c & 0xffff) | (d << 16); + hl[4] = al4 = (a & 0xffff) | (b << 16); + + h = ah5; + l = al5; + + a = l & 0xffff; b = l >>> 16; + c = h & 0xffff; d = h >>> 16; + + h = hh[5]; + l = hl[5]; + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + b += a >>> 16; + c += b >>> 16; + d += c >>> 16; + + hh[5] = ah5 = (c & 0xffff) | (d << 16); + hl[5] = al5 = (a & 0xffff) | (b << 16); + + h = ah6; + l = al6; + + a = l & 0xffff; b = l >>> 16; + c = h & 0xffff; d = h >>> 16; + + h = hh[6]; + l = hl[6]; + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + b += a >>> 16; + c += b >>> 16; + d += c >>> 16; + + hh[6] = ah6 = (c & 0xffff) | (d << 16); + hl[6] = al6 = (a & 0xffff) | (b << 16); + + h = ah7; + l = al7; + + a = l & 0xffff; b = l >>> 16; + c = h & 0xffff; d = h >>> 16; + + h = hh[7]; + l = hl[7]; + + a += l & 0xffff; b += l >>> 16; + c += h & 0xffff; d += h >>> 16; + + b += a >>> 16; + c += b >>> 16; + d += c >>> 16; + + hh[7] = ah7 = (c & 0xffff) | (d << 16); + hl[7] = al7 = (a & 0xffff) | (b << 16); + + pos += 128; + n -= 128; + } + + return n; +} + +function crypto_hash(out, m, n) { + var hh = new Int32Array(8), + hl = new Int32Array(8), + x = new Uint8Array(256), + i, b = n; + + hh[0] = 0x6a09e667; + hh[1] = 0xbb67ae85; + hh[2] = 0x3c6ef372; + hh[3] = 0xa54ff53a; + hh[4] = 0x510e527f; + hh[5] = 0x9b05688c; + hh[6] = 0x1f83d9ab; + hh[7] = 0x5be0cd19; + + hl[0] = 0xf3bcc908; + hl[1] = 0x84caa73b; + hl[2] = 0xfe94f82b; + hl[3] = 0x5f1d36f1; + hl[4] = 0xade682d1; + hl[5] = 0x2b3e6c1f; + hl[6] = 0xfb41bd6b; + hl[7] = 0x137e2179; + + crypto_hashblocks_hl(hh, hl, m, n); + n %= 128; + + for (i = 0; i < n; i++) x[i] = m[b-n+i]; + x[n] = 128; + + n = 256-128*(n<112?1:0); + x[n-9] = 0; + ts64(x, n-8, (b / 0x20000000) | 0, b << 3); + crypto_hashblocks_hl(hh, hl, x, n); + + for (i = 0; i < 8; i++) ts64(out, 8*i, hh[i], hl[i]); + + return 0; +} + +function add(p, q) { + var a = gf(), b = gf(), c = gf(), + d = gf(), e = gf(), f = gf(), + g = gf(), h = gf(), t = gf(); + + Z(a, p[1], p[0]); + Z(t, q[1], q[0]); + M(a, a, t); + A(b, p[0], p[1]); + A(t, q[0], q[1]); + M(b, b, t); + M(c, p[3], q[3]); + M(c, c, D2); + M(d, p[2], q[2]); + A(d, d, d); + Z(e, b, a); + Z(f, d, c); + A(g, d, c); + A(h, b, a); + + M(p[0], e, f); + M(p[1], h, g); + M(p[2], g, f); + M(p[3], e, h); +} + +function cswap(p, q, b) { + var i; + for (i = 0; i < 4; i++) { + sel25519(p[i], q[i], b); + } +} + +function pack(r, p) { + var tx = gf(), ty = gf(), zi = gf(); + inv25519(zi, p[2]); + M(tx, p[0], zi); + M(ty, p[1], zi); + pack25519(r, ty); + r[31] ^= par25519(tx) << 7; +} + +function scalarmult(p, q, s) { + var b, i; + set25519(p[0], gf0); + set25519(p[1], gf1); + set25519(p[2], gf1); + set25519(p[3], gf0); + for (i = 255; i >= 0; --i) { + b = (s[(i/8)|0] >> (i&7)) & 1; + cswap(p, q, b); + add(q, p); + add(p, p); + cswap(p, q, b); + } +} + +function scalarbase(p, s) { + var q = [gf(), gf(), gf(), gf()]; + set25519(q[0], X); + set25519(q[1], Y); + set25519(q[2], gf1); + M(q[3], X, Y); + scalarmult(p, q, s); +} + +function crypto_sign_keypair(pk, sk, seeded) { + var d = new Uint8Array(64); + var p = [gf(), gf(), gf(), gf()]; + var i; + + if (!seeded) randombytes(sk, 32); + crypto_hash(d, sk, 32); + d[0] &= 248; + d[31] &= 127; + d[31] |= 64; + + scalarbase(p, d); + pack(pk, p); + + for (i = 0; i < 32; i++) sk[i+32] = pk[i]; + return 0; +} + +var L = new Float64Array([0xed, 0xd3, 0xf5, 0x5c, 0x1a, 0x63, 0x12, 0x58, 0xd6, 0x9c, 0xf7, 0xa2, 0xde, 0xf9, 0xde, 0x14, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0x10]); + +function modL(r, x) { + var carry, i, j, k; + for (i = 63; i >= 32; --i) { + carry = 0; + for (j = i - 32, k = i - 12; j < k; ++j) { + x[j] += carry - 16 * x[i] * L[j - (i - 32)]; + carry = (x[j] + 128) >> 8; + x[j] -= carry * 256; + } + x[j] += carry; + x[i] = 0; + } + carry = 0; + for (j = 0; j < 32; j++) { + x[j] += carry - (x[31] >> 4) * L[j]; + carry = x[j] >> 8; + x[j] &= 255; + } + for (j = 0; j < 32; j++) x[j] -= carry * L[j]; + for (i = 0; i < 32; i++) { + x[i+1] += x[i] >> 8; + r[i] = x[i] & 255; + } +} + +function reduce(r) { + var x = new Float64Array(64), i; + for (i = 0; i < 64; i++) x[i] = r[i]; + for (i = 0; i < 64; i++) r[i] = 0; + modL(r, x); +} + +// Note: difference from C - smlen returned, not passed as argument. +function crypto_sign(sm, m, n, sk) { + var d = new Uint8Array(64), h = new Uint8Array(64), r = new Uint8Array(64); + var i, j, x = new Float64Array(64); + var p = [gf(), gf(), gf(), gf()]; + + crypto_hash(d, sk, 32); + d[0] &= 248; + d[31] &= 127; + d[31] |= 64; + + var smlen = n + 64; + for (i = 0; i < n; i++) sm[64 + i] = m[i]; + for (i = 0; i < 32; i++) sm[32 + i] = d[32 + i]; + + crypto_hash(r, sm.subarray(32), n+32); + reduce(r); + scalarbase(p, r); + pack(sm, p); + + for (i = 32; i < 64; i++) sm[i] = sk[i]; + crypto_hash(h, sm, n + 64); + reduce(h); + + for (i = 0; i < 64; i++) x[i] = 0; + for (i = 0; i < 32; i++) x[i] = r[i]; + for (i = 0; i < 32; i++) { + for (j = 0; j < 32; j++) { + x[i+j] += h[i] * d[j]; + } + } + + modL(sm.subarray(32), x); + return smlen; +} + +function unpackneg(r, p) { + var t = gf(), chk = gf(), num = gf(), + den = gf(), den2 = gf(), den4 = gf(), + den6 = gf(); + + set25519(r[2], gf1); + unpack25519(r[1], p); + S(num, r[1]); + M(den, num, D); + Z(num, num, r[2]); + A(den, r[2], den); + + S(den2, den); + S(den4, den2); + M(den6, den4, den2); + M(t, den6, num); + M(t, t, den); + + pow2523(t, t); + M(t, t, num); + M(t, t, den); + M(t, t, den); + M(r[0], t, den); + + S(chk, r[0]); + M(chk, chk, den); + if (neq25519(chk, num)) M(r[0], r[0], I); + + S(chk, r[0]); + M(chk, chk, den); + if (neq25519(chk, num)) return -1; + + if (par25519(r[0]) === (p[31]>>7)) Z(r[0], gf0, r[0]); + + M(r[3], r[0], r[1]); + return 0; +} + +function crypto_sign_open(m, sm, n, pk) { + var i, mlen; + var t = new Uint8Array(32), h = new Uint8Array(64); + var p = [gf(), gf(), gf(), gf()], + q = [gf(), gf(), gf(), gf()]; + + mlen = -1; + if (n < 64) return -1; + + if (unpackneg(q, pk)) return -1; + + for (i = 0; i < n; i++) m[i] = sm[i]; + for (i = 0; i < 32; i++) m[i+32] = pk[i]; + crypto_hash(h, m, n); + reduce(h); + scalarmult(p, q, h); + + scalarbase(q, sm.subarray(32)); + add(p, q); + pack(t, p); + + n -= 64; + if (crypto_verify_32(sm, 0, t, 0)) { + for (i = 0; i < n; i++) m[i] = 0; + return -1; + } + + for (i = 0; i < n; i++) m[i] = sm[i + 64]; + mlen = n; + return mlen; +} + +var crypto_secretbox_KEYBYTES = 32, + crypto_secretbox_NONCEBYTES = 24, + crypto_secretbox_ZEROBYTES = 32, + crypto_secretbox_BOXZEROBYTES = 16, + crypto_scalarmult_BYTES = 32, + crypto_scalarmult_SCALARBYTES = 32, + crypto_box_PUBLICKEYBYTES = 32, + crypto_box_SECRETKEYBYTES = 32, + crypto_box_BEFORENMBYTES = 32, + crypto_box_NONCEBYTES = crypto_secretbox_NONCEBYTES, + crypto_box_ZEROBYTES = crypto_secretbox_ZEROBYTES, + crypto_box_BOXZEROBYTES = crypto_secretbox_BOXZEROBYTES, + crypto_sign_BYTES = 64, + crypto_sign_PUBLICKEYBYTES = 32, + crypto_sign_SECRETKEYBYTES = 64, + crypto_sign_SEEDBYTES = 32, + crypto_hash_BYTES = 64; + +nacl.lowlevel = { + crypto_core_hsalsa20: crypto_core_hsalsa20, + crypto_stream_xor: crypto_stream_xor, + crypto_stream: crypto_stream, + crypto_stream_salsa20_xor: crypto_stream_salsa20_xor, + crypto_stream_salsa20: crypto_stream_salsa20, + crypto_onetimeauth: crypto_onetimeauth, + crypto_onetimeauth_verify: crypto_onetimeauth_verify, + crypto_verify_16: crypto_verify_16, + crypto_verify_32: crypto_verify_32, + crypto_secretbox: crypto_secretbox, + crypto_secretbox_open: crypto_secretbox_open, + crypto_scalarmult: crypto_scalarmult, + crypto_scalarmult_base: crypto_scalarmult_base, + crypto_box_beforenm: crypto_box_beforenm, + crypto_box_afternm: crypto_box_afternm, + crypto_box: crypto_box, + crypto_box_open: crypto_box_open, + crypto_box_keypair: crypto_box_keypair, + crypto_hash: crypto_hash, + crypto_sign: crypto_sign, + crypto_sign_keypair: crypto_sign_keypair, + crypto_sign_open: crypto_sign_open, + + crypto_secretbox_KEYBYTES: crypto_secretbox_KEYBYTES, + crypto_secretbox_NONCEBYTES: crypto_secretbox_NONCEBYTES, + crypto_secretbox_ZEROBYTES: crypto_secretbox_ZEROBYTES, + crypto_secretbox_BOXZEROBYTES: crypto_secretbox_BOXZEROBYTES, + crypto_scalarmult_BYTES: crypto_scalarmult_BYTES, + crypto_scalarmult_SCALARBYTES: crypto_scalarmult_SCALARBYTES, + crypto_box_PUBLICKEYBYTES: crypto_box_PUBLICKEYBYTES, + crypto_box_SECRETKEYBYTES: crypto_box_SECRETKEYBYTES, + crypto_box_BEFORENMBYTES: crypto_box_BEFORENMBYTES, + crypto_box_NONCEBYTES: crypto_box_NONCEBYTES, + crypto_box_ZEROBYTES: crypto_box_ZEROBYTES, + crypto_box_BOXZEROBYTES: crypto_box_BOXZEROBYTES, + crypto_sign_BYTES: crypto_sign_BYTES, + crypto_sign_PUBLICKEYBYTES: crypto_sign_PUBLICKEYBYTES, + crypto_sign_SECRETKEYBYTES: crypto_sign_SECRETKEYBYTES, + crypto_sign_SEEDBYTES: crypto_sign_SEEDBYTES, + crypto_hash_BYTES: crypto_hash_BYTES +}; + +/* High-level API */ + +function checkLengths(k, n) { + if (k.length !== crypto_secretbox_KEYBYTES) throw new Error('bad key size'); + if (n.length !== crypto_secretbox_NONCEBYTES) throw new Error('bad nonce size'); +} + +function checkBoxLengths(pk, sk) { + if (pk.length !== crypto_box_PUBLICKEYBYTES) throw new Error('bad public key size'); + if (sk.length !== crypto_box_SECRETKEYBYTES) throw new Error('bad secret key size'); +} + +function checkArrayTypes() { + var t, i; + for (i = 0; i < arguments.length; i++) { + if ((t = Object.prototype.toString.call(arguments[i])) !== '[object Uint8Array]') + throw new TypeError('unexpected type ' + t + ', use Uint8Array'); + } +} + +function cleanup(arr) { + for (var i = 0; i < arr.length; i++) arr[i] = 0; +} + +nacl.util = {}; + +nacl.util.decodeUTF8 = function(s) { + var i, d = unescape(encodeURIComponent(s)), b = new Uint8Array(d.length); + for (i = 0; i < d.length; i++) b[i] = d.charCodeAt(i); + return b; +}; + +nacl.util.encodeUTF8 = function(arr) { + var i, s = []; + for (i = 0; i < arr.length; i++) s.push(String.fromCharCode(arr[i])); + return decodeURIComponent(escape(s.join(''))); +}; + +nacl.util.encodeBase64 = function(arr) { + if (typeof btoa === 'undefined') { + return (new Buffer(arr)).toString('base64'); + } else { + var i, s = [], len = arr.length; + for (i = 0; i < len; i++) s.push(String.fromCharCode(arr[i])); + return btoa(s.join('')); + } +}; + +nacl.util.decodeBase64 = function(s) { + if (typeof atob === 'undefined') { + return new Uint8Array(Array.prototype.slice.call(new Buffer(s, 'base64'), 0)); + } else { + var i, d = atob(s), b = new Uint8Array(d.length); + for (i = 0; i < d.length; i++) b[i] = d.charCodeAt(i); + return b; + } +}; + +nacl.randomBytes = function(n) { + var b = new Uint8Array(n); + randombytes(b, n); + return b; +}; + +nacl.secretbox = function(msg, nonce, key) { + checkArrayTypes(msg, nonce, key); + checkLengths(key, nonce); + var m = new Uint8Array(crypto_secretbox_ZEROBYTES + msg.length); + var c = new Uint8Array(m.length); + for (var i = 0; i < msg.length; i++) m[i+crypto_secretbox_ZEROBYTES] = msg[i]; + crypto_secretbox(c, m, m.length, nonce, key); + return c.subarray(crypto_secretbox_BOXZEROBYTES); +}; + +nacl.secretbox.open = function(box, nonce, key) { + checkArrayTypes(box, nonce, key); + checkLengths(key, nonce); + var c = new Uint8Array(crypto_secretbox_BOXZEROBYTES + box.length); + var m = new Uint8Array(c.length); + for (var i = 0; i < box.length; i++) c[i+crypto_secretbox_BOXZEROBYTES] = box[i]; + if (c.length < 32) return false; + if (crypto_secretbox_open(m, c, c.length, nonce, key) !== 0) return false; + return m.subarray(crypto_secretbox_ZEROBYTES); +}; + +nacl.secretbox.keyLength = crypto_secretbox_KEYBYTES; +nacl.secretbox.nonceLength = crypto_secretbox_NONCEBYTES; +nacl.secretbox.overheadLength = crypto_secretbox_BOXZEROBYTES; + +nacl.scalarMult = function(n, p) { + checkArrayTypes(n, p); + if (n.length !== crypto_scalarmult_SCALARBYTES) throw new Error('bad n size'); + if (p.length !== crypto_scalarmult_BYTES) throw new Error('bad p size'); + var q = new Uint8Array(crypto_scalarmult_BYTES); + crypto_scalarmult(q, n, p); + return q; +}; + +nacl.scalarMult.base = function(n) { + checkArrayTypes(n); + if (n.length !== crypto_scalarmult_SCALARBYTES) throw new Error('bad n size'); + var q = new Uint8Array(crypto_scalarmult_BYTES); + crypto_scalarmult_base(q, n); + return q; +}; + +nacl.scalarMult.scalarLength = crypto_scalarmult_SCALARBYTES; +nacl.scalarMult.groupElementLength = crypto_scalarmult_BYTES; + +nacl.box = function(msg, nonce, publicKey, secretKey) { + var k = nacl.box.before(publicKey, secretKey); + return nacl.secretbox(msg, nonce, k); +}; + +nacl.box.before = function(publicKey, secretKey) { + checkArrayTypes(publicKey, secretKey); + checkBoxLengths(publicKey, secretKey); + var k = new Uint8Array(crypto_box_BEFORENMBYTES); + crypto_box_beforenm(k, publicKey, secretKey); + return k; +}; + +nacl.box.after = nacl.secretbox; + +nacl.box.open = function(msg, nonce, publicKey, secretKey) { + var k = nacl.box.before(publicKey, secretKey); + return nacl.secretbox.open(msg, nonce, k); +}; + +nacl.box.open.after = nacl.secretbox.open; + +nacl.box.keyPair = function() { + var pk = new Uint8Array(crypto_box_PUBLICKEYBYTES); + var sk = new Uint8Array(crypto_box_SECRETKEYBYTES); + crypto_box_keypair(pk, sk); + return {publicKey: pk, secretKey: sk}; +}; + +nacl.box.keyPair.fromSecretKey = function(secretKey) { + checkArrayTypes(secretKey); + if (secretKey.length !== crypto_box_SECRETKEYBYTES) + throw new Error('bad secret key size'); + var pk = new Uint8Array(crypto_box_PUBLICKEYBYTES); + crypto_scalarmult_base(pk, secretKey); + return {publicKey: pk, secretKey: new Uint8Array(secretKey)}; +}; + +nacl.box.publicKeyLength = crypto_box_PUBLICKEYBYTES; +nacl.box.secretKeyLength = crypto_box_SECRETKEYBYTES; +nacl.box.sharedKeyLength = crypto_box_BEFORENMBYTES; +nacl.box.nonceLength = crypto_box_NONCEBYTES; +nacl.box.overheadLength = nacl.secretbox.overheadLength; + +nacl.sign = function(msg, secretKey) { + checkArrayTypes(msg, secretKey); + if (secretKey.length !== crypto_sign_SECRETKEYBYTES) + throw new Error('bad secret key size'); + var signedMsg = new Uint8Array(crypto_sign_BYTES+msg.length); + crypto_sign(signedMsg, msg, msg.length, secretKey); + return signedMsg; +}; + +nacl.sign.open = function(signedMsg, publicKey) { + if (arguments.length !== 2) + throw new Error('nacl.sign.open accepts 2 arguments; did you mean to use nacl.sign.detached.verify?'); + checkArrayTypes(signedMsg, publicKey); + if (publicKey.length !== crypto_sign_PUBLICKEYBYTES) + throw new Error('bad public key size'); + var tmp = new Uint8Array(signedMsg.length); + var mlen = crypto_sign_open(tmp, signedMsg, signedMsg.length, publicKey); + if (mlen < 0) return null; + var m = new Uint8Array(mlen); + for (var i = 0; i < m.length; i++) m[i] = tmp[i]; + return m; +}; + +nacl.sign.detached = function(msg, secretKey) { + var signedMsg = nacl.sign(msg, secretKey); + var sig = new Uint8Array(crypto_sign_BYTES); + for (var i = 0; i < sig.length; i++) sig[i] = signedMsg[i]; + return sig; +}; + +nacl.sign.detached.verify = function(msg, sig, publicKey) { + checkArrayTypes(msg, sig, publicKey); + if (sig.length !== crypto_sign_BYTES) + throw new Error('bad signature size'); + if (publicKey.length !== crypto_sign_PUBLICKEYBYTES) + throw new Error('bad public key size'); + var sm = new Uint8Array(crypto_sign_BYTES + msg.length); + var m = new Uint8Array(crypto_sign_BYTES + msg.length); + var i; + for (i = 0; i < crypto_sign_BYTES; i++) sm[i] = sig[i]; + for (i = 0; i < msg.length; i++) sm[i+crypto_sign_BYTES] = msg[i]; + return (crypto_sign_open(m, sm, sm.length, publicKey) >= 0); +}; + +nacl.sign.keyPair = function() { + var pk = new Uint8Array(crypto_sign_PUBLICKEYBYTES); + var sk = new Uint8Array(crypto_sign_SECRETKEYBYTES); + crypto_sign_keypair(pk, sk); + return {publicKey: pk, secretKey: sk}; +}; + +nacl.sign.keyPair.fromSecretKey = function(secretKey) { + checkArrayTypes(secretKey); + if (secretKey.length !== crypto_sign_SECRETKEYBYTES) + throw new Error('bad secret key size'); + var pk = new Uint8Array(crypto_sign_PUBLICKEYBYTES); + for (var i = 0; i < pk.length; i++) pk[i] = secretKey[32+i]; + return {publicKey: pk, secretKey: new Uint8Array(secretKey)}; +}; + +nacl.sign.keyPair.fromSeed = function(seed) { + checkArrayTypes(seed); + if (seed.length !== crypto_sign_SEEDBYTES) + throw new Error('bad seed size'); + var pk = new Uint8Array(crypto_sign_PUBLICKEYBYTES); + var sk = new Uint8Array(crypto_sign_SECRETKEYBYTES); + for (var i = 0; i < 32; i++) sk[i] = seed[i]; + crypto_sign_keypair(pk, sk, true); + return {publicKey: pk, secretKey: sk}; +}; + +nacl.sign.publicKeyLength = crypto_sign_PUBLICKEYBYTES; +nacl.sign.secretKeyLength = crypto_sign_SECRETKEYBYTES; +nacl.sign.seedLength = crypto_sign_SEEDBYTES; +nacl.sign.signatureLength = crypto_sign_BYTES; + +nacl.hash = function(msg) { + checkArrayTypes(msg); + var h = new Uint8Array(crypto_hash_BYTES); + crypto_hash(h, msg, msg.length); + return h; +}; + +nacl.hash.hashLength = crypto_hash_BYTES; + +nacl.verify = function(x, y) { + checkArrayTypes(x, y); + // Zero length arguments are considered not equal. + if (x.length === 0 || y.length === 0) return false; + if (x.length !== y.length) return false; + return (vn(x, 0, y, 0, x.length) === 0) ? true : false; +}; + +nacl.setPRNG = function(fn) { + randombytes = fn; +}; + +(function() { + // Initialize PRNG if environment provides CSPRNG. + // If not, methods calling randombytes will throw. + var crypto; + if (typeof window !== 'undefined') { + // Browser. + if (window.crypto && window.crypto.getRandomValues) { + crypto = window.crypto; // Standard + } else if (window.msCrypto && window.msCrypto.getRandomValues) { + crypto = window.msCrypto; // Internet Explorer 11+ + } + if (crypto) { + nacl.setPRNG(function(x, n) { + var i, v = new Uint8Array(n); + crypto.getRandomValues(v); + for (i = 0; i < n; i++) x[i] = v[i]; + cleanup(v); + }); + } + } else if (typeof require !== 'undefined') { + // Node.js. + crypto = require('crypto'); + if (crypto) { + nacl.setPRNG(function(x, n) { + var i, v = crypto.randomBytes(n); + for (i = 0; i < n; i++) x[i] = v[i]; + cleanup(v); + }); + } + } +})(); + +// == CHANGE TO ES6 EXPORT == // +//})(typeof module !== 'undefined' && module.exports ? module.exports : (window.nacl = window.nacl || {})); +export default nacl \ No newline at end of file diff --git a/qortal-ui-crypto/api/deps/qora.js b/qortal-ui-crypto/api/deps/qora.js new file mode 100644 index 00000000..5c52ec44 --- /dev/null +++ b/qortal-ui-crypto/api/deps/qora.js @@ -0,0 +1,336 @@ +// QORA + +const TYPES = { + GENESIS_TRANSACTION: 1, + PAYMENT_TRANSACTION: 2, + + REGISTER_NAME_TRANSACTION: 3, + UPDATE_NAME_TRANSACTION: 4, + SELL_NAME_TRANSACTION: 5, + CANCEL_SELL_NAME_TRANSACTION: 6, + BUY_NAME_TRANSACTION: 7, + + CREATE_POLL_TRANSACTION: 8, + VOTE_ON_POLL_TRANSACTION: 9, + + ARBITRARY_TRANSACTION: 10, + + ISSUE_ASSET_TRANSACTION: 11, + TRANSFER_ASSET_TRANSACTION: 12, + CREATE_ORDER_TRANSACTION: 13, + CANCEL_ORDER_TRANSACTION: 14, + MULTI_PAYMENT_TRANSACTION: 15, + + DEPLOY_AT_TRANSACTION: 16, + + MESSAGE_TRANSACTION: 17 +}; + +function getKeyPairFromSeed(seed, returnBase58) +{ + if(typeof(seed) == "string") { + seed = new Uint8Array(Base58.decode(seed)); + } + + var keyPair = nacl.sign.keyPair.fromSeed(seed); + + var base58privateKey = Base58.encode(keyPair.secretKey); + var base58publicKey = Base58.encode(keyPair.publicKey); + if(returnBase58) { + return { + privateKey: Base58.encode(keyPair.secretKey), + publicKey: Base58.encode(keyPair.publicKey) + }; + } else { + return { + privateKey: keyPair.secretKey, + publicKey: keyPair.publicKey + }; + } +} + +function stringtoUTF8Array(message) { + if (typeof message == 'string') { + var s = unescape(encodeURIComponent(message)); // UTF-8 + message = new Uint8Array(s.length); + for (var i = 0; i < s.length; i++) { + message[i] = s.charCodeAt(i) & 0xff; + } + } + return message; +} + +function int32ToBytes (word) { + var byteArray = []; + for (var b = 0; b < 32; b += 8) { + byteArray.push((word >>> (24 - b % 32)) & 0xFF); + } + return byteArray; +} + +function int64ToBytes (int64) { + // we want to represent the input as a 8-bytes array + var byteArray = [0, 0, 0, 0, 0, 0, 0, 0]; + + for ( var index = 0; index < byteArray.length; index ++ ) { + var byte = int64 & 0xff; + byteArray [ byteArray.length - index - 1 ] = byte; + int64 = (int64 - byte) / 256 ; + } + + return byteArray; +} + +function appendBuffer (buffer1, buffer2) { + buffer1 = new Uint8Array(buffer1); + buffer2 = new Uint8Array(buffer2); + var tmp = new Uint8Array(buffer1.byteLength + buffer2.byteLength); + tmp.set(buffer1, 0); + tmp.set(buffer2, buffer1.byteLength); + return tmp; +} + +function equal (buf1, buf2) +{ + if (buf1.byteLength != buf2.byteLength) return false; + var dv1 = new Uint8Array(buf1); + var dv2 = new Uint8Array(buf2); + for (var i = 0; i != buf1.byteLength; i++) + { + if (dv1[i] != dv2[i]) return false; + } + return true; +} + +function generateAccountSeed(seed, nonce, returnBase58) +{ + if(typeof(seed) == "string") { + seed = Base58.decode(seed); + } + + nonceBytes = int32ToBytes(nonce); + + var resultSeed = new Uint8Array(); + + resultSeed = appendBuffer(resultSeed, nonceBytes); + resultSeed = appendBuffer(resultSeed, seed); + resultSeed = appendBuffer(resultSeed, nonceBytes); + + if(returnBase58) { + return Base58.encode(SHA256.digest(SHA256.digest(resultSeed))); + } else { + return new SHA256.digest(SHA256.digest(resultSeed)); + } + +} + +function getAccountAddressFromPublicKey(publicKey) +{ + var ADDRESS_VERSION = 58; // Q + + if(typeof(publicKey) == "string") { + publicKey = Base58.decode(publicKey); + } + + var publicKeyHashSHA256 = SHA256.digest(publicKey); + + var ripemd160 = new RIPEMD160(); + + var publicKeyHash = ripemd160.digest(publicKeyHashSHA256); + + var addressArray = new Uint8Array(); + + addressArray = appendBuffer(addressArray, [ADDRESS_VERSION]); + addressArray = appendBuffer(addressArray, publicKeyHash); + + var checkSum = SHA256.digest(SHA256.digest(addressArray)); + + addressArray = appendBuffer(addressArray, checkSum.subarray(0, 4)); + + return Base58.encode(addressArray); +} + +function getAccountAddressType(address) +{ + try { + var ADDRESS_VERSION = 58; // Q + var AT_ADDRESS_VERSION = 23; // A + + if(typeof(address) == "string") { + address = Base58.decode(address); + } + + var checkSum = address.subarray(address.length - 4, address.length) + var addressWitoutChecksum = address.subarray(0, address.length - 4); + + var checkSumTwo = SHA256.digest(SHA256.digest(addressWitoutChecksum)); + checkSumTwo = checkSumTwo.subarray(0, 4); + + if (equal(checkSum, checkSumTwo)) + { + if(address[0] == ADDRESS_VERSION) + { + return "standard"; + } + if(address[0] == AT_ADDRESS_VERSION) + { + return "at"; + } + } + + return "invalid"; + + } catch (e) { + return "invalid"; + } +} + +function isValidAddress(address) +{ + return (getAccountAddressType(address) != "invalid"); +} + +function generateSignaturePaymentTransaction(keyPair, lastReference, recipient, amount, fee, timestamp) { + const data = generatePaymentTransactionBase(keyPair.publicKey, lastReference, recipient, amount, fee, timestamp); + return nacl.sign.detached(data, keyPair.privateKey); +} + +function generatePaymentTransaction(keyPair, lastReference, recipient, amount, fee, timestamp, signature) { + return appendBuffer(generatePaymentTransactionBase(keyPair.publicKey, lastReference, recipient, amount, fee, timestamp), + signature); +} + +function generatePaymentTransactionBase(publicKey, lastReference, recipient, amount, fee, timestamp) { + const txType = TYPES.PAYMENT_TRANSACTION; + const typeBytes = int32ToBytes(txType); + const timestampBytes = int64ToBytes(timestamp); + const amountBytes = int64ToBytes(amount * 100000000); + const feeBytes = int64ToBytes(fee * 100000000); + + var data = new Uint8Array(); + + data = appendBuffer(data, typeBytes); + data = appendBuffer(data, timestampBytes); + data = appendBuffer(data, lastReference); + data = appendBuffer(data, publicKey); + data = appendBuffer(data, recipient); + data = appendBuffer(data, amountBytes); + data = appendBuffer(data, feeBytes); + + return data; +} + +function generateSignatureMessageTransaction(keyPair, lastReference, recipient, amount, fee, timestamp, message, isText, isEncrypted) { + const data = generateMessageTransactionBase(keyPair.publicKey, lastReference, recipient, amount, fee, timestamp, message, isText, isEncrypted); + return nacl.sign.detached(data, keyPair.privateKey); +} + +function generateMessageTransaction(keyPair, lastReference, recipient, amount, fee, timestamp, message, isText, isEncrypted, signature) { + return appendBuffer(generateMessageTransactionBase(keyPair.publicKey, lastReference, recipient, amount, fee, timestamp, message, isText, isEncrypted), + signature); +} + +function generateMessageTransactionBase(publicKey, lastReference, recipient, amount, fee, timestamp, message, isText, isEncrypted) { + txType = TYPES.MESSAGE_TRANSACTION; + + const typeBytes = int32ToBytes(txType); + const timestampBytes = int64ToBytes(timestamp); + const amountBytes = int64ToBytes(amount * 100000000); + const feeBytes = int64ToBytes(fee * 100000000); + const messageLength = int32ToBytes(message.length); + const key = int64ToBytes(0); + + isTextB = new Uint8Array(1); + isTextB[0] = isText; + + isEncryptedB = new Uint8Array(1); + isEncryptedB[0] = isEncrypted; + + var data = new Uint8Array(); + + data = appendBuffer(data, typeBytes); + data = appendBuffer(data, timestampBytes); + data = appendBuffer(data, lastReference); + data = appendBuffer(data, publicKey); + data = appendBuffer(data, recipient); + data = appendBuffer(data, key); + data = appendBuffer(data, amountBytes); + data = appendBuffer(data, messageLength); + data = appendBuffer(data, message); + data = appendBuffer(data, isEncryptedB); + data = appendBuffer(data, isTextB); + data = appendBuffer(data, feeBytes); + + return data; +} + + +function generateSignatureArbitraryTransactionV3(keyPair, lastReference, service, arbitraryData, fee, timestamp) { + const data = generateArbitraryTransactionV3Base(keyPair.publicKey, lastReference, service, arbitraryData, fee, timestamp); + return nacl.sign.detached(data, keyPair.privateKey); +} + +function generateArbitraryTransactionV3(keyPair, lastReference, service, arbitraryData, fee, timestamp, signature) { + return appendBuffer(generateArbitraryTransactionV3Base(keyPair.publicKey, lastReference, service, arbitraryData, fee, timestamp), + signature); +} + +function generateArbitraryTransactionV3Base(publicKey, lastReference, service, arbitraryData, fee, timestamp) { + const txType = TYPES.ARBITRARY_TRANSACTION; + const typeBytes = int32ToBytes(txType); + const timestampBytes = int64ToBytes(timestamp); + const feeBytes = int64ToBytes(fee * 100000000); + const serviceBytes = int32ToBytes(service); + const dataSizeBytes = int32ToBytes(arbitraryData.length); + const paymentsLengthBytes = int32ToBytes(0); // Support payments - not yet. + + var data = new Uint8Array(); + + data = appendBuffer(data, typeBytes); + data = appendBuffer(data, timestampBytes); + data = appendBuffer(data, lastReference); + data = appendBuffer(data, publicKey); + data = appendBuffer(data, paymentsLengthBytes); + // Here it is necessary to insert the payments, if there are + data = appendBuffer(data, serviceBytes); + data = appendBuffer(data, dataSizeBytes); + data = appendBuffer(data, arbitraryData); + data = appendBuffer(data, feeBytes); + + return data; +} + + +function generateSignatureRegisterNameTransaction(keyPair, lastReference, owner, name, value, fee, timestamp) { + const data = generateRegisterNameTransactionBase(keyPair.publicKey, lastReference, owner, name, value, fee, timestamp); + return nacl.sign.detached(data, keyPair.privateKey); +} + +function generateRegisterNameTransaction(keyPair, lastReference, owner, name, value, fee, timestamp, signature) { + return appendBuffer( generateRegisterNameTransactionBase(keyPair.publicKey, lastReference, owner, name, value, fee, timestamp), + signature ); +} + +function generateRegisterNameTransactionBase(publicKey, lastReference, owner, name, value, fee, timestamp) { + const txType = TYPES.REGISTER_NAME_TRANSACTION; + const typeBytes = int32ToBytes(txType); + const timestampBytes = int64ToBytes(timestamp); + const feeBytes = int64ToBytes(fee * 100000000); + const nameSizeBytes = int32ToBytes(name.length); + const valueSizeBytes = int32ToBytes(value.length); + + var data = new Uint8Array(); + + data = appendBuffer(data, typeBytes); + data = appendBuffer(data, timestampBytes); + data = appendBuffer(data, lastReference); + data = appendBuffer(data, publicKey); + data = appendBuffer(data, owner); + data = appendBuffer(data, nameSizeBytes); + data = appendBuffer(data, name); + data = appendBuffer(data, valueSizeBytes); + data = appendBuffer(data, value); + data = appendBuffer(data, feeBytes); + + return data; +} \ No newline at end of file diff --git a/qortal-ui-crypto/api/deps/ripemd160.js b/qortal-ui-crypto/api/deps/ripemd160.js new file mode 100644 index 00000000..a50d0035 --- /dev/null +++ b/qortal-ui-crypto/api/deps/ripemd160.js @@ -0,0 +1,226 @@ +// Extracted from https://github.com/crypto-browserify/ripemd160 +const ARRAY16 = new Array(16); +const zl = initU8Array([ + 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, + 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8, + 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12, + 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2, + 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13 +]); +const zr = initU8Array([ + 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12, + 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2, + 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13, + 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14, + 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11 +]); +const sl = initU8Array([ + 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8, + 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12, + 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5, + 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12, + 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6 +]); +const sr = initU8Array([ + 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6, + 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11, + 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5, + 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8, + 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11 +]); +const hl = initU32Array([0x00000000, 0x5a827999, 0x6ed9eba1, 0x8f1bbcdc, 0xa953fd4e]); +const hr = initU32Array([0x50a28be6, 0x5c4dd124, 0x6d703ef3, 0x7a6d76e9, 0x00000000]); +function rotl(x, n) { + return (x << n) | (x >>> (32 - n)); +} +function fn1(a, b, c, d, e, m, k, s) { + return (rotl((a + (b ^ c ^ d) + m + k) | 0, s) + e) | 0; +} +function fn2(a, b, c, d, e, m, k, s) { + return (rotl((a + ((b & c) | ((~b) & d)) + m + k) | 0, s) + e) | 0; +} +function fn3(a, b, c, d, e, m, k, s) { + return (rotl((a + ((b | (~c)) ^ d) + m + k) | 0, s) + e) | 0; +} +function fn4(a, b, c, d, e, m, k, s) { + return (rotl((a + ((b & d) | (c & (~d))) + m + k) | 0, s) + e) | 0; +} +function fn5(a, b, c, d, e, m, k, s) { + return (rotl((a + (b ^ (c | (~d))) + m + k) | 0, s) + e) | 0; +} +function readInt32LE(buffer, offset) { + offset >>>= 0; + return (buffer[offset]) + | (buffer[offset + 1] << 8) + | (buffer[offset + 2] << 16) + | (buffer[offset + 3] << 24); +} +function writeUInt32LE(buffer, value, offset) { + value = +value; + offset >>>= 0; + buffer[offset + 3] = (value >>> 24); + buffer[offset + 2] = (value >>> 16); + buffer[offset + 1] = (value >>> 8); + buffer[offset] = (value & 0xff); + return offset + 4; +} +function writeInt32LE(buffer, value, offset) { + value = +value; + offset >>>= 0; + buffer[offset] = (value & 0xff); + buffer[offset + 1] = (value >>> 8); + buffer[offset + 2] = (value >>> 16); + buffer[offset + 3] = (value >>> 24); + return offset + 4; +} +function initU32Array(data) { + if (typeof Uint32Array !== 'undefined') { + return new Uint32Array(data); + } + else { + return data; + } +} +function initU8Array(data) { + if (typeof Uint8Array !== 'undefined') { + return new Uint8Array(data); + } + else { + return data; + } +} +function createU8Array(size) { + if (typeof Uint8Array !== 'undefined') { + return new Uint8Array(size); + } + else { + return new Array(size); + } +} +export class RIPEMD160 { + constructor() { + this._block = createU8Array(64); + this._blockSize = 64; + this._blockOffset = 0; + this._length = [0, 0, 0, 0]; + this._finalized = false; + this._a = 0x67452301; + this._b = 0xefcdab89; + this._c = 0x98badcfe; + this._d = 0x10325476; + this._e = 0xc3d2e1f0; + } + update(data) { + if (this._finalized) + throw new Error('Digest already called'); + // consume data + const block = this._block; + let offset = 0; + while (this._blockOffset + data.length - offset >= this._blockSize) { + for (let i = this._blockOffset; i < this._blockSize;) + block[i++] = data[offset++]; + this._update(); + this._blockOffset = 0; + } + while (offset < data.length) + block[this._blockOffset++] = data[offset++]; + // update length + for (let j = 0, carry = data.length * 8; carry > 0; ++j) { + this._length[j] += carry; + carry = (this._length[j] / 0x0100000000) | 0; + if (carry > 0) + this._length[j] -= 0x0100000000 * carry; + } + return this; + } + _update() { + const words = ARRAY16; + for (let j = 0; j < 16; ++j) { + words[j] = readInt32LE(this._block, j * 4); + } + let al = this._a | 0; + let bl = this._b | 0; + let cl = this._c | 0; + let dl = this._d | 0; + let el = this._e | 0; + let ar = this._a | 0; + let br = this._b | 0; + let cr = this._c | 0; + let dr = this._d | 0; + let er = this._e | 0; + // computation + for (let i = 0; i < 80; i += 1) { + let tl; + let tr; + if (i < 16) { + tl = fn1(al, bl, cl, dl, el, words[zl[i]], hl[0], sl[i]); + tr = fn5(ar, br, cr, dr, er, words[zr[i]], hr[0], sr[i]); + } + else if (i < 32) { + tl = fn2(al, bl, cl, dl, el, words[zl[i]], hl[1], sl[i]); + tr = fn4(ar, br, cr, dr, er, words[zr[i]], hr[1], sr[i]); + } + else if (i < 48) { + tl = fn3(al, bl, cl, dl, el, words[zl[i]], hl[2], sl[i]); + tr = fn3(ar, br, cr, dr, er, words[zr[i]], hr[2], sr[i]); + } + else if (i < 64) { + tl = fn4(al, bl, cl, dl, el, words[zl[i]], hl[3], sl[i]); + tr = fn2(ar, br, cr, dr, er, words[zr[i]], hr[3], sr[i]); + } + else { // if (i<80) { + tl = fn5(al, bl, cl, dl, el, words[zl[i]], hl[4], sl[i]); + tr = fn1(ar, br, cr, dr, er, words[zr[i]], hr[4], sr[i]); + } + al = el; + el = dl; + dl = rotl(cl, 10); + cl = bl; + bl = tl; + ar = er; + er = dr; + dr = rotl(cr, 10); + cr = br; + br = tr; + } + // update state + const t = (this._b + cl + dr) | 0; + this._b = (this._c + dl + er) | 0; + this._c = (this._d + el + ar) | 0; + this._d = (this._e + al + br) | 0; + this._e = (this._a + bl + cr) | 0; + this._a = t; + } + digest() { + if (this._finalized) { + throw new Error('Digest already called'); + } + this._finalized = true; + // create padding and handle blocks + this._block[this._blockOffset++] = 0x80; + if (this._blockOffset > 56) { + this._block.fill(0, this._blockOffset, 64); + this._update(); + this._blockOffset = 0; + } + this._block.fill(0, this._blockOffset, 56); + writeUInt32LE(this._block, this._length[0], 56); + writeUInt32LE(this._block, this._length[1], 60); + this._update(); + // produce result + const buffer = createU8Array(20); + writeInt32LE(buffer, this._a, 0); + writeInt32LE(buffer, this._b, 4); + writeInt32LE(buffer, this._c, 8); + writeInt32LE(buffer, this._d, 12); + writeInt32LE(buffer, this._e, 16); + // reset state + this._block.fill(0); + this._blockOffset = 0; + for (let i = 0; i < 4; ++i) { + this._length[i] = 0; + } + return buffer; + } +} +export default RIPEMD160; diff --git a/qortal-ui-crypto/api/deps/sha256.js b/qortal-ui-crypto/api/deps/sha256.js new file mode 100644 index 00000000..e4f718f4 --- /dev/null +++ b/qortal-ui-crypto/api/deps/sha256.js @@ -0,0 +1,142 @@ +// SHA-256 hash function. Copyright-free. +// Requires typed arrays. +const SHA256 = {}; + +SHA256.K = [ + 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, 0x3956c25b, + 0x59f111f1, 0x923f82a4, 0xab1c5ed5, 0xd807aa98, 0x12835b01, + 0x243185be, 0x550c7dc3, 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, + 0xc19bf174, 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc, + 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da, 0x983e5152, + 0xa831c66d, 0xb00327c8, 0xbf597fc7, 0xc6e00bf3, 0xd5a79147, + 0x06ca6351, 0x14292967, 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, + 0x53380d13, 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85, + 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3, 0xd192e819, + 0xd6990624, 0xf40e3585, 0x106aa070, 0x19a4c116, 0x1e376c08, + 0x2748774c, 0x34b0bcb5, 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, + 0x682e6ff3, 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208, + 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2 +]; + +// The digest function returns the hash value (digest) +// as a 32 byte (typed) array. +// message: the string or byte array to hash +SHA256.digest = function(message) { + var h0 = 0x6a09e667; + var h1 = 0xbb67ae85; + var h2 = 0x3c6ef372; + var h3 = 0xa54ff53a; + var h4 = 0x510e527f; + var h5 = 0x9b05688c; + var h6 = 0x1f83d9ab; + var h7 = 0x5be0cd19; + var K = SHA256.K; + if (typeof message == 'string') { + var s = unescape(encodeURIComponent(message)); // UTF-8 + message = new Uint8Array(s.length); + for (var i = 0; i < s.length; i++) { + message[i] = s.charCodeAt(i) & 0xff; + } + } + var length = message.length; + var byteLength = Math.floor((length + 72) / 64) * 64; + var wordLength = byteLength / 4; + var bitLength = length * 8; + var m = new Uint8Array(byteLength); + m.set(message); + m[length] = 0x80; + m[byteLength - 4] = bitLength >>> 24; + m[byteLength - 3] = (bitLength >>> 16) & 0xff; + m[byteLength - 2] = (bitLength >>> 8) & 0xff; + m[byteLength - 1] = bitLength & 0xff; + var words = new Int32Array(wordLength); + var byteIndex = 0; + for (var i = 0; i < words.length; i++) { + var word = m[byteIndex++] << 24; + word |= m[byteIndex++] << 16; + word |= m[byteIndex++] << 8; + word |= m[byteIndex++]; + words[i] = word; + } + var w = new Int32Array(64); + for (var j = 0; j < wordLength; j += 16) { + for (i = 0; i < 16; i++) { + w[i] = words[j + i]; + } + for (i = 16; i < 64; i++) { + var v = w[i - 15]; + var s0 = (v >>> 7) | (v << 25); + s0 ^= (v >>> 18) | (v << 14); + s0 ^= (v >>> 3); + v = w[i - 2]; + var s1 = (v >>> 17) | (v << 15); + s1 ^= (v >>> 19) | (v << 13); + s1 ^= (v >>> 10); + w[i] = (w[i - 16] + s0 + w[i - 7] + s1) & 0xffffffff; + } + var a = h0; + var b = h1; + var c = h2; + var d = h3; + var e = h4; + var f = h5; + var g = h6; + var h = h7; + for (i = 0; i < 64; i++) { + s1 = (e >>> 6) | (e << 26); + s1 ^= (e >>> 11) | (e << 21); + s1 ^= (e >>> 25) | (e << 7); + var ch = (e & f) ^ (~e & g); + var temp1 = (h + s1 + ch + K[i] + w[i]) & 0xffffffff; + s0 = (a >>> 2) | (a << 30); + s0 ^= (a >>> 13) | (a << 19); + s0 ^= (a >>> 22) | (a << 10); + var maj = (a & b) ^ (a & c) ^ (b & c); + var temp2 = (s0 + maj) & 0xffffffff; + h = g + g = f + f = e + e = (d + temp1) & 0xffffffff; + d = c; + c = b; + b = a; + a = (temp1 + temp2) & 0xffffffff; + } + h0 = (h0 + a) & 0xffffffff; + h1 = (h1 + b) & 0xffffffff; + h2 = (h2 + c) & 0xffffffff; + h3 = (h3 + d) & 0xffffffff; + h4 = (h4 + e) & 0xffffffff; + h5 = (h5 + f) & 0xffffffff; + h6 = (h6 + g) & 0xffffffff; + h7 = (h7 + h) & 0xffffffff; + } + var hash = new Uint8Array(32); + for (var i = 0; i < 4; i++) { + hash[i] = (h0 >>> (8 * (3 - i))) & 0xff; + hash[i + 4] = (h1 >>> (8 * (3 - i))) & 0xff; + hash[i + 8] = (h2 >>> (8 * (3 - i))) & 0xff; + hash[i + 12] = (h3 >>> (8 * (3 - i))) & 0xff; + hash[i + 16] = (h4 >>> (8 * (3 - i))) & 0xff; + hash[i + 20] = (h5 >>> (8 * (3 - i))) & 0xff; + hash[i + 24] = (h6 >>> (8 * (3 - i))) & 0xff; + hash[i + 28] = (h7 >>> (8 * (3 - i))) & 0xff; + } + return hash; +} + +// The hash function returns the hash value as a hex string. +// message: the string or byte array to hash +SHA256.hash = function(message) { + var digest = SHA256.digest(message); + var hex = ''; + for (var i = 0; i < digest.length; i++) { + var s = '0' + digest[i].toString(16); + hex += s.length > 2 ? s.substring(1) : s; + } + return hex; +} + + +// == Convert to ES6 Module == // +export default SHA256; \ No newline at end of file diff --git a/qortal-ui-crypto/api/deps/utils.js b/qortal-ui-crypto/api/deps/utils.js new file mode 100644 index 00000000..20715934 --- /dev/null +++ b/qortal-ui-crypto/api/deps/utils.js @@ -0,0 +1,74 @@ +'use strict' +const utils = { + int32ToBytes(word) { + var byteArray = [] + for (var b = 0; b < 32; b += 8) { + byteArray.push((word >>> (24 - b % 32)) & 0xFF) + } + return byteArray + }, + + stringtoUTF8Array(message) { + if (typeof message === 'string') { + var s = unescape(encodeURIComponent(message)) // UTF-8 + message = new Uint8Array(s.length) + for (var i = 0; i < s.length; i++) { + message[i] = s.charCodeAt(i) & 0xff + } + } + return message + }, + // ...buffers then buffers.foreach and append to buffer1 + appendBuffer(buffer1, buffer2) { + buffer1 = new Uint8Array(buffer1) + buffer2 = new Uint8Array(buffer2) + let tmp = new Uint8Array(buffer1.byteLength + buffer2.byteLength) + tmp.set(buffer1, 0) + tmp.set(buffer2, buffer1.byteLength) + return tmp + }, + + int64ToBytes(int64) { + // we want to represent the input as a 8-bytes array + var byteArray = [0, 0, 0, 0, 0, 0, 0, 0] + + for (var index = 0; index < byteArray.length; index++) { + var byte = int64 & 0xff + byteArray[byteArray.length - index - 1] = byte + int64 = (int64 - byte) / 256 + } + + return byteArray + }, + + hexToBytes(hexString) { + return new Uint8Array(hexString.match(/.{1,2}/g).map(byte => parseInt(byte, 16))) + }, + + stringToHex(bytes) { + return bytes.reduce((str, byte) => str + byte.toString(16).padStart(2, '0'), '') + }, + + equal(buf1, buf2) { + if (buf1.byteLength != buf2.byteLength) return false + var dv1 = new Uint8Array(buf1) + var dv2 = new Uint8Array(buf2) + for (var i = 0; i != buf1.byteLength; i++) { + if (dv1[i] != dv2[i]) return false + } + return true + }, + + bytesToHex(byteArray) { + var _byteArrayToHex = [] + + for (var index = 0; index < byteArray.length; index++) { + _byteArrayToHex.push((byteArray[index] >>> 4).toString(16)) + _byteArrayToHex.push((byteArray[index] & 15).toString(16)); + } + + return _byteArrayToHex.join("") + } +} + +export default utils diff --git a/qortal-ui-crypto/api/fetch-request.js b/qortal-ui-crypto/api/fetch-request.js new file mode 100644 index 00000000..f7e5c9b2 --- /dev/null +++ b/qortal-ui-crypto/api/fetch-request.js @@ -0,0 +1,30 @@ +import { watchConfig, waitForConfig } from '../config.js' + +let config = {} +watchConfig((c) => { + config = c +}) + +export async function request(url, options) { + options = options || {} + const body = options.body + const method = options.method || 'GET' + const headers = options.headers || {} + + await waitForConfig() + + const n = config.nodeConfig.knownNodes[config.nodeConfig.node] + const node = n.protocol + '://' + n.domain + ':' + n.port + return fetch(node + url, { + method, + headers, + body, + }).then(async (response) => { + try { + const json = await response.clone().json() + return json + } catch (e) { + return await response.text() + } + }) +} diff --git a/qortal-ui-crypto/api/kdf.js b/qortal-ui-crypto/api/kdf.js new file mode 100644 index 00000000..b94134ac --- /dev/null +++ b/qortal-ui-crypto/api/kdf.js @@ -0,0 +1,39 @@ +import { store } from '../api_deps.js' +import { stateAwait } from './utils/stateAwait.js' +import { Sha512 } from 'asmcrypto.js' +import utils from '../api/deps/utils.js' + +export const kdf = async (seed, salt, status = () => { }) => { + const state = store.getState() + const config = state.config + const workers = state.app.workers.workers + status('Waiting for workers to be ready') + await stateAwait(state => state.app.workers.ready) + status('Deriving key parts') + salt = new Uint8Array(salt) + const seedParts = await Promise.all(workers.map((worker, index) => { + const nonce = index + return worker.request('kdf', { + key: seed, + salt, + nonce, + staticSalt: config.crypto.staticSalt, + staticBcryptSalt: config.crypto.staticBcryptSalt + }).then(data => { + let jsonData + try { + jsonData = JSON.parse(data) + data = jsonData + } catch (e) { + // ... + } + if (seed !== data.key) throw new Error('Error, incorrect key. ' + seed + ' !== ' + data.key) + if (nonce !== data.nonce) throw new Error('Error, incorrect nonce') + return data.result + }) + })) + status('Combining key parts') + const result = new Sha512().process(utils.stringtoUTF8Array(config.crypto.staticSalt + seedParts.reduce((a, c) => a + c))).finish().result + status('Key is ready ') + return result +} diff --git a/qortal-ui-crypto/api/registerUsername.js b/qortal-ui-crypto/api/registerUsername.js new file mode 100644 index 00000000..c270c209 --- /dev/null +++ b/qortal-ui-crypto/api/registerUsername.js @@ -0,0 +1,46 @@ +/** + * Not to be confused with register name...this is a special use case + */ +import { request, createTransaction, processTransaction } from './api.js' + +const TX_TYPE = 3 // NAME_REGISTRATION +const CHECK_LAST_REF_INTERVAL = 30 * 1000 // err 30 seconds + +const pendingAddresses = {} + +// const config = store.getState().config +// const node = config.coin.node.api +// const baseUrl = node.url + node.tail + +const checkLastRefs = () => { + Object.entries(pendingAddresses).forEach(([address, fn]) => { + // console.log(fn, address) + request('addresses/lastreference/' + address).then(res => { + if (res === 'false') return + fn(res) + delete pendingAddresses[address] + clearInterval(lastRefInterval) + }) + // fetch(baseUrl + 'addresses/lastreference/' + address) + // .then(async res => res.text()) + }) +} + +const lastRefInterval = setInterval(() => checkLastRefs(), CHECK_LAST_REF_INTERVAL) + +const callOnLastRef = (address, fn) => { + pendingAddresses[address] = fn +} + +export const registerUsername = async ({ name, address, lastRef, keyPair }) => { + callOnLastRef(address, lastreference => { + const txBytes = createTransaction(TX_TYPE, keyPair, { + registrantPublicKey: keyPair.publicKey, + registrantAddress: address, + name, + value: address, + lastReference: lastreference + }) + processTransaction(txBytes).then(res => {}) + }) +} diff --git a/qortal-ui-crypto/api/storeWallet.js b/qortal-ui-crypto/api/storeWallet.js new file mode 100644 index 00000000..eab5fa99 --- /dev/null +++ b/qortal-ui-crypto/api/storeWallet.js @@ -0,0 +1,33 @@ +import { HmacSha512, AES_CBC } from 'asmcrypto.js' +import { kdf } from './kdf.js' +// import Base58 from '../qora/deps/Base58.js' +import Base58 from './deps/Base58.js' + +const getRandomValues = window.crypto ? window.crypto.getRandomValues.bind(window.crypto) : window.msCrypto.getRandomValues.bind(window.msCrypto) + +export const generateSaveWalletData = async (wallet, password, kdfThreads, statusUpdateFn) => { + statusUpdateFn('Generating random values') + let iv = new Uint8Array(16) + getRandomValues(iv) + let salt = new Uint8Array(32) + getRandomValues(salt) // Can actually use a salt this time, as we can store the salt with the wallet + + // const key = PBKDF2_HMAC_SHA512.bytes(utils.stringtoUTF8Array(password), salt, PBKDF2_ROUNDS, 64) // 512bit key to be split in two for mac/encryption + const key = await kdf(password, salt, statusUpdateFn) + statusUpdateFn('Encrypting seed') + const encryptionKey = key.slice(0, 32) + const macKey = key.slice(32, 63) + const encryptedSeed = AES_CBC.encrypt(wallet._byteSeed, encryptionKey, false, iv) + // const mac = HmacSha512.bytes(encryptedSeed, macKey) + statusUpdateFn('Generating mac') + const mac = new HmacSha512(macKey).process(encryptedSeed).finish().result + return { + address0: wallet._addresses[0].address, + encryptedSeed: Base58.encode(encryptedSeed), + salt: Base58.encode(salt), + iv: Base58.encode(iv), + version: wallet._walletVersion, + mac: Base58.encode(mac), + kdfThreads + } +} diff --git a/qortal-ui-crypto/api/tradeRequest.js b/qortal-ui-crypto/api/tradeRequest.js new file mode 100644 index 00000000..18ec53a4 --- /dev/null +++ b/qortal-ui-crypto/api/tradeRequest.js @@ -0,0 +1,97 @@ +// Trade Bot +import TradeBotCreateRequest from './transactions/trade-portal/tradebot/TradeBotCreateRequest.js'; +import TradeBotRespondRequest from './transactions/trade-portal/tradebot/TradeBotRespondRequest.js'; +import signTradeBotTransaction from './transactions/trade-portal/tradebot/signTradeBotTransaction.js' + +// Trade Offer +import DeleteTradeOffer from './transactions/trade-portal/tradeoffer/DeleteTradeOffer.js'; + +import { request } from './fetch-request' + + +// TradeBotCreateRequest +export const tradeBotCreateRequest = (requestObject) => { + const txn = new TradeBotCreateRequest().createTransaction(requestObject) + + return request('/crosschain/tradebot/create', { + method: 'POST', + headers: { + 'Accept': 'text/plain', + 'Content-Type': 'application/json' + }, + body: JSON.stringify(txn) + }) +} + +// TradeBotRespondRequest +export const tradeBotRespondRequest = (requestObject) => { + const txn = new TradeBotRespondRequest().createTransaction(requestObject) + + return request('/crosschain/tradebot/respond', { + method: 'POST', + headers: { + 'Accept': 'application/json', + 'Content-Type': 'application/json' + }, + body: JSON.stringify(txn) + }) +} + + +// Sign Trade Transactions +export const signTradeBotTxn = (unsignedTxn, keyPair) => { + return signTradeBotTransaction(unsignedTxn, keyPair) +} + +// Delete Trade Offer +export const deleteTradeOffer = (requestObject) => { + const txn = new DeleteTradeOffer().createTransaction(requestObject) + + return request('/crosschain/tradeoffer', { + method: 'DELETE', + headers: { + 'Accept': 'application/json', + 'Content-Type': 'application/json' + }, + body: JSON.stringify(txn) + }) +} + +// Send BTC +export const sendBtc = (requestObject) => { + + return request('/crosschain/btc/send', { + method: 'POST', + headers: { + 'Accept': 'application/json', + 'Content-Type': 'application/json' + }, + body: JSON.stringify(requestObject) + }) +} + +// Send LTC +export const sendLtc = (requestObject) => { + + return request('/crosschain/ltc/send', { + method: 'POST', + headers: { + 'Accept': 'application/json', + 'Content-Type': 'application/json' + }, + body: JSON.stringify(requestObject) + }) +} + +// Send DOGE +export const sendDoge = (requestObject) => { + + return request('/crosschain/doge/send', { + method: 'POST', + headers: { + 'Accept': 'application/json', + 'Content-Type': 'application/json' + }, + body: JSON.stringify(requestObject) + }) +} diff --git a/qortal-ui-crypto/api/transactions/AirdropTransaction.js b/qortal-ui-crypto/api/transactions/AirdropTransaction.js new file mode 100644 index 00000000..552e42e8 --- /dev/null +++ b/qortal-ui-crypto/api/transactions/AirdropTransaction.js @@ -0,0 +1,50 @@ +'use strict'; +import TransactionBase from './TransactionBase.js' +import { QORT_DECIMALS } from '../constants.js' +// import { Sha256 } from 'asmcrypto.js/dist_es5/entry-export_all.js' + +export default class PaymentTransaction extends TransactionBase { + constructor () { + super() + this.type = 20 + this.amount = 42 * Math.pow(10, 8) + this.tests.push( + () => { + if (!(this._amount >= 0)) { + return 'Invalid amount ' + this._amount / QORT_DECIMALS + } + return true + }, + () => { + if (!(this._recipient instanceof Uint8Array && this._recipient.length == 25)) { + return 'Invalid recipient ' + Base58.encode(this._recipient) + } + return true + } + ) + } + + set recipient (recipient) { // Always Base58 encoded. Accepts Uint8Array or Base58 string. + this._recipient = recipient instanceof Uint8Array ? recipient : this.constructor.Base58.decode(recipient) + } + set amount (amount) { + this._amount = amount * QORT_DECIMALS + this._amountBytes = this.constructor.utils.int64ToBytes(amount) + } + + set reference (seed) { + const sha = seed => new Sha512().process(seed).finish().result + let reference = sha(sha(seed)) + reference += reference + } + + get params () { + const params = super.params + params.push( + this._recipient, + this._amountBytes, + this._feeBytes + ) + return params + } +} diff --git a/qortal-ui-crypto/api/transactions/DelegationTransaction.js b/qortal-ui-crypto/api/transactions/DelegationTransaction.js new file mode 100644 index 00000000..bc74502a --- /dev/null +++ b/qortal-ui-crypto/api/transactions/DelegationTransaction.js @@ -0,0 +1,31 @@ +'use strict'; +import TransactionBase from './TransactionBase.js' +// import { QORT_DECIMALS } from "../constants.js" // Not needed, no amount + +export default class DelegationTransaction extends TransactionBase { + constructor () { + super() + this.type = 18 + this.tests.push( + () => { + if (!(this._superNodeAddress instanceof Uint8Array && this._superNodeAddress.length == 25)) { + return 'Invalid recipient ' + Base58.encode(this._superNodeAddress) + } + return true + } + ) + } + + set superNodeAddress (superNodeAddress) { // Always Base58 encoded. Accepts Uint8Array or Base58 string. + this._superNodeAddress = superNodeAddress instanceof Uint8Array ? superNodeAddress : this.constructor.Base58.decode(superNodeAddress) + } + + get params () { + const params = super.params + params.push( + this._superNodeAddress, + this._feeBytes + ) + return params + } +} diff --git a/qortal-ui-crypto/api/transactions/MessageTransaction.js b/qortal-ui-crypto/api/transactions/MessageTransaction.js new file mode 100644 index 00000000..f28a25fe --- /dev/null +++ b/qortal-ui-crypto/api/transactions/MessageTransaction.js @@ -0,0 +1,95 @@ +"use strict"; +import PaymentTransaction from "./PaymentTransaction.js" +import { QORT_DECIMALS } from "../constants.js" + +/* ==================================== +EXTEND THE PAYMENT TRANSACTION YOU CLOWN +====================================== */ + +export default class MessageTransaction extends PaymentTransaction{ + constructor(){ + super(); + this.type = 17 + this._key = this.constructor.utils.int64ToBytes(0); + this._isEncrypted = new Uint8Array(1); // Defaults to false + this._isText = new Uint8Array(1); // Defaults to false + } + + set message(message /* UTF8 String */){ + // ...yes? no? + this.messageText = message; + + // Not sure about encoding here... + //this._message = message instanceof Uint8Array ? message : this.constructor.Base58.decode(message); + this._message = this.constructor.utils.stringtoUTF8Array(message) + this._messageLength = this.constructor.utils.int64ToBytes(this._message.length) + } + set isEncrypted(isEncrypted){ + this._isEncrypted[0] = isEncrypted; + } + set isText(isText){ + this._isText[0] = isText; + } + get _params(){ + // dont extend super because paymentTrasaction is different + //const params = super.params; + return [ + this._typeBytes, + this._timestampBytes, + this._lastReference, + this._keyPair.publicKey, + this._recipient, + this._key, + this._amountBytes, + this._messageLength, + this._message, + this._isEncrypted, + this._isText, + this._feeBytes + ] + } +} + +//"use strict"; +//function generateSignatureMessageTransaction(keyPair, lastReference, recipient, amount, fee, timestamp, message, isText, isEncrypted) => { +// const data = generateMessageTransactionBase(keyPair.publicKey, lastReference, recipient, amount, fee, timestamp, message, isText, isEncrypted); +// return nacl.sign.detached(data, keyPair.privateKey); +//} +// +//function generateMessageTransaction(keyPair, lastReference, recipient, amount, fee, timestamp, message, isText, isEncrypted, signature) => { +// return appendBuffer(generateMessageTransactionBase(keyPair.publicKey, lastReference, recipient, amount, fee, timestamp, message, isText, isEncrypted), +// signature); +//} +//function generateMessageTransactionBase(publicKey, lastReference, recipient, amount, fee, timestamp, message, isText, isEncrypted) => { +// txType = TYPES.MESSAGE_TRANSACTION; +// +// const typeBytes = int32ToBytes(txType); +// const timestampBytes = int64ToBytes(timestamp); +// const amountBytes = int64ToBytes(amount * 100000000); +// const feeBytes = int64ToBytes(fee * 100000000); +// const messageLength = int32ToBytes(message.length); +// const key = int64ToBytes(0); +// +// isTextB = new Uint8Array(1); +// isTextB[0] = isText; +// +// isEncryptedB = new Uint8Array(1); +// isEncryptedB[0] = isEncrypted; +// +// let data = new Uint8Array(); +// +// data = appendBuffer(data, typeBytes); +// data = appendBuffer(data, timestampBytes); +// data = appendBuffer(data, lastReference); +// data = appendBuffer(data, publicKey); +// data = appendBuffer(data, recipient); +// data = appendBuffer(data, key); +// data = appendBuffer(data, amountBytes); +// data = appendBuffer(data, messageLength); +// data = appendBuffer(data, message); +// data = appendBuffer(data, isEncryptedB); +// data = appendBuffer(data, isTextB); +// data = appendBuffer(data, feeBytes); +// +// return data; +//} \ No newline at end of file diff --git a/qortal-ui-crypto/api/transactions/PaymentTransaction.js b/qortal-ui-crypto/api/transactions/PaymentTransaction.js new file mode 100644 index 00000000..dd9afce0 --- /dev/null +++ b/qortal-ui-crypto/api/transactions/PaymentTransaction.js @@ -0,0 +1,96 @@ +'use strict'; +import TransactionBase from './TransactionBase.js' +// import { QORT_DECIMALS } from '../constants.js' +import Base58 from '../deps/Base58.js' +// import { store } from '../../store.js' +import { store } from '../../api.js' + +export default class PaymentTransaction extends TransactionBase { + constructor() { + super() + this.type = 2 + this.tests.push( + () => { + if (!(this._amount >= 0)) { + return 'Invalid amount ' + this._amount / store.getState().config.coin.decimals + } + return true + }, + () => { + if (!(this._recipient instanceof Uint8Array && this._recipient.length == 25)) { + return 'Invalid recipient ' + Base58.encode(this._recipient) + } + return true + } + ) + } + + set recipient(recipient) { // Always Base58 encoded. Accepts Uint8Array or Base58 string. + this._recipient = recipient instanceof Uint8Array ? recipient : this.constructor.Base58.decode(recipient) + } + set amount(amount) { + // console.log('=====DECIMALS ', store.getState().config.coin.decimals) + // console.log("IINIT AMOUNT: ", amount); + this._amount = amount * store.getState().config.coin.decimals + this._amountBytes = this.constructor.utils.int64ToBytes(this._amount) + } + get params() { + const params = super.params + params.push( + this._recipient, + this._amountBytes, + this._feeBytes + ) + return params + } + + render(html) { + const conf = store.getState().config + // console.log(this) + return html` + + + + + + + + + +
To${Base58.encode(this._recipient)}
Amount${this._amount / conf.coin.decimals} ${conf.coin.symbol}
+ ` + } +} +// +// import txTypes from "./txTypes.js" +// import nacl from "./deps/nacl-fast.js" +// import Utils from "./Utils.js" +// +// function generateSignaturePaymentTransaction(keyPair, lastReference, recipient, amount, fee, timestamp) => { +// const data = generatePaymentTransactionBase(keyPair.publicKey, lastReference, recipient, amount, fee, timestamp); +// return nacl.sign.detached(data, keyPair.privateKey); +// } +// +// function generatePaymentTransaction(keyPair, lastReference, recipient, amount, fee, timestamp, signature) => { +// return Utils.appendBuffer(generatePaymentTransactionBase(keyPair.publicKey, lastReference, recipient, amount, fee, timestamp),signature); +// } +// +// function generatePaymentTransactionBase(publicKey, lastReference, recipient, amount, fee, timestamp) => { +// const txType = txTypes.PAYMENT_TRANSACTION; +// const typeBytes = Utils.int32ToBytes(txType); +// const timestampBytes = Utils.int64ToBytes(timestamp); +// const amountBytes = Utils.int64ToBytes(amount * 100000000); +// const feeBytes = Utils.int64ToBytes(fee * 100000000); +// +// let data = new Uint8Array(); +// +// data = Utils.appendBuffer(data, typeBytes); +// data = Utils.appendBuffer(data, timestampBytes); +// data = Utils.appendBuffer(data, lastReference); +// data = Utils.appendBuffer(data, publicKey); +// data = Utils.appendBuffer(data, recipient); +// data = Utils.appendBuffer(data, amountBytes); +// data = Utils.appendBuffer(data, feeBytes); +// +// return data; +// } diff --git a/qortal-ui-crypto/api/transactions/PublicizeTransaction.js b/qortal-ui-crypto/api/transactions/PublicizeTransaction.js new file mode 100644 index 00000000..d4982bcb --- /dev/null +++ b/qortal-ui-crypto/api/transactions/PublicizeTransaction.js @@ -0,0 +1,23 @@ +"use strict"; +import ChatBase from "./chat/ChatBase.js" + +export default class PublicizeTransaction extends ChatBase { + constructor() { + super(); + this.type = 19 + this.fee = 0 + } + + set proofOfWorkNonce(proofOfWorkNonce) { + this._proofOfWorkNonce = this.constructor.utils.int32ToBytes(proofOfWorkNonce) + } + + get params() { + const params = super.params; + params.push( + this._proofOfWorkNonce, + this._feeBytes + ) + return params; + } +} diff --git a/qortal-ui-crypto/api/transactions/TransactionBase.js b/qortal-ui-crypto/api/transactions/TransactionBase.js new file mode 100644 index 00000000..6acc7eaa --- /dev/null +++ b/qortal-ui-crypto/api/transactions/TransactionBase.js @@ -0,0 +1,162 @@ +'use strict'; +import { TX_TYPES, QORT_DECIMALS } from '../constants.js' +import nacl from '../deps/nacl-fast.js' +import Base58 from '../deps/Base58.js' +import utils from '../deps/utils.js' + +export default class TransactionBase { + static get utils() { + return utils + } + static get nacl() { + return nacl + } + static get Base58() { + return Base58 + } + + constructor() { + // Defaults + this.fee = 0 + this.groupID = 0 + this.timestamp = Date.now() + this.tests = [ + () => { + if (!(this._type >= 1 && this._type in TX_TYPES)) { + return 'Invalid type: ' + this.type + } + return true + }, + () => { + if (this._fee < 0) { + return 'Invalid fee: ' + this._fee / QORT_DECIMALS + } + return true + }, + () => { + if (this._groupID < 0 || !Number.isInteger(this._groupID)) { + return 'Invalid groupID: ' + this._groupID + } + return true + }, + () => { + if (!(new Date(this._timestamp)).getTime() > 0) { + return 'Invalid timestamp: ' + this._timestamp + } + return true + }, + () => { + if (!(this._lastReference instanceof Uint8Array && this._lastReference.byteLength == 64)) { + return 'Invalid last reference: ' + this._lastReference + } + return true + }, + () => { + if (!(this._keyPair)) { + return 'keyPair must be specified' + } + if (!(this._keyPair.publicKey instanceof Uint8Array && this._keyPair.publicKey.byteLength === 32)) { + return 'Invalid publicKey' + } + if (!(this._keyPair.privateKey instanceof Uint8Array && this._keyPair.privateKey.byteLength === 64)) { + return 'Invalid privateKey' + } + return true + } + ] + } + + set keyPair(keyPair) { + this._keyPair = keyPair + } + set type(type) { + this.typeText = TX_TYPES[type] + this._type = type + this._typeBytes = this.constructor.utils.int32ToBytes(this._type) + } + set groupID(groupID) { + this._groupID = groupID + this._groupIDBytes = this.constructor.utils.int32ToBytes(this._groupID) + } + set timestamp(timestamp) { + this._timestamp = timestamp + this._timestampBytes = this.constructor.utils.int64ToBytes(this._timestamp) + } + set fee(fee) { + this._fee = fee * QORT_DECIMALS + this._feeBytes = this.constructor.utils.int64ToBytes(this._fee) + } + set lastReference(lastReference) { // Always Base58 encoded. Accepts Uint8Array or Base58 string. + // lastReference could be a string or an Uint8Array + this._lastReference = lastReference instanceof Uint8Array ? lastReference : this.constructor.Base58.decode(lastReference) + } + get params() { + return [ + this._typeBytes, + this._timestampBytes, + this._groupIDBytes, + this._lastReference, + this._keyPair.publicKey + ] + } + get signedBytes() { + if (!this._signedBytes) { + this.sign() + } + return this._signedBytes + } + + // render function but NOT lit element + render(html) { + return html`render method to display requested transaction info` + } + + validParams() { + let finalResult = { + valid: true + } + // const valid = + this.tests.some(test => { + const result = test() + if (result !== true) { + finalResult = { + valid: false, + message: result + } + return true // exists the loop + } + }) + return finalResult + } + + generateBase() { + const isValid = this.validParams() + if (!isValid.valid) { + throw new Error(isValid.message) + } + let result = new Uint8Array() + + this.params.forEach(item => { + result = this.constructor.utils.appendBuffer(result, item) + }) + + this._base = result + return result + } + + sign() { + if (!this._keyPair) { + throw new Error('keyPair not defined') + } + + if (!this._base) { + this.generateBase() + } + + this._signature = this.constructor.nacl.sign.detached(this._base, this._keyPair.privateKey) + + this._signedBytes = this.constructor.utils.appendBuffer(this._base, this._signature) + + return this._signature + } +} diff --git a/qortal-ui-crypto/api/transactions/arbitraryV3.js b/qortal-ui-crypto/api/transactions/arbitraryV3.js new file mode 100644 index 00000000..5d62000a --- /dev/null +++ b/qortal-ui-crypto/api/transactions/arbitraryV3.js @@ -0,0 +1,42 @@ +"use strict"; +/* +TO DO +*/ + + +(function(){ + function generateSignatureArbitraryTransactionV3(keyPair, lastReference, service, arbitraryData, fee, timestamp) => { + const data = generateArbitraryTransactionV3Base(keyPair.publicKey, lastReference, service, arbitraryData, fee, timestamp); + return nacl.sign.detached(data, keyPair.privateKey); + } + + function generateArbitraryTransactionV3(keyPair, lastReference, service, arbitraryData, fee, timestamp, signature) => { + return appendBuffer(generateArbitraryTransactionV3Base(keyPair.publicKey, lastReference, service, arbitraryData, fee, timestamp), + signature); + } + + function generateArbitraryTransactionV3Base(publicKey, lastReference, service, arbitraryData, fee, timestamp) => { + const txType = TYPES.ARBITRARY_TRANSACTION; + const typeBytes = int32ToBytes(txType); + const timestampBytes = int64ToBytes(timestamp); + const feeBytes = int64ToBytes(fee * 100000000); + const serviceBytes = int32ToBytes(service); + const dataSizeBytes = int32ToBytes(arbitraryData.length); + const paymentsLengthBytes = int32ToBytes(0); // Support payments - not yet. + + var data = new Uint8Array(); + + data = appendBuffer(data, typeBytes); + data = appendBuffer(data, timestampBytes); + data = appendBuffer(data, lastReference); + data = appendBuffer(data, publicKey); + data = appendBuffer(data, paymentsLengthBytes); + // Here it is necessary to insert the payments, if there are + data = appendBuffer(data, serviceBytes); + data = appendBuffer(data, dataSizeBytes); + data = appendBuffer(data, arbitraryData); + data = appendBuffer(data, feeBytes); + + return data; + } +}()) \ No newline at end of file diff --git a/qortal-ui-crypto/api/transactions/chat/ChatBase.js b/qortal-ui-crypto/api/transactions/chat/ChatBase.js new file mode 100644 index 00000000..3a81d3f2 --- /dev/null +++ b/qortal-ui-crypto/api/transactions/chat/ChatBase.js @@ -0,0 +1,137 @@ +'use strict'; +import { TX_TYPES, QORT_DECIMALS } from '../../constants.js' +import nacl from '../../deps/nacl-fast.js' +import Base58 from '../../deps/Base58.js' +import utils from '../../deps/utils.js' + +export default class ChatBase { + static get utils() { + return utils + } + static get nacl() { + return nacl + } + static get Base58() { + return Base58 + } + + constructor() { + this.fee = 0 + this.groupID = 0 + this.tests = [ + () => { + if (!(this._type >= 1 && this._type in TX_TYPES)) { + return 'Invalid type: ' + this.type + } + return true + }, + () => { + if (this._fee < 0) { + return 'Invalid fee: ' + this._fee / QORT_DECIMALS + } + return true + }, + () => { + if (this._groupID < 0 || !Number.isInteger(this._groupID)) { + return 'Invalid groupID: ' + this._groupID + } + return true + }, + () => { + if (!(new Date(this._timestamp)).getTime() > 0) { + return 'Invalid timestamp: ' + this._timestamp + } + return true + }, + () => { + if (!(this._lastReference instanceof Uint8Array && this._lastReference.byteLength == 64)) { + return 'Invalid last reference: ' + this._lastReference + } + return true + }, + () => { + if (!(this._keyPair)) { + return 'keyPair must be specified' + } + if (!(this._keyPair.publicKey instanceof Uint8Array && this._keyPair.publicKey.byteLength === 32)) { + return 'Invalid publicKey' + } + if (!(this._keyPair.privateKey instanceof Uint8Array && this._keyPair.privateKey.byteLength === 64)) { + return 'Invalid privateKey' + } + return true + } + ] + } + + set keyPair(keyPair) { + this._keyPair = keyPair + } + set type(type) { + this.typeText = TX_TYPES[type] + this._type = type + this._typeBytes = this.constructor.utils.int32ToBytes(this._type) + } + set groupID(groupID) { + this._groupID = groupID + this._groupIDBytes = this.constructor.utils.int32ToBytes(this._groupID) + } + set timestamp(timestamp) { + this._timestamp = timestamp + this._timestampBytes = this.constructor.utils.int64ToBytes(this._timestamp) + } + set fee(fee) { + this._fee = fee * QORT_DECIMALS + this._feeBytes = this.constructor.utils.int64ToBytes(this._fee) + } + set lastReference(lastReference) { + this._lastReference = lastReference instanceof Uint8Array ? lastReference : this.constructor.Base58.decode(lastReference) + } + get params() { + + return [ + this._typeBytes, + this._timestampBytes, + this._groupIDBytes, + this._lastReference, + this._keyPair.publicKey + ] + } + + get chatBytes() { + + const isValid = this.validParams() + if (!isValid.valid) { + throw new Error(isValid.message) + } + + let result = new Uint8Array() + + this.params.forEach(item => { + result = this.constructor.utils.appendBuffer(result, item) + }) + + this._chatBytes = result + + return this._chatBytes + } + + validParams() { + let finalResult = { + valid: true + } + + this.tests.some(test => { + const result = test() + if (result !== true) { + finalResult = { + valid: false, + message: result + } + return true + } + }) + return finalResult + } + +} diff --git a/qortal-ui-crypto/api/transactions/chat/ChatTransaction.js b/qortal-ui-crypto/api/transactions/chat/ChatTransaction.js new file mode 100644 index 00000000..6e6dcfd4 --- /dev/null +++ b/qortal-ui-crypto/api/transactions/chat/ChatTransaction.js @@ -0,0 +1,77 @@ +"use strict"; +import ChatBase from "./ChatBase.js" +import nacl from '../../deps/nacl-fast.js' +import ed2curve from '../../deps/ed2curve.js' +import { Sha256 } from 'asmcrypto.js' + + +export default class ChatTransaction extends ChatBase { + constructor() { + super(); + this.type = 18 + this.fee = 0 + } + + set recipientPublicKey(recipientPublicKey) { + this._base58RecipientPublicKey = recipientPublicKey instanceof Uint8Array ? this.constructor.Base58.encode(recipientPublicKey) : recipientPublicKey + this._recipientPublicKey = this.constructor.Base58.decode(this._base58RecipientPublicKey) + + } + + set proofOfWorkNonce(proofOfWorkNonce) { + this._proofOfWorkNonce = this.constructor.utils.int32ToBytes(proofOfWorkNonce) + } + + + set recipient(recipient) { + this._recipient = recipient instanceof Uint8Array ? recipient : this.constructor.Base58.decode(recipient) + this._hasReceipient = new Uint8Array(1) + this._hasReceipient[0] = 1 + } + + set message(message) { + + this.messageText = message; + + this._message = this.constructor.utils.stringtoUTF8Array(message) + this._messageLength = this.constructor.utils.int32ToBytes(this._message.length) + } + + set isEncrypted(isEncrypted) { + this._isEncrypted = new Uint8Array(1); + this._isEncrypted[0] = isEncrypted; + + if (isEncrypted === 1) { + const convertedPrivateKey = ed2curve.convertSecretKey(this._keyPair.privateKey) + const convertedPublicKey = ed2curve.convertPublicKey(this._recipientPublicKey) + const sharedSecret = new Uint8Array(32); + nacl.lowlevel.crypto_scalarmult(sharedSecret, convertedPrivateKey, convertedPublicKey); + + this._chatEncryptionSeed = new Sha256().process(sharedSecret).finish().result + this._encryptedMessage = nacl.secretbox(this._message, this._lastReference.slice(0, 24), this._chatEncryptionSeed) + } + + this._myMessage = isEncrypted === 1 ? this._encryptedMessage : this._message + this._myMessageLenth = isEncrypted === 1 ? this.constructor.utils.int32ToBytes(this._myMessage.length) : this._messageLength + } + + set isText(isText) { + this._isText = new Uint8Array(1); + this._isText[0] = isText; + } + + get params() { + const params = super.params; + params.push( + this._proofOfWorkNonce, + this._hasReceipient, + this._recipient, + this._myMessageLenth, + this._myMessage, + this._isEncrypted, + this._isText, + this._feeBytes + ) + return params; + } +} diff --git a/qortal-ui-crypto/api/transactions/chat/GroupChatTransaction.js b/qortal-ui-crypto/api/transactions/chat/GroupChatTransaction.js new file mode 100644 index 00000000..efbd97b0 --- /dev/null +++ b/qortal-ui-crypto/api/transactions/chat/GroupChatTransaction.js @@ -0,0 +1,52 @@ +"use strict"; +import ChatBase from "./ChatBase.js" + +export default class GroupChatTransaction extends ChatBase { + constructor() { + super(); + this.type = 18 + this.fee = 0 + } + + set proofOfWorkNonce(proofOfWorkNonce) { + this._proofOfWorkNonce = this.constructor.utils.int32ToBytes(proofOfWorkNonce) + } + + + set hasReceipient(hasReceipient) { + this._hasReceipient = new Uint8Array(1) + this._hasReceipient[0] = hasReceipient + } + + set message(message) { + + this.messageText = message; + + this._message = this.constructor.utils.stringtoUTF8Array(message) + this._messageLength = this.constructor.utils.int32ToBytes(this._message.length) + } + + set isEncrypted(isEncrypted) { + this._isEncrypted = new Uint8Array(1); + this._isEncrypted[0] = isEncrypted; // Set to false... + } + + set isText(isText) { + this._isText = new Uint8Array(1); + this._isText[0] = isText; // Set to true + } + + get params() { + const params = super.params; + params.push( + this._proofOfWorkNonce, + this._hasReceipient, + this._messageLength, + this._message, + this._isEncrypted, + this._isText, + this._feeBytes + ) + return params; + } +} diff --git a/qortal-ui-crypto/api/transactions/chat/decryptChatMessage.js b/qortal-ui-crypto/api/transactions/chat/decryptChatMessage.js new file mode 100644 index 00000000..5ea06ec8 --- /dev/null +++ b/qortal-ui-crypto/api/transactions/chat/decryptChatMessage.js @@ -0,0 +1,27 @@ +import nacl from '../../deps/nacl-fast.js' +import Base58 from '../../deps/Base58.js' +import ed2curve from '../../deps/ed2curve.js' +import { Sha256 } from 'asmcrypto.js' + + +export const decryptChatMessage = (encryptedMessage, privateKey, recipientPublicKey, lastReference) => { + let _encryptedMessage = Base58.decode(encryptedMessage) + + const _base58RecipientPublicKey = recipientPublicKey instanceof Uint8Array ? Base58.encode(recipientPublicKey) : recipientPublicKey + const _recipientPublicKey = Base58.decode(_base58RecipientPublicKey) + + const _lastReference = lastReference instanceof Uint8Array ? lastReference : Base58.decode(lastReference) + + const convertedPrivateKey = ed2curve.convertSecretKey(privateKey) + const convertedPublicKey = ed2curve.convertPublicKey(_recipientPublicKey) + const sharedSecret = new Uint8Array(32); + nacl.lowlevel.crypto_scalarmult(sharedSecret, convertedPrivateKey, convertedPublicKey); + + const _chatEncryptionSeed = new Sha256().process(sharedSecret).finish().result + const _decryptedMessage = nacl.secretbox.open(_encryptedMessage, _lastReference.slice(0, 24), _chatEncryptionSeed) + + let decryptedMessage = '' + + _decryptedMessage === false ? decryptedMessage : decryptedMessage = new TextDecoder('utf-8').decode(_decryptedMessage); + return decryptedMessage +} diff --git a/qortal-ui-crypto/api/transactions/chat/signChat.js b/qortal-ui-crypto/api/transactions/chat/signChat.js new file mode 100644 index 00000000..2c8428da --- /dev/null +++ b/qortal-ui-crypto/api/transactions/chat/signChat.js @@ -0,0 +1,46 @@ +import nacl from '../../deps/nacl-fast.js' +import utils from '../../deps/utils.js' + + +const signChat = (chatBytes, nonce, keyPair) => { + + if (!chatBytes) { + throw new Error('Chat Bytes not defined') + } + + if (!nonce) { + throw new Error('Nonce not defined') + } + + if (!keyPair) { + throw new Error('keyPair not defined') + } + + const _nonce = utils.int32ToBytes(nonce) + + if (chatBytes.length === undefined) { + const _chatBytesBuffer = Object.keys(chatBytes).map(function (key) { return chatBytes[key]; }); + + const chatBytesBuffer = new Uint8Array(_chatBytesBuffer) + chatBytesBuffer.set(_nonce, 112) + + + const signature = nacl.sign.detached(chatBytesBuffer, keyPair.privateKey) + + const signedBytes = utils.appendBuffer(chatBytesBuffer, signature) + + return signedBytes + } else { + const chatBytesBuffer = new Uint8Array(chatBytes) + chatBytesBuffer.set(_nonce, 112) + + + const signature = nacl.sign.detached(chatBytesBuffer, keyPair.privateKey) + + const signedBytes = utils.appendBuffer(chatBytesBuffer, signature) + + return signedBytes + } +} + +export default signChat diff --git a/qortal-ui-crypto/api/transactions/groups/AddGroupAdminTransaction.js b/qortal-ui-crypto/api/transactions/groups/AddGroupAdminTransaction.js new file mode 100644 index 00000000..e69de29b diff --git a/qortal-ui-crypto/api/transactions/groups/CancelGroupBanTransaction.js b/qortal-ui-crypto/api/transactions/groups/CancelGroupBanTransaction.js new file mode 100644 index 00000000..e69de29b diff --git a/qortal-ui-crypto/api/transactions/groups/CancelGroupInviteTransaction.js b/qortal-ui-crypto/api/transactions/groups/CancelGroupInviteTransaction.js new file mode 100644 index 00000000..e69de29b diff --git a/qortal-ui-crypto/api/transactions/groups/CreateGroupTransaction.js b/qortal-ui-crypto/api/transactions/groups/CreateGroupTransaction.js new file mode 100644 index 00000000..4c9069d8 --- /dev/null +++ b/qortal-ui-crypto/api/transactions/groups/CreateGroupTransaction.js @@ -0,0 +1,90 @@ +"use strict"; +import TransactionBase from "../TransactionBase.js" + +export default class CreateGroupTransaction extends TransactionBase { + constructor() { + super() + this.type = 22 + this.fee = 0.001 + // this.tests.push( + // () => { + // if (!(this._registrantAddress instanceof Uint8Array && this._registrantAddress.length == 25)) { + // return "Invalid Registrant " + Base58.encode(this._registrantAddress) + // } + // return true + // } + // ) + } + + render(html) { + return html` + You are requesting to creating the group below: +
+
Group Name: ${this._rGroupName}
+
+
Group Description: ${this._rGroupDesc}
+
+
Group Type: ${this.myGroupType === 1 ? "Public" : "Private"}
+
+ On pressing confirm, the group request will be sent! + ` + } + + // set registrantAddress(registrantAddress) { + // this._registrantAddress = registrantAddress instanceof Uint8Array ? registrantAddress : this.constructor.Base58.decode(registrantAddress); + // } + + set rGroupName(rGroupName) { + this._rGroupName = rGroupName; + + this._rGroupNameBytes = this.constructor.utils.stringtoUTF8Array(this._rGroupName.toLocaleLowerCase()) + this._rGroupNameLength = this.constructor.utils.int32ToBytes(this._rGroupNameBytes.length) + } + + set rGroupDesc(rGroupDesc) { + this._rGroupDesc = rGroupDesc; + + this._rGroupDescBytes = this.constructor.utils.stringtoUTF8Array(this._rGroupDesc.toLocaleLowerCase()) + this._rGroupDescLength = this.constructor.utils.int32ToBytes(this._rGroupDescBytes.length) + } + + set rGroupType(rGroupType) { + this.myGroupType = rGroupType; + this._rGroupType = new Uint8Array(1) + this._rGroupType[0] = rGroupType; + } + + set rGroupApprovalThreshold(rGroupApprovalThreshold) { + this._rGroupApprovalThreshold = new Uint8Array(1) + this._rGroupApprovalThreshold[0] = rGroupApprovalThreshold; + } + + set rGroupMinimumBlockDelay(rGroupMinimumBlockDelay) { + this._rGroupMinimumBlockDelay = rGroupMinimumBlockDelay; + + this._rGroupMinimumBlockDelayBytes = this.constructor.utils.int32ToBytes(this._rGroupMinimumBlockDelay) + } + + set rGroupMaximumBlockDelay(rGroupMaximumBlockDelay) { + this._rGroupMaximumBlockDelay = rGroupMaximumBlockDelay; + + this._rGroupMaximumBlockDelayBytes = this.constructor.utils.int32ToBytes(this._rGroupMaximumBlockDelay) + } + + get params() { + const params = super.params; + params.push( + // this._registrantAddress, + this._rGroupNameLength, + this._rGroupNameBytes, + this._rGroupDescLength, + this._rGroupDescBytes, + this._rGroupType, + this._rGroupApprovalThreshold, + this._rGroupMinimumBlockDelayBytes, + this._rGroupMaximumBlockDelayBytes, + this._feeBytes + ) + return params; + } +} \ No newline at end of file diff --git a/qortal-ui-crypto/api/transactions/groups/GroupApprovalTransaction.js b/qortal-ui-crypto/api/transactions/groups/GroupApprovalTransaction.js new file mode 100644 index 00000000..e69de29b diff --git a/qortal-ui-crypto/api/transactions/groups/GroupBanTransaction.js b/qortal-ui-crypto/api/transactions/groups/GroupBanTransaction.js new file mode 100644 index 00000000..e69de29b diff --git a/qortal-ui-crypto/api/transactions/groups/GroupInviteTransaction.js b/qortal-ui-crypto/api/transactions/groups/GroupInviteTransaction.js new file mode 100644 index 00000000..e69de29b diff --git a/qortal-ui-crypto/api/transactions/groups/GroupKickTransaction.js b/qortal-ui-crypto/api/transactions/groups/GroupKickTransaction.js new file mode 100644 index 00000000..e69de29b diff --git a/qortal-ui-crypto/api/transactions/groups/JoinGroupTransaction.js b/qortal-ui-crypto/api/transactions/groups/JoinGroupTransaction.js new file mode 100644 index 00000000..b3498516 --- /dev/null +++ b/qortal-ui-crypto/api/transactions/groups/JoinGroupTransaction.js @@ -0,0 +1,51 @@ +"use strict"; +import TransactionBase from "../TransactionBase.js" + +export default class JoinGroupTransaction extends TransactionBase { + constructor() { + super() + this.type = 31 + this.fee = 0.001 // THOUGHTS: Fee should be easily set and dynamic in future... (0.001) + this.tests.push( + () => { + if (!(this._registrantAddress instanceof Uint8Array && this._registrantAddress.length == 25)) { + return "Invalid Registrant " + Base58.encode(this._registrantAddress) + } + return true + } + ) + } + + render(html) { + return html` + You are requesting to join the group below: +
+ ${this._rGroupName} +
+ On pressing confirm, the group request will be sent! + ` + } + + set registrantAddress(registrantAddress) {// Always Base58 encoded. Accepts Uint8Array or Base58 string. + this._registrantAddress = registrantAddress instanceof Uint8Array ? registrantAddress : this.constructor.Base58.decode(registrantAddress); + } + + set rGroupId(rGroupId) { + this._rGroupId = rGroupId; + + this._rGroupIdBytes = this.constructor.utils.int32ToBytes(this._rGroupId) + } + + set rGroupName(rGroupName) { + this._rGroupName = rGroupName; + } + + get params() { + const params = super.params; + params.push( + this._rGroupIdBytes, + this._feeBytes + ) + return params; + } +} \ No newline at end of file diff --git a/qortal-ui-crypto/api/transactions/groups/LeaveGroupTransaction.js b/qortal-ui-crypto/api/transactions/groups/LeaveGroupTransaction.js new file mode 100644 index 00000000..0c6287d4 --- /dev/null +++ b/qortal-ui-crypto/api/transactions/groups/LeaveGroupTransaction.js @@ -0,0 +1,51 @@ +"use strict"; +import TransactionBase from "../TransactionBase.js" + +export default class LeaveGroupTransaction extends TransactionBase { + constructor() { + super() + this.type = 32 + this.fee = 0.001 // THOUGHTS: Fee should be easily set and dynamic in future... (0.001) + this.tests.push( + () => { + if (!(this._registrantAddress instanceof Uint8Array && this._registrantAddress.length == 25)) { + return "Invalid Registrant " + Base58.encode(this._registrantAddress) + } + return true + } + ) + } + + render(html) { + return html` + You are requesting to leave the group below: +
+ ${this._rGroupName} +
+ On pressing confirm, the group request will be sent! + ` + } + + set registrantAddress(registrantAddress) {// Always Base58 encoded. Accepts Uint8Array or Base58 string. + this._registrantAddress = registrantAddress instanceof Uint8Array ? registrantAddress : this.constructor.Base58.decode(registrantAddress); + } + + set rGroupId(rGroupId) { + this._rGroupId = rGroupId; + + this._rGroupIdBytes = this.constructor.utils.int32ToBytes(this._rGroupId) + } + + set rGroupName(rGroupName) { + this._rGroupName = rGroupName; + } + + get params() { + const params = super.params; + params.push( + this._rGroupIdBytes, + this._feeBytes + ) + return params; + } +} diff --git a/qortal-ui-crypto/api/transactions/groups/RemoveGroupAdminTransaction.js b/qortal-ui-crypto/api/transactions/groups/RemoveGroupAdminTransaction.js new file mode 100644 index 00000000..e69de29b diff --git a/qortal-ui-crypto/api/transactions/groups/SetGroupTransaction.js b/qortal-ui-crypto/api/transactions/groups/SetGroupTransaction.js new file mode 100644 index 00000000..e69de29b diff --git a/qortal-ui-crypto/api/transactions/groups/UpdateGroupTransaction.js b/qortal-ui-crypto/api/transactions/groups/UpdateGroupTransaction.js new file mode 100644 index 00000000..e69de29b diff --git a/qortal-ui-crypto/api/transactions/names/RegisterNameTransaction.js b/qortal-ui-crypto/api/transactions/names/RegisterNameTransaction.js new file mode 100644 index 00000000..f9c6efac --- /dev/null +++ b/qortal-ui-crypto/api/transactions/names/RegisterNameTransaction.js @@ -0,0 +1,55 @@ +"use strict"; +import TransactionBase from "../TransactionBase.js" +import { QORT_DECIMALS } from "../../constants.js" + +export default class RegisterNameTransaction extends TransactionBase { + constructor() { + super() + this.type = 3 + this.fee = 0.001 + // this.tests.push( + // () => { + // if (!(this._registrantAddress instanceof Uint8Array && this._registrantAddress.length == 25)) { + // return "Invalid registrant " + Base58.encode(this._registrantAddress) + // } + // return true + // } + // ) + } + + render(html) { + return html` + You are registering the name below: +
+ ${this.nameText} +
+ On pressing confirm, the name will be registered! + ` + } + + set name(name) { + this.nameText = name; + + this._nameBytes = this.constructor.utils.stringtoUTF8Array(name) + this._nameLength = this.constructor.utils.int32ToBytes(this._nameBytes.length) + } + + set value(value) { + this.valueText = value.length === 0 ? "Registered Name on the Qortal Chain" : value; + + this._valueBytes = this.constructor.utils.stringtoUTF8Array(this.valueText) + this._valueLength = this.constructor.utils.int32ToBytes(this._valueBytes.length) + } + + get params() { + const params = super.params; + params.push( + this._nameLength, + this._nameBytes, + this._valueLength, + this._valueBytes, + this._feeBytes + ) + return params; + } +} diff --git a/qortal-ui-crypto/api/transactions/processTransaction.js b/qortal-ui-crypto/api/transactions/processTransaction.js new file mode 100644 index 00000000..e69de29b diff --git a/qortal-ui-crypto/api/transactions/registerName_dnsthing.js b/qortal-ui-crypto/api/transactions/registerName_dnsthing.js new file mode 100644 index 00000000..08e7713c --- /dev/null +++ b/qortal-ui-crypto/api/transactions/registerName_dnsthing.js @@ -0,0 +1,39 @@ +"use strict"; +/* + TO DO +*/ +(function(){ + function generateSignatureRegisterNameTransaction(keyPair, lastReference, owner, name, value, fee, timestamp) => { + const data = generateRegisterNameTransactionBase(keyPair.publicKey, lastReference, owner, name, value, fee, timestamp); + return nacl.sign.detached(data, keyPair.privateKey); + } + + function generateRegisterNameTransaction(keyPair, lastReference, owner, name, value, fee, timestamp, signature) => { + return appendBuffer( generateRegisterNameTransactionBase(keyPair.publicKey, lastReference, owner, name, value, fee, timestamp), + signature ); + } + + function generateRegisterNameTransactionBase(publicKey, lastReference, owner, name, value, fee, timestamp) => { + const txType = TYPES.REGISTER_NAME_TRANSACTION; + const typeBytes = int32ToBytes(txType); + const timestampBytes = int64ToBytes(timestamp); + const feeBytes = int64ToBytes(fee * 100000000); + const nameSizeBytes = int32ToBytes(name.length); + const valueSizeBytes = int32ToBytes(value.length); + + let data = new Uint8Array(); + + data = appendBuffer(data, typeBytes); + data = appendBuffer(data, timestampBytes); + data = appendBuffer(data, lastReference); + data = appendBuffer(data, publicKey); + data = appendBuffer(data, owner); + data = appendBuffer(data, nameSizeBytes); + data = appendBuffer(data, name); + data = appendBuffer(data, valueSizeBytes); + data = appendBuffer(data, value); + data = appendBuffer(data, feeBytes); + + return data; + } +}()) \ No newline at end of file diff --git a/qortal-ui-crypto/api/transactions/reward-share/RemoveRewardShareTransaction.js b/qortal-ui-crypto/api/transactions/reward-share/RemoveRewardShareTransaction.js new file mode 100644 index 00000000..f83a085a --- /dev/null +++ b/qortal-ui-crypto/api/transactions/reward-share/RemoveRewardShareTransaction.js @@ -0,0 +1,54 @@ + +"use strict"; + +import TransactionBase from "../TransactionBase.js" + +import publicKeyToAddress from '../../wallet/publicKeyToAddress.js' +import { Base58 } from "../../deps/deps.js"; + + +export default class RemoveRewardShareTransaction extends TransactionBase { + constructor() { + super() + this.type = 38 + } + + render(html) { + return html` + You are removing a reward share transaction associated with account: +
+ ${this.constructor.Base58.encode(this._recipient)} +
+ On pressing confirm, the rewardshare will be removed and the minting key will become invalid. + ` + } + + set rewardShareKeyPairPublicKey(rewardShareKeyPairPublicKey) { + + this._rewardShareKeyPairPublicKey = Base58.decode(rewardShareKeyPairPublicKey) + } + + set recipient(recipient) { + + const _address = publicKeyToAddress(this._keyPair.publicKey) + this._recipient = recipient instanceof Uint8Array ? recipient : this.constructor.Base58.decode(recipient) + this.fee = _address === recipient ? 0 : 0.001 + } + + + set percentageShare(share) { + this._percentageShare = share * 100 + this._percentageShareBytes = this.constructor.utils.int64ToBytes(this._percentageShare) + } + + get params() { + const params = super.params + params.push( + this._recipient, + this._rewardShareKeyPairPublicKey, + this._percentageShareBytes, + this._feeBytes + ) + return params; + } +} diff --git a/qortal-ui-crypto/api/transactions/reward-share/RewardShareTransaction.js b/qortal-ui-crypto/api/transactions/reward-share/RewardShareTransaction.js new file mode 100644 index 00000000..4af1f0a2 --- /dev/null +++ b/qortal-ui-crypto/api/transactions/reward-share/RewardShareTransaction.js @@ -0,0 +1,64 @@ +import publicKeyToAddress from '../../wallet/publicKeyToAddress.js' + +"use strict"; +import TransactionBase from "../TransactionBase.js" +import nacl from '../../deps/nacl-fast.js' +import ed2curve from '../../deps/ed2curve.js' +import { Sha256 } from 'asmcrypto.js' + +export default class RewardShareTransaction extends TransactionBase { + constructor() { + super() + this.type = 38 + } + + render(html) { + return html` + Would you like to create a reward share transaction, sharing ${this._percentageShare / 1e8}% of your minting rewards with ${this.constructor.Base58.encode(this._recipient)}? + If yes, you will need to save the key below in order to mint. It can be supplied to any node in order to allow it to mint on your behalf. +
+ ${this._base58RewardShareSeed} +
+ On pressing confirm, the rewardshare will be created, but you will still need to supply the above key to a node in order to mint with the account. + ` + } + + set recipientPublicKey(recipientPublicKey) { + this._base58RecipientPublicKey = recipientPublicKey instanceof Uint8Array ? this.constructor.Base58.encode(recipientPublicKey) : recipientPublicKey + this._recipientPublicKey = this.constructor.Base58.decode(this._base58RecipientPublicKey) + + this.recipient = publicKeyToAddress(this._recipientPublicKey) + + this.fee = (recipientPublicKey === this.constructor.Base58.encode(this._keyPair.publicKey) ? 0 : 0.001) + + // Reward share keys + const convertedPrivateKey = ed2curve.convertSecretKey(this._keyPair.privateKey) + const convertedPublicKey = ed2curve.convertPublicKey(this._recipientPublicKey) + const sharedSecret = new Uint8Array(32); + nacl.lowlevel.crypto_scalarmult(sharedSecret, convertedPrivateKey, convertedPublicKey); + this._rewardShareSeed = new Sha256().process(sharedSecret).finish().result + this._base58RewardShareSeed = this.constructor.Base58.encode(this._rewardShareSeed) + + this._rewardShareKeyPair = nacl.sign.keyPair.fromSeed(this._rewardShareSeed) + } + + set recipient(recipient) { // Always Base58 encoded. Accepts Uint8Array or Base58 string. + this._recipient = recipient instanceof Uint8Array ? recipient : this.constructor.Base58.decode(recipient) + } + + set percentageShare(share) { + this._percentageShare = share * 100 + this._percentageShareBytes = this.constructor.utils.int64ToBytes(this._percentageShare) + } + + get params() { + const params = super.params + params.push( + this._recipient, + this._rewardShareKeyPair.publicKey, + this._percentageShareBytes, + this._feeBytes + ) + return params; + } +} diff --git a/qortal-ui-crypto/api/transactions/trade-portal/tradebot/TradeBotCreateRequest.js b/qortal-ui-crypto/api/transactions/trade-portal/tradebot/TradeBotCreateRequest.js new file mode 100644 index 00000000..85d5867c --- /dev/null +++ b/qortal-ui-crypto/api/transactions/trade-portal/tradebot/TradeBotCreateRequest.js @@ -0,0 +1,79 @@ +/** + * CrossChain - TradeBot Create Request (Sell Action) + * + * These are special types of transactions (JSON ENCODED) + */ + +export default class TradeBotCreateRequest { + constructor() { + // ... + } + + createTransaction(txnReq) { + + this.creatorPublicKey(txnReq.creatorPublicKey); + + this.qortAmount(txnReq.qortAmount); + + this.fundingQortAmount(txnReq.fundingQortAmount); + + this.foreignBlockchain(txnReq.foreignBlockchain); + + this.foreignAmount(txnReq.foreignAmount); + + this.tradeTimeout(txnReq.tradeTimeout); + + this.receivingAddress(txnReq.receivingAddress); + + return this.txnRequest(); + } + + creatorPublicKey(creatorPublicKey) { + + this._creatorPublicKey = creatorPublicKey; + + } + + qortAmount(qortAmount) { + this._qortAmount = qortAmount; + } + + + fundingQortAmount(fundingQortAmount) { + + this._fundingQortAmount = fundingQortAmount; + } + + foreignBlockchain(foreignBlockchain) { + + this._foreignBlockchain = foreignBlockchain; + } + + foreignAmount(foreignAmount) { + + this._foreignAmount = foreignAmount; + } + + tradeTimeout(tradeTimeout) { + + this._tradeTimeout = tradeTimeout; + } + + receivingAddress(receivingAddress) { + + this._receivingAddress = receivingAddress; + } + + txnRequest() { + + return { + creatorPublicKey: this._creatorPublicKey, + qortAmount: this._qortAmount, + fundingQortAmount: this._fundingQortAmount, + foreignBlockchain: this._foreignBlockchain, + foreignAmount: this._foreignAmount, + tradeTimeout: this._tradeTimeout, + receivingAddress: this._receivingAddress + } + } +} diff --git a/qortal-ui-crypto/api/transactions/trade-portal/tradebot/TradeBotRespondRequest.js b/qortal-ui-crypto/api/transactions/trade-portal/tradebot/TradeBotRespondRequest.js new file mode 100644 index 00000000..773ea336 --- /dev/null +++ b/qortal-ui-crypto/api/transactions/trade-portal/tradebot/TradeBotRespondRequest.js @@ -0,0 +1,45 @@ +/** + * CrossChain - TradeBot Respond Request (Buy Action) + * + * These are special types of transactions (JSON ENCODED) + */ + +export default class TradeBotRespondRequest { + constructor() { + // ... + } + + createTransaction(txnReq) { + + this.atAddress(txnReq.atAddress) + + this.foreignKey(txnReq.foreignKey) + + this.receivingAddress(txnReq.receivingAddress) + + return this.txnRequest() + } + + atAddress(atAddress) { + + this._atAddress = atAddress + } + + foreignKey(foreignKey) { + this._foreignKey = foreignKey + } + + receivingAddress(receivingAddress) { + + this._receivingAddress = receivingAddress + } + + txnRequest() { + + return { + atAddress: this._atAddress, + foreignKey: this._foreignKey, + receivingAddress: this._receivingAddress + } + } +} diff --git a/qortal-ui-crypto/api/transactions/trade-portal/tradebot/signTradeBotTransaction.js b/qortal-ui-crypto/api/transactions/trade-portal/tradebot/signTradeBotTransaction.js new file mode 100644 index 00000000..3671183a --- /dev/null +++ b/qortal-ui-crypto/api/transactions/trade-portal/tradebot/signTradeBotTransaction.js @@ -0,0 +1,38 @@ +import Base58 from '../../../deps/Base58.js' +import nacl from '../../../deps/nacl-fast.js' +import utils from '../../../deps/utils.js' + + +const signTradeBotTransaction = (unsignedTxn, keyPair) => { + + if (!unsignedTxn) { + throw new Error('Unsigned Transaction Bytes not defined') + } + + if (!keyPair) { + throw new Error('keyPair not defined') + } + + const txnBuffer = Base58.decode(unsignedTxn) + + if (keyPair.privateKey.length === undefined) { + + const _privateKey = Object.keys(keyPair.privateKey).map(function (key) { return keyPair.privateKey[key]; }); + const privateKey = new Uint8Array(_privateKey) + + const signature = nacl.sign.detached(txnBuffer, privateKey) + + const signedBytes = utils.appendBuffer(txnBuffer, signature) + + return signedBytes + } else { + + const signature = nacl.sign.detached(txnBuffer, keyPair.privateKey) + + const signedBytes = utils.appendBuffer(txnBuffer, signature) + + return signedBytes + } +} + +export default signTradeBotTransaction diff --git a/qortal-ui-crypto/api/transactions/trade-portal/tradeoffer/DeleteTradeOffer.js b/qortal-ui-crypto/api/transactions/trade-portal/tradeoffer/DeleteTradeOffer.js new file mode 100644 index 00000000..c7b3f0e1 --- /dev/null +++ b/qortal-ui-crypto/api/transactions/trade-portal/tradeoffer/DeleteTradeOffer.js @@ -0,0 +1,39 @@ +/** + * CrossChain - DELETE TradeOffer + * + * These are special types of transactions (JSON ENCODED) + */ + +export default class DeleteTradeOffer { + constructor() { + // ... + } + + createTransaction(txnReq) { + + this.creatorPublicKey(txnReq.creatorPublicKey) + + this.atAddress(txnReq.atAddress) + + return this.txnRequest() + } + + creatorPublicKey(creatorPublicKey) { + + this._creatorPublicKey = creatorPublicKey + + } + + atAddress(atAddress) { + + this._atAddress = atAddress + } + + txnRequest() { + + return { + creatorPublicKey: this._creatorPublicKey, + atAddress: this._atAddress + } + } +} diff --git a/qortal-ui-crypto/api/transactions/trade-portal/tradeoffer/cancelAllOffers.js b/qortal-ui-crypto/api/transactions/trade-portal/tradeoffer/cancelAllOffers.js new file mode 100644 index 00000000..425c2684 --- /dev/null +++ b/qortal-ui-crypto/api/transactions/trade-portal/tradeoffer/cancelAllOffers.js @@ -0,0 +1,24 @@ +import { request } from '../../../fetch-request.js' +import { deleteTradeOffer, signTradeBotTxn } from '../../../tradeRequest.js'; +import { processTransaction } from '../../../createTransaction.js' + +export const cancelAllOffers = async (requestObject) => { + const keyPair = requestObject.keyPair; + const publicKey = requestObject.base58PublicKey; + const address = requestObject.address; + + const getMyOpenOffers = async () => { + const res = await request('/crosschain/tradeoffers'); + const myOpenTradeOrders = await res.filter(order => order.mode === "OFFERING" && order.qortalCreator === address); + return myOpenTradeOrders; + } + + const myOpenOffers = await getMyOpenOffers(); + let response = true; + myOpenOffers.forEach( async (openOffer) => { + let unsignedTxn = await deleteTradeOffer({ creatorPublicKey: publicKey, atAddress: openOffer.qortalAtAddress }); + let signedTxnBytes = await signTradeBotTxn(unsignedTxn, keyPair); + await processTransaction(signedTxnBytes); + }); + return response +} diff --git a/qortal-ui-crypto/api/transactions/transactions.js b/qortal-ui-crypto/api/transactions/transactions.js new file mode 100644 index 00000000..c15cbd25 --- /dev/null +++ b/qortal-ui-crypto/api/transactions/transactions.js @@ -0,0 +1,25 @@ +import PaymentTransaction from './PaymentTransaction.js' +import MessageTransaction from './MessageTransaction.js' +import RegisterNameTransaction from './names/RegisterNameTransaction.js' +import ChatTransaction from './chat/ChatTransaction.js' +import GroupChatTransaction from './chat/GroupChatTransaction.js'; +import RewardShareTransaction from './reward-share/RewardShareTransaction.js' +import RemoveRewardShareTransaction from './reward-share/RemoveRewardShareTransaction.js' +import CreateGroupTransaction from './groups/CreateGroupTransaction.js'; +import JoinGroupTransaction from './groups/JoinGroupTransaction.js' +import LeaveGroupTransaction from './groups/LeaveGroupTransaction.js' +import PublicizeTransaction from './PublicizeTransaction.js' + +export const transactionTypes = { + 2: PaymentTransaction, + 3: RegisterNameTransaction, + 17: MessageTransaction, + 18: ChatTransaction, + 181: GroupChatTransaction, + 19: PublicizeTransaction, + 22: CreateGroupTransaction, + 31: JoinGroupTransaction, + 32: LeaveGroupTransaction, + 38: RewardShareTransaction, + 381: RemoveRewardShareTransaction +} diff --git a/qortal-ui-crypto/api/utils/randomBase58Generator.js b/qortal-ui-crypto/api/utils/randomBase58Generator.js new file mode 100644 index 00000000..57e6b0aa --- /dev/null +++ b/qortal-ui-crypto/api/utils/randomBase58Generator.js @@ -0,0 +1,11 @@ +export const randomBase58Generator = (digits) => { + digits = digits || 0 + let base58 = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz'.split('') + let result = '' + let char + while (result.length < digits) { + char = base58[Math.random() * 57 >> 0] + if (result.indexOf(char) === -1) result += char + } + return result +} diff --git a/qortal-ui-crypto/api/utils/stateAwait.js b/qortal-ui-crypto/api/utils/stateAwait.js new file mode 100644 index 00000000..8e8278f3 --- /dev/null +++ b/qortal-ui-crypto/api/utils/stateAwait.js @@ -0,0 +1,31 @@ +import { store } from '../../api.js' + +let subscriptions = [] + +// Have to wait with init because something import stateAwait before the store gets initialized +let initialized = false +const init = () => { + initialized = true + store.subscribe(() => { + const state = store.getState() + + subscriptions = subscriptions.filter(fn => fn(state)) + }) +} + +export const stateAwait = fn => { + return new Promise((resolve, reject) => { + // Check immediately...then if not true store it + if (!initialized) { + init() + } + if (fn(store.getState())) resolve() + subscriptions.push(state => { + if (fn(state)) { + resolve() + return true + } + return false + }) + }) +} diff --git a/qortal-ui-crypto/api/wallet/base58PublicKeyToAddress.js b/qortal-ui-crypto/api/wallet/base58PublicKeyToAddress.js new file mode 100644 index 00000000..914a67e0 --- /dev/null +++ b/qortal-ui-crypto/api/wallet/base58PublicKeyToAddress.js @@ -0,0 +1,11 @@ +import publicKeyToAddress from './publicKeyToAddress' +import Base58 from '../deps/Base58.js' + + +export const base58PublicKeyToAddress = (base58pubkey, qora = false) => { + const decodePubKey = Base58.decode(base58pubkey) + + const address = publicKeyToAddress(decodePubKey, qora) + + return address +} diff --git a/qortal-ui-crypto/api/wallet/publicKeyToAddress.js b/qortal-ui-crypto/api/wallet/publicKeyToAddress.js new file mode 100644 index 00000000..cd484903 --- /dev/null +++ b/qortal-ui-crypto/api/wallet/publicKeyToAddress.js @@ -0,0 +1,37 @@ +import RIPEMD160 from '../deps/ripemd160.js' +import BROKEN_RIPEMD160 from '../deps/broken-ripemd160.js' +import { Sha256 } from 'asmcrypto.js' + +import utils from '../deps/utils.js' +import Base58 from '../deps/Base58.js' +import { Buffer } from 'buffer' + +import { ADDRESS_VERSION } from '../constants.js' + +const repeatSHA256 = (passphrase, hashes) => { + let hash = passphrase + for (let i = 0; i < hashes; i++) { + hash = new Sha256().process(hash).finish().result + } + return hash +} + +const publicKeyToAddress = (publicKey, qora = false) => { + const publicKeySha256 = new Sha256().process(publicKey).finish().result + const _publicKeyHash = qora ? new BROKEN_RIPEMD160().digest(publicKeySha256) : new RIPEMD160().update(Buffer.from(publicKeySha256)).digest('hex') + + const publicKeyHash = qora ? _publicKeyHash : _publicKeyHash + let address = new Uint8Array() + + address = utils.appendBuffer(address, [ADDRESS_VERSION]) + address = utils.appendBuffer(address, publicKeyHash) + + const checkSum = repeatSHA256(address, 2) + address = utils.appendBuffer(address, checkSum.subarray(0, 4)) + + address = Base58.encode(address) + + return address +} + +export default publicKeyToAddress diff --git a/qortal-ui-crypto/api/wallet/validateAddress.js b/qortal-ui-crypto/api/wallet/validateAddress.js new file mode 100644 index 00000000..515773b1 --- /dev/null +++ b/qortal-ui-crypto/api/wallet/validateAddress.js @@ -0,0 +1,12 @@ +import Base58 from '../deps/Base58.js' + + +export const validateAddress = (address) => { + const decodePubKey = Base58.decode(address) + + if (!(decodePubKey instanceof Uint8Array && decodePubKey.length == 25)) { + return false + } + return true + +} diff --git a/qortal-ui-crypto/api_deps.js b/qortal-ui-crypto/api_deps.js new file mode 100644 index 00000000..c0d637b8 --- /dev/null +++ b/qortal-ui-crypto/api_deps.js @@ -0,0 +1,3 @@ +let store +export { store } +export const initApi = (s) => { store = s } diff --git a/qortal-ui-crypto/config.js b/qortal-ui-crypto/config.js new file mode 100644 index 00000000..6fccb8cc --- /dev/null +++ b/qortal-ui-crypto/config.js @@ -0,0 +1,38 @@ +import { store } from './api.js' + +let config = false +let loaded = false +const configWatchers = [] +const waitingForConfig = [] + +const subscribeToStore = () => { + if (!store) return setTimeout(() => subscribeToStore(), 50) // 0.05s + + store.subscribe(() => { + const cA = store.getState().app + const c = store.getState().config + if (!c.loaded) return + if (!loaded) waitingForConfig.forEach(r => r(cA)) + configWatchers.forEach(fn => fn(cA)) + config = cA + }) +} + +subscribeToStore() + +export function getConfig() { + return config +} + +export function watchConfig(fn) { + // config ? fn(config) : void 0 + fn(config) + configWatchers.push(fn) +} + +export function waitForConfig() { + return new Promise((resolve, reject) => { + if (config) return resolve(config) + waitingForConfig.push(resolve) + }) +} \ No newline at end of file diff --git a/qortal-ui-crypto/package.json b/qortal-ui-crypto/package.json new file mode 100644 index 00000000..15db7223 --- /dev/null +++ b/qortal-ui-crypto/package.json @@ -0,0 +1,27 @@ +{ + "name": "qortal-ui-crypto", + "version": "2.1.0", + "keywords": [ + "QORT", + "QORTAL", + "DECENTRALIZED" + ], + "homepage": "https://qortal.org", + "main": "api.js", + "repository": { + "type": "git", + "url": "https://github.com/Qortal/UI.git", + "directory": "qortal-ui-crypto" + }, + "author": "QORTAL ", + "license": "GPL-3.0", + "dependencies": { + "asmcrypto.js": "^2.3.2", + "buffer": "^6.0.3", + "jssha": "^3.2.0", + "lodash": "^4.17.21" + }, + "engines": { + "node": ">=14.17.0" + } +} \ No newline at end of file diff --git a/qortal-ui-plugins/build-config.js b/qortal-ui-plugins/build-config.js new file mode 100644 index 00000000..48266961 --- /dev/null +++ b/qortal-ui-plugins/build-config.js @@ -0,0 +1,123 @@ +const babel = require("@rollup/plugin-babel"); +const { nodeResolve } = require("@rollup/plugin-node-resolve"); +const replace = require('@rollup/plugin-replace') +const globals = require("rollup-plugin-node-globals"); +const commonjs = require("@rollup/plugin-commonjs"); +const progress = require("rollup-plugin-progress"); +const { terser } = require("rollup-plugin-terser"); +const path = require("path"); +const alias = require("@rollup/plugin-alias"); + +const aliases = { + // 'qortal-ui-crypto': 'node_modules/qortal-ui-crypto/api.js' +}; + +const generateRollupConfig = (inputFile, outputFile) => { + return { + inputOptions: { + onwarn: (warning, rollupWarn) => { + if (warning.code !== "CIRCULAR_DEPENDENCY") { + rollupWarn(warning); + } + }, + input: inputFile, + plugins: [ + alias({ + // entries: {} + entries: Object.keys(aliases).map((find) => { + return { + find, + replacement: aliases[find], + }; + }), + }), + nodeResolve({ + preferBuiltins: false, + mainFields: ['module', 'browser'] + }), + replace({ + preventAssignment: true, + "process.env.NODE_ENV": JSON.stringify("production"), + }), + commonjs(), + globals(), + progress(), + babel.babel({ + babelHelpers: 'bundled', + exclude: "node_modules/**", + }), + terser({ + compress: true, + output: { + comments: false, + }, + }) + ], + }, + outputOptions: { + file: outputFile, + format: "umd", + }, + }; +}; + +const generateForPlugins = () => { + const configs = [ + { + in: "plugins/core/main.src.js", + out: "plugins/core/main.js", + }, + { + in: "plugins/core/trade-portal/trade-portal.src.js", + out: "plugins/core/trade-portal/trade-portal.js", + }, + { + in: "plugins/core/send-coin/send-coin.src.js", + out: "plugins/core/send-coin/send-coin.js", + }, + { + in: "plugins/core/wallet/wallet-app.src.js", + out: "plugins/core/wallet/wallet-app.js", + }, + { + in: "plugins/core/reward-share/reward-share.src.js", + out: "plugins/core/reward-share/reward-share.js", + }, + { + in: "plugins/core/node-management/node-management.src.js", + out: "plugins/core/node-management/node-management.js", + }, + { + in: "plugins/core/group-management/group-management.src.js", + out: "plugins/core/group-management/group-management.js", + }, + { + in: "plugins/core/name-registration/name-registration.src.js", + out: "plugins/core/name-registration/name-registration.js", + }, + { + in: "plugins/core/messaging/messaging.src.js", + out: "plugins/core/messaging/messaging.js", + }, + { + in: "plugins/core/messaging/chain-messaging/chain-messaging.src.js", + out: "plugins/core/messaging/chain-messaging/chain-messaging.js", + }, + { + in: "plugins/core/messaging/q-chat/q-chat.src.js", + out: "plugins/core/messaging/q-chat/q-chat.js", + }, + { + in: "plugins/core/minting/minting-info.src.js", + out: "plugins/core/minting/minting-info.js", + } + ].map((file) => { + return generateRollupConfig( + path.join(__dirname, file.in), + path.join(__dirname, file.out) + ); + }); + + return configs; +}; +module.exports = generateForPlugins; diff --git a/qortal-ui-plugins/build.js b/qortal-ui-plugins/build.js new file mode 100644 index 00000000..5c8bc3f8 --- /dev/null +++ b/qortal-ui-plugins/build.js @@ -0,0 +1,23 @@ +const rollup = require('rollup') + +const configs = require('./build-config.js')() + +const build = () => { + configs.forEach(async file => { + const bundle = await rollup.rollup(file.inputOptions); + + const { output } = await bundle.generate(file.outputOptions); + + for (const chunkOrAsset of output) { + if (chunkOrAsset.type === 'asset') { + // console.log('Asset', chunkOrAsset); + } else { + // .. + } + } + + await bundle.write(file.outputOptions); + }) + console.log('BUILD PLUGINS ==> Bundling Done 🎉'); +} +module.exports = build diff --git a/qortal-ui-plugins/default-plugins.js b/qortal-ui-plugins/default-plugins.js new file mode 100644 index 00000000..9531c199 --- /dev/null +++ b/qortal-ui-plugins/default-plugins.js @@ -0,0 +1,36 @@ + +const PLUGINS = 'plugins' +const BUILD = 'build' +const WATCH = 'watch' + + +/** + * @package Plugins Controller + * @param { String } type + */ + +const pluginsController = (type) => { + switch (type) { + case PLUGINS: + const path = require('path') + const plugins = [ + { + folder: path.join(__dirname, 'plugins/core'), + name: 'core' + } + ] + return plugins + case BUILD: + const build = require('./build.js') + return build + case WATCH: + const watch = require('./watch.js') + return watch + default: + return + } + +} + + +module.exports = pluginsController diff --git a/qortal-ui-plugins/epml.js b/qortal-ui-plugins/epml.js new file mode 100644 index 00000000..188f8def --- /dev/null +++ b/qortal-ui-plugins/epml.js @@ -0,0 +1,11 @@ +import { Epml, EpmlReadyPlugin, RequestPlugin, ContentWindow as EpmlContentWindowPlugin, EpmlStreamPlugin, EpmlProxyPlugin, EpmlStream } from 'epml' + +// Epml.registerPlugin(contentWindowsPlugin) +Epml.registerPlugin(RequestPlugin) +Epml.registerPlugin(EpmlReadyPlugin) +Epml.registerPlugin(EpmlContentWindowPlugin) +Epml.registerPlugin(EpmlStreamPlugin) +Epml.registerPlugin(EpmlProxyPlugin) +Epml.allowProxying = true + +export { Epml, EpmlStream } diff --git a/qortal-ui-plugins/package.json b/qortal-ui-plugins/package.json new file mode 100644 index 00000000..1772e6d4 --- /dev/null +++ b/qortal-ui-plugins/package.json @@ -0,0 +1,53 @@ +{ + "name": "qortal-ui-plugins", + "version": "2.1.0", + "keywords": [ + "QORT", + "QORTAL", + "DECENTRALIZED" + ], + "homepage": "https://qortal.org", + "main": "default-plugins.js", + "repository": { + "type": "git", + "url": "https://github.com/Qortal/UI.git", + "directory": "qortal-ui-plugins" + }, + "author": "QORTAL ", + "license": "GPL-3.0", + "dependencies": { + "@material/mwc-list": "^0.18.0", + "@material/mwc-select": "^0.18.0", + "emoji-picker-js": "https://github.com/Qortal/emoji-picker-js" + }, + "devDependencies": { + "@babel/core": "^7.16.0", + "@github/time-elements": "^3.1.2", + "@material/mwc-button": "^0.18.0", + "@material/mwc-dialog": "^0.18.0", + "@material/mwc-icon": "^0.18.0", + "@material/mwc-icon-button": "^0.18.0", + "@material/mwc-slider": "^0.20.0", + "@material/mwc-tab": "^0.18.0", + "@material/mwc-tab-bar": "^0.18.0", + "@material/mwc-textfield": "^0.18.0", + "@polymer/paper-progress": "^3.0.1", + "@polymer/paper-spinner": "^3.0.2", + "@rollup/plugin-alias": "^3.1.8", + "@rollup/plugin-babel": "^5.3.0", + "@rollup/plugin-commonjs": "^21.0.1", + "@rollup/plugin-node-resolve": "^13.0.6", + "@rollup/plugin-replace": "^3.0.0", + "@vaadin/vaadin-grid": "^5.6.6", + "epml": "^0.3.3", + "html-escaper": "^3.0.3", + "lit-html": "^1.3.0", + "rollup": "^2.60.2", + "rollup-plugin-node-globals": "^1.4.0", + "rollup-plugin-progress": "^1.1.2", + "rollup-plugin-terser": "^7.0.2" + }, + "engines": { + "node": ">=14.17.0" + } +} diff --git a/qortal-ui-plugins/plugins/core/group-management/group-management.src.js b/qortal-ui-plugins/plugins/core/group-management/group-management.src.js new file mode 100644 index 00000000..9c817b85 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/group-management/group-management.src.js @@ -0,0 +1,843 @@ + +import { LitElement, html, css } from 'lit-element' +import { render } from 'lit-html' +import { Epml } from '../../../epml.js' + +import '@material/mwc-icon' +import '@material/mwc-button' +import '@material/mwc-textfield' +import '@material/mwc-dialog' + +import '@polymer/paper-spinner/paper-spinner-lite.js' +import '@vaadin/vaadin-grid/vaadin-grid.js' +import '@vaadin/vaadin-grid/theme/material/all-imports.js' + +import '@github/time-elements' + +const parentEpml = new Epml({ type: 'WINDOW', source: window.parent }) + +class GroupManagement extends LitElement { + static get properties() { + return { + loading: { type: Boolean }, + publicGroups: { type: Array }, + joinedGroups: { type: Array }, + recipientPublicKey: { type: String }, + selectedAddress: { type: Object }, + manageGroupObj: { type: Object }, + joinGroupObj: { type: Object }, + leaveGroupObj: { type: Object }, + btnDisable: { type: Boolean }, + isLoading: { type: Boolean }, + error: { type: Boolean }, + message: { type: String }, + removeError: { type: Boolean }, + removeMessage: { type: String } + } + } + + static get styles() { + return css` + * { + --mdc-theme-primary: rgb(3, 169, 244); + --paper-input-container-focus-color: var(--mdc-theme-primary); + } + #group-management-page { + background: #fff; + padding: 12px 24px; + } + + mwc-textfield { + width:100%; + } + + .red { + --mdc-theme-primary: red; + } + + .red-button { + --mdc-theme-primary: red; + --mdc-theme-on-primary: white; + } + + mwc-button.red-button { + --mdc-theme-primary: red; + --mdc-theme-on-primary: white; + } + + .divCard { + border: 1px solid #eee; + padding: 1em; + /** box-shadow: 0 1px 1px 0 rgba(0,0,0,0.14), 0 2px 1px -1px rgba(0,0,0,0.12), 0 1px 2px 0 rgba(0,0,0,0.20); **/ + box-shadow: 0 .3px 1px 0 rgba(0,0,0,0.14), 0 1px 1px -1px rgba(0,0,0,0.12), 0 1px 2px 0 rgba(0,0,0,0.20); + margin-bottom: 2em; + } + + h2 { + margin:0; + } + + h2, h3, h4, h5 { + color:#333; + font-weight: 400; + } + + [hidden] { + display: hidden !important; + visibility: none !important; + } + .details { + display: flex; + font-size: 18px; + } + span { + font-size: 18px; + word-break: break-all; + } + select { + padding: 13px 20px; + width: 100%; + font-size: 14px; + color: #555; + font-weight: 400; + } + .title { + font-weight:600; + font-size:12px; + line-height: 32px; + opacity: 0.66; + } + .itemList { + padding:0; + } + /* .itemList > * { + padding-left:24px; + padding-right:24px; + } */ + ` + } + + constructor() { + super() + this.selectedAddress = {} + this.publicGroups = [] + this.joinedGroups = [] + this.manageGroupObj = {} + this.joinGroupObj = {} + this.leaveGroupObj = {} + this.recipientPublicKey = '' + this.btnDisable = false + this.isLoading = false + } + + render() { + return html` +
+
+

Qortal Groups

+ this.shadowRoot.querySelector('#createGroupDialog').show()}>addCreate Group +
+ +
+

Public Groups

+ + + + + { + render(html` this.joinGroup(data.item)}>queueJoin`, root) + }}> + + + ${this.isEmptyArray(this.publicGroups) ? html` + No Open Public Groups available! + `: ''} +
+ +
+

Your Joined Groups

+ + + + { + render(html`${this.renderRole(data.item)}`, root) + }}> + { + render(html`${this.renderManageButton(data.item)}`, root) + }}> + + ${this.isEmptyArray(this.joinedGroups) ? html` + Not a member of any groups! + `: ''} +
+ + + +
+

Create a New Group

+
+
+ + +

+ +

+

+ Group Type: + +

+

+ Group Approval Threshold (number / percentage of Admins that must approve a transaction): + +

+

+ Minimum Block delay for Group Transaction Approvals: + +

+

+ Maximum Block delay for Group Transaction Approvals: + +

+
+ + + Creating Group   + + + + ${this.message} + +
+ + + Create + + + Close + +
+ + + +
+

Join Group Request

+
+
+ +
+ Group Name +
+
${this.joinGroupObj.groupName}
+ + Description +
+
${this.joinGroupObj.description}
+ + Owner +
+
${this.joinGroupObj.owner}
+ + Date Created +
+
+ + ${!this.joinGroupObj.updated ? "" : html`Date Updated +
+
`} +
+ +
+ + + Joining   + + + + ${this.message} + +
+ + this._joinGroup(this.joinGroupObj.groupId, this.joinGroupObj.groupName)} + > + Join + + + Close + +
+ + + +
+

Leave Group Request

+
+
+ +
+ Group Name +
+
${this.leaveGroupObj.groupName}
+ + Description +
+
${this.leaveGroupObj.description}
+ + Owner +
+
${this.leaveGroupObj.owner}
+ + Date Created +
+
+ + ${!this.leaveGroupObj.updated ? "" : html`Date Updated +
+
`} +
+ +
+ + + Leaving   + + + + ${this.message} + +
+ + this._leaveGroup(this.leaveGroupObj.groupId, this.leaveGroupObj.groupName)} + > + Leave Group + + + Close + +
+ + + +
Manage Group Owner: ${this.manageGroupObj.groupName}
+ + + Close + +
+ + + +
Manage Group Admin: ${this.manageGroupObj.groupName}
+ + + Close + +
+
+ ` + } + + resetDefaultSettings() { + this.error = false + this.message = '' + this.isLoading = false + } + + manageGroupOwner(groupObj) { + this.resetDefaultSettings() + this.manageGroupObj = groupObj + + this.shadowRoot.querySelector('#manageGroupOwnerDialog').show() + } + + manageGroupAdmin(groupObj) { + this.resetDefaultSettings() + this.manageGroupObj = groupObj + + this.shadowRoot.querySelector('#manageGroupAdminDialog').show() + } + + joinGroup(groupObj) { + this.resetDefaultSettings() + this.joinGroupObj = groupObj + + this.shadowRoot.querySelector('#joinDialog').show() + } + + leaveGroup(groupObj) { + this.resetDefaultSettings() + this.leaveGroupObj = groupObj + + this.shadowRoot.querySelector('#leaveDialog').show() + } + + timeIsoString(timestamp) { + let myTimestamp = timestamp === undefined ? 1587560082346 : timestamp + let time = new Date(myTimestamp) + return time.toISOString() + } + + renderRole(groupObj) { + if (groupObj.owner === this.selectedAddress.address) { + return "Owner" + } else if (groupObj.isAdmin === true) { + return "Admin" + } else { + return "Member" + } + } + + renderManageButton(groupObj) { + if (groupObj.owner === this.selectedAddress.address) { + // render owner actions btn to modal + return html` this.manageGroupOwner(groupObj)}>createManage` + } else if (groupObj.isAdmin === true) { + // render admin actions modal + return html` this.manageGroupAdmin(groupObj)}>createManage` + } else { + // render member leave group modal + return html` this.leaveGroup(groupObj)}>exit_to_appLeave` + } + } + + _textMenu(event) { + + const getSelectedText = () => { + var text = ""; + if (typeof window.getSelection != "undefined") { + text = window.getSelection().toString(); + } else if (typeof this.shadowRoot.selection != "undefined" && this.shadowRoot.selection.type == "Text") { + text = this.shadowRoot.selection.createRange().text; + } + return text; + } + + const checkSelectedTextAndShowMenu = () => { + let selectedText = getSelectedText(); + if (selectedText && typeof selectedText === 'string') { + + let _eve = { pageX: event.pageX, pageY: event.pageY, clientX: event.clientX, clientY: event.clientY } + + let textMenuObject = { selectedText: selectedText, eventObject: _eve, isFrame: true } + + parentEpml.request('openCopyTextMenu', textMenuObject) + } + } + + checkSelectedTextAndShowMenu() + } + + + firstUpdated() { + + // Call getNamesGrid + // this.getNamesGrid() + + const getOpenPublicGroups = async () => { + let openG = await parentEpml.request('apiCall', { + url: `/groups?limit=0&reverse=true` + }) + + let myGs = openG.filter(myG => myG.isOpen === true) + return myGs + } + + const getJoinedGroups = async () => { + let joinedG = await parentEpml.request('apiCall', { + url: `/groups/member/${this.selectedAddress.address}` + }) + + return joinedG + } + + const getOpen_JoinedGroups = async () => { + // this.publicGroups = [] + // this.joinedGroups = [] + + let _joinedGroups = await getJoinedGroups() + let _publicGroups = await getOpenPublicGroups() + + let results = _publicGroups.filter(myOpenGroup => { + let value = _joinedGroups.some(myJoinedGroup => myOpenGroup.groupId === myJoinedGroup.groupId) + return !value + }); + this.publicGroups = results + this.joinedGroups = _joinedGroups + setTimeout(getOpen_JoinedGroups, this.config.user.nodeSettings.pingInterval) + } + + window.addEventListener("contextmenu", (event) => { + + event.preventDefault(); + this._textMenu(event) + }); + + window.addEventListener("click", () => { + + parentEpml.request('closeCopyTextMenu', null) + }); + + window.onkeyup = (e) => { + if (e.keyCode === 27) { + + parentEpml.request('closeCopyTextMenu', null) + } + } + + let configLoaded = false + + parentEpml.ready().then(() => { + parentEpml.subscribe('selected_address', async selectedAddress => { + this.selectedAddress = {} + selectedAddress = JSON.parse(selectedAddress) + if (!selectedAddress || Object.entries(selectedAddress).length === 0) return + this.selectedAddress = selectedAddress + }) + parentEpml.subscribe('config', c => { + if (!configLoaded) { + setTimeout(getOpen_JoinedGroups, 1) + configLoaded = true + } + this.config = JSON.parse(c) + }) + parentEpml.subscribe('copy_menu_switch', async value => { + + if (value === 'false' && window.getSelection().toString().length !== 0) { + + this.clearSelection() + } + }) + }) + + + parentEpml.imReady() + } + + async createGroup(e) { + // Reset Default Settings... + this.resetDefaultSettings() + + const groupNameInput = this.shadowRoot.getElementById("groupNameInput").value + const groupDescInput = this.shadowRoot.getElementById("groupDescInput").value + const groupTypeInput = this.shadowRoot.getElementById("groupTypeInput").value + const groupApprovalInput = this.shadowRoot.getElementById("groupApprovalInput").value + const groupMinDelayInput = this.shadowRoot.getElementById("groupMinDelayInput").value + const groupMaxDelayInput = this.shadowRoot.getElementById("groupMaxDelayInput").value + + this.isLoading = true + + // Get Last Ref + const getLastRef = async () => { + let myRef = await parentEpml.request('apiCall', { + type: 'api', + url: `/addresses/lastreference/${this.selectedAddress.address}` + }) + return myRef + }; + + const validateReceiver = async () => { + let lastRef = await getLastRef(); + let _groupTypeInput = parseInt(groupTypeInput) + let _groupApprovalInput = parseInt(groupApprovalInput) + let _groupMinDelayInput = parseInt(groupMinDelayInput) + let _groupMaxDelayInput = parseInt(groupMaxDelayInput) + + this.resetDefaultSettings() + let myTransaction = await makeTransactionRequest(_groupTypeInput, _groupApprovalInput, _groupMinDelayInput, _groupMaxDelayInput, lastRef) + getTxnRequestResponse(myTransaction) + + } + + // Make Transaction Request + const makeTransactionRequest = async (_groupTypeInput, _groupApprovalInput, _groupMinDelayInput, _groupMaxDelayInput, lastRef) => { + + let myTxnrequest = await parentEpml.request('transaction', { + type: 22, + nonce: this.selectedAddress.nonce, + params: { + registrantAddress: this.selectedAddress.address, + rGroupName: groupNameInput, + rGroupDesc: groupDescInput, + rGroupType: _groupTypeInput, + rGroupApprovalThreshold: _groupApprovalInput, + rGroupMinimumBlockDelay: _groupMinDelayInput, + rGroupMaximumBlockDelay: _groupMaxDelayInput, + lastReference: lastRef, + } + }) + + return myTxnrequest + } + + // FAILED txnResponse = {success: false, message: "User declined transaction"} + // SUCCESS txnResponse = { success: true, data: true } + + const getTxnRequestResponse = (txnResponse) => { + + if (txnResponse.success === false && txnResponse.message) { + this.error = true + this.message = txnResponse.message + throw new Error(txnResponse) + } else if (txnResponse.success === true && !txnResponse.data.error) { + this.message = 'Group Creation Successful!' + this.error = false + } else { + this.error = true + this.message = txnResponse.data.message + throw new Error(txnResponse) + } + } + + if (groupNameInput.length < 3) { + this.error = true + this.message = "Invalid Group Name" + this.isLoading = false + } else if (groupDescInput.length < 3) { + this.error = true + this.message = "Invalid Group Description" + this.isLoading = false + } else if (groupTypeInput === 'reject') { + this.error = true + this.message = "Select a Group Type" + this.isLoading = false + } else if (groupApprovalInput === 'reject') { + this.error = true + this.message = "Select a Group Approval Threshold" + this.isLoading = false + } else if (groupMinDelayInput === 'reject') { + this.error = true + this.message = "Select a Minimum Block delay for Group Transaction Approvals" + this.isLoading = false + } else if (groupMaxDelayInput === 'reject') { + this.error = true + this.message = "Select a Maximum Block delay for Group Transaction Approvals" + this.isLoading = false + } else { + this.error = false + // Call validateReceiver + validateReceiver() + } + // this.resetDefaultSettings() + } + + async _joinGroup(groupId, groupName) { + // Reset Default Settings... + this.resetDefaultSettings() + + this.isLoading = true + + // Get Last Ref + const getLastRef = async () => { + let myRef = await parentEpml.request('apiCall', { + type: 'api', + url: `/addresses/lastreference/${this.selectedAddress.address}` + }) + return myRef + }; + + const validateReceiver = async () => { + let lastRef = await getLastRef(); + + this.resetDefaultSettings() + let myTransaction = await makeTransactionRequest(lastRef) + getTxnRequestResponse(myTransaction) + + } + + // Make Transaction Request + const makeTransactionRequest = async (lastRef) => { + + let myTxnrequest = await parentEpml.request('transaction', { + type: 31, + nonce: this.selectedAddress.nonce, + params: { + registrantAddress: this.selectedAddress.address, + rGroupName: groupName, + rGroupId: groupId, + lastReference: lastRef, + } + }) + + return myTxnrequest + } + + // FAILED txnResponse = {success: false, message: "User declined transaction"} + // SUCCESS txnResponse = { success: true, data: true } + + const getTxnRequestResponse = (txnResponse) => { + + if (txnResponse.success === false && txnResponse.message) { + this.error = true + this.message = txnResponse.message + throw new Error(txnResponse) + } else if (txnResponse.success === true && !txnResponse.data.error) { + this.message = 'Join Group Request Sent Successfully!' + this.error = false + } else { + this.error = true + this.message = txnResponse.data.message + throw new Error(txnResponse) + } + } + + validateReceiver() + + this.resetDefaultSettings() + } + + async _leaveGroup(groupId, groupName) { + // Reset Default Settings... + this.resetDefaultSettings() + + this.isLoading = true + + // Get Last Ref + const getLastRef = async () => { + let myRef = await parentEpml.request('apiCall', { + type: 'api', + url: `/addresses/lastreference/${this.selectedAddress.address}` + }) + return myRef + }; + + const validateReceiver = async () => { + let lastRef = await getLastRef(); + + this.resetDefaultSettings() + let myTransaction = await makeTransactionRequest(lastRef) + getTxnRequestResponse(myTransaction) + + } + + // Make Transaction Request + const makeTransactionRequest = async (lastRef) => { + + let myTxnrequest = await parentEpml.request('transaction', { + type: 32, + nonce: this.selectedAddress.nonce, + params: { + registrantAddress: this.selectedAddress.address, + rGroupName: groupName, + rGroupId: groupId, + lastReference: lastRef, + } + }) + + return myTxnrequest + } + + // FAILED txnResponse = {success: false, message: "User declined transaction"} + // SUCCESS txnResponse = { success: true, data: true } + + const getTxnRequestResponse = (txnResponse) => { + + if (txnResponse.success === false && txnResponse.message) { + this.error = true + this.message = txnResponse.message + throw new Error(txnResponse) + } else if (txnResponse.success === true && !txnResponse.data.error) { + this.message = 'Leave Group Request Sent Successfully!' + this.error = false + } else { + this.error = true + this.message = txnResponse.data.message + throw new Error(txnResponse) + } + } + + validateReceiver() + + this.resetDefaultSettings() + } + + clearSelection() { + + window.getSelection().removeAllRanges() + window.parent.getSelection().removeAllRanges() + } + + isEmptyArray(arr) { + if (!arr) { return true } + return arr.length === 0 + } +} + +window.customElements.define('group-management', GroupManagement) diff --git a/qortal-ui-plugins/plugins/core/group-management/group-transaction/group-transaction.src.js b/qortal-ui-plugins/plugins/core/group-management/group-transaction/group-transaction.src.js new file mode 100644 index 00000000..20fcd01d --- /dev/null +++ b/qortal-ui-plugins/plugins/core/group-management/group-transaction/group-transaction.src.js @@ -0,0 +1,289 @@ +import { LitElement, html, css } from 'lit-element' +// import { render } from 'lit-html' +// import { Epml } from '../../../src/epml.js' +import { Epml } from '../../../../epml.js' + +import '@polymer/paper-spinner/paper-spinner-lite.js' + +// import * as thing from 'time-elements' +// import '@vaadin/vaadin-grid/vaadin-grid.js' +// import '@vaadin/vaadin-grid/theme/material/all-imports.js' + +// import '@material/mwc-icon' +// import '@material/mwc-textfield' +// import '@material/mwc-button' +// import '@material/mwc-dialog' + +const parentEpml = new Epml({ type: 'WINDOW', source: window.parent }) + +class GroupTransaction extends LitElement { + static get properties() { + return { + loading: { type: Boolean }, + upTime: { type: String }, + mintingAccounts: { type: Array }, + peers: { type: Array }, + addMintingAccountLoading: { type: Boolean }, + removeMintingAccountLoading: { type: Boolean }, + addPeerLoading: { type: Boolean }, + confPeerLoading: { type: Boolean }, + addMintingAccountKey: { type: String }, + removeMintingAccountKey: { type: String }, + addPeerMessage: { type: String }, + confPeerMessage: { type: String }, + addMintingAccountMessage: { type: String }, + removeMintingAccountMessage: { type: String }, + tempMintingAccount: { type: Object }, + selectedAddress: { type: Object } + } + } + + static get styles() { + return css` + * { + --mdc-theme-primary: rgb(3, 169, 244); + --paper-input-container-focus-color: var(--mdc-theme-primary); + } + + paper-spinner-lite{ + height: 24px; + width: 24px; + --paper-spinner-color: var(--mdc-theme-primary); + --paper-spinner-stroke-width: 2px; + } + + #group-transaction-page { + background:#fff; + } + + mwc-textfield { + width:100%; + } + + .red { + --mdc-theme-primary: red; + } + + .red-button { + --mdc-theme-primary: red; + --mdc-theme-on-primary: white; + } + + mwc-button.red-button { + --mdc-theme-primary: red; + --mdc-theme-on-primary: white; + } + + .group-transaction-card { + /* margin:12px; */ + padding:12px 24px; + background:#fff; + border-radius:2px; + box-shadow: 11; + } + + h2 { + margin:0; + } + + h2, h3, h4, h5 { + color:#333; + font-weight: 400; + } + + [hidden] { + display: hidden !important; + visibility: none !important; + } + .details { + display: flex; + font-size: 18px; + } + + ` + } + + constructor() { + super() + this.upTime = "" + this.mintingAccounts = [] + this.peers = [] + this.addPeerLoading = false + this.confPeerLoading = false + this.addMintingAccountLoading = false + this.removeMintingAccountLoading = false + this.addMintingAccountKey = '' + this.removeMintingAccountKey = '' + this.addPeerMessage = '' + this.confPeerMessage = '' + this.addMintingAccountMessage = '' + this.removeMintingAccountMessage = '' + this.tempMintingAccount = {} + this.selectedAddress = {} + this.config = { + user: { + node: { + + } + } + } + } + + render() { + return html` +
+ +
+

Group Transaction

+ +

${this.addMintingAccountMessage}

+ +
+
+ ` + } + + // getMintingAccountGrid() { + + // const myGrid = this.shadowRoot.querySelector('#mintingAccountsGrid') + + // myGrid.addEventListener('click', (e) => { + // this.tempMintingAccount = myGrid.getEventContext(e).item + + // this.shadowRoot.querySelector('#removeMintingAccountDialog').show() + // }) + + // } + + + // addPeer(e) { + // this.addPeerLoading = true + // const addPeerAddress = this.shadowRoot.querySelector('#addPeerAddress').value + + // parentEpml.request('apiCall', { + // url: `/peers`, + // method: 'POST', + // body: addPeerAddress + // }).then(res => { + // this.addPeerMessage = res.message + + // this.addPeerLoading = false + // }) + + // } + + + // addMintingAccount(e) { + // this.addMintingAccountLoading = true + // this.addMintingAccountMessage = "Loading..." + + // this.addMintingAccountKey = this.shadowRoot.querySelector('#addMintingAccountKey').value + + // parentEpml.request('apiCall', { + // url: `/admin/mintingaccounts`, + // method: 'POST', + // body: this.addMintingAccountKey + // }).then(res => { + // if (res === true) { + // this.updateMintingAccounts() + // this.addMintingAccountKey = '' + // this.addMintingAccountMessage = 'Minting Node Added Successfully!' + // this.addMintingAccountLoading = false + // } else { + // this.addMintingAccountKey = '' + // this.addMintingAccountMessage = 'Failed to Add Minting Node!' // Corrected an error here thanks to crow (-_-) + // this.addMintingAccountLoading = false + // } + // }) + // } + + // updateMintingAccounts() { + // parentEpml.request('apiCall', { + // url: `/admin/mintingaccounts` + // }).then(res => { + + // this.mintingAccounts = [] + // setTimeout(() => { this.mintingAccounts = res }, 1) + // }) + + // // setTimeout(updateMintingAccounts, this.config.user.nodeSettings.pingInterval) // Perhaps should be slower...? + // } + + // removeMintingAccount(e) { + // this.removeMintingAccountLoading = true + // this.removeMintingAccountMessage = "Loading..." + + // this.removeMintingAccountKey = this.shadowRoot.querySelector('#removeMintingAccountKey').value + + // this.mintingAccounts.forEach(mintingAccount => { + // if (this.tempMintingAccount.recipientAccount === mintingAccount.recipientAccount) { + + // parentEpml.request('apiCall', { + // url: `/admin/mintingaccounts`, + // method: 'DELETE', + // body: this.removeMintingAccountKey + // }).then(res => { + // if (res === true) { + // this.updateMintingAccounts() + // this.removeMintingAccountKey = '' + // this.removeMintingAccountMessage = 'Minting Node Removed Successfully!' + // this.removeMintingAccountLoading = false + // } else { + // this.removeMintingAccountKey = '' + // this.removeMintingAccountMessage = 'Failed to Remove Minting Node!' + // this.removeMintingAccountLoading = false + // } + // }) + // } + // }) + + // } + + firstUpdated() { + + // Call getMintingAccountGrid + // this.getMintingAccountGrid() + + // Call updateMintingAccounts + // this.updateMintingAccounts() + + const getGroupIdFromURL = () => { + let tempUrl = document.location.href + let decodeTempUrl = decodeURI(tempUrl) + let splitedUrl = decodeTempUrl.split('?') + let myGroupId = splitedUrl[1] + this.addMintingAccountMessage = myGroupId + console.log(myGroupId); + } + + getGroupIdFromURL() + + let configLoaded = false + + parentEpml.ready().then(() => { + parentEpml.subscribe('selected_address', async selectedAddress => { + this.selectedAddress = {} + selectedAddress = JSON.parse(selectedAddress) + if (!selectedAddress || Object.entries(selectedAddress).length === 0) return + this.selectedAddress = selectedAddress + }) + parentEpml.subscribe('config', c => { + if (!configLoaded) { + // setTimeout(getGroupIdFromURL, 1) + configLoaded = true + } + this.config = JSON.parse(c) + }) + }) + + + parentEpml.imReady() + } + + isEmptyArray(arr) { + if (!arr) { return true } + return arr.length === 0 + } +} + +window.customElements.define('group-transaction', GroupTransaction) diff --git a/qortal-ui-plugins/plugins/core/group-management/group-transaction/index.html b/qortal-ui-plugins/plugins/core/group-management/group-transaction/index.html new file mode 100644 index 00000000..68da30df --- /dev/null +++ b/qortal-ui-plugins/plugins/core/group-management/group-transaction/index.html @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/qortal-ui-plugins/plugins/core/group-management/index.html b/qortal-ui-plugins/plugins/core/group-management/index.html new file mode 100644 index 00000000..ec489846 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/group-management/index.html @@ -0,0 +1,46 @@ + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/qortal-ui-plugins/plugins/core/index.html b/qortal-ui-plugins/plugins/core/index.html new file mode 100644 index 00000000..084e05ff --- /dev/null +++ b/qortal-ui-plugins/plugins/core/index.html @@ -0,0 +1 @@ +

Core plugin

\ No newline at end of file diff --git a/qortal-ui-plugins/plugins/core/main.src.js b/qortal-ui-plugins/plugins/core/main.src.js new file mode 100644 index 00000000..f83d88a9 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/main.src.js @@ -0,0 +1,116 @@ +import { parentEpml } from './connect.js' +import './streams/streams.js' + +let config = {} +let haveRegisteredNodeManagement = false + + +parentEpml.ready().then(() => { + // THOUGHTS: DONE: The request to register urls should be made once... + + + // pluginUrlsConf + let pluginUrlsConf = [ + { + url: 'minting', + domain: 'core', + page: 'minting/index.html', + title: 'Minting Details', + icon: 'info', + menus: [], + parent: false + }, + { + url: 'wallet', + domain: 'core', + page: 'wallet/index.html', + title: 'Wallet', + icon: 'account_balance_wallet', + menus: [], + parent: false + }, + { + url: 'send-coin', + domain: 'core', + page: 'send-coin/index.html', + title: 'Send Coin', + icon: 'send', + menus: [], + parent: false + }, + { + url: 'trade-portal', + domain: 'core', + page: 'trade-portal/index.html', + title: 'Trade Portal', + icon: 'toc', + menus: [], + parent: false + }, + { + url: 'reward-share', + domain: 'core', + page: 'reward-share/index.html', + title: 'Reward Share', + icon: 'call_split', + menus: [], + parent: false + }, + { + url: 'name-registration', + domain: 'core', + page: 'name-registration/index.html', + title: 'Name Registration', + icon: 'assignment_ind', + menus: [], + parent: false + }, + { + url: 'q-chat', + domain: 'core', + page: 'messaging/q-chat/index.html', + title: 'Q-Chat', + icon: 'message', + menus: [], + parent: false + }, + { + url: 'group-management', + domain: 'core', + page: 'group-management/index.html', + title: 'Group Management', + icon: 'group', + menus: [], + parent: false + } + ] + + const registerPlugins = (pluginInfo) => { + parentEpml.request('registerUrl', pluginInfo) + } + + + parentEpml.subscribe('config', c => { + config = JSON.parse(c) + + // Only register node management if node management is enabled and it hasn't already been registered + if (!haveRegisteredNodeManagement && config.user.knownNodes[config.user.node].enableManagement) { + haveRegisteredNodeManagement = true + + let nodeManagementConf = { + url: 'node-management', + domain: 'core', + page: 'node-management/index.html', + title: 'Node Management', + icon: 'cloud', + menus: [], + parent: false + } + + let _pluginUrlsConf = [...pluginUrlsConf, nodeManagementConf] + registerPlugins(_pluginUrlsConf) + } else { + registerPlugins(pluginUrlsConf) + } + }) +}) diff --git a/qortal-ui-plugins/plugins/core/messaging/chain-messaging/chain-messaging.src.js b/qortal-ui-plugins/plugins/core/messaging/chain-messaging/chain-messaging.src.js new file mode 100644 index 00000000..4ae3b611 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/messaging/chain-messaging/chain-messaging.src.js @@ -0,0 +1,100 @@ +import { LitElement, html, css } from 'lit-element' + +class ChainMessaging extends LitElement { + static get properties() { + return { + loading: { type: Boolean }, + } + } + + static get styles() { + return css` + * { + --mdc-theme-primary: rgb(3, 169, 244); + --paper-input-container-focus-color: var(--mdc-theme-primary); + } + + paper-spinner-lite{ + height: 24px; + width: 24px; + --paper-spinner-color: var(--mdc-theme-primary); + --paper-spinner-stroke-width: 2px; + } + + #chain-messaging-page { + background:#fff; + } + + ` + } + + constructor() { + super() + // ... + } + + render() { + return html` +
+ +

Coming Soon!

+
+ ` + } + + + firstUpdated() { + + window.addEventListener("contextmenu", (event) => { + + event.preventDefault(); + // this._textMenu(event) + }); + + window.addEventListener("click", () => { + + // parentEpml.request('closeCopyTextMenu', null) + }); + + window.onkeyup = (e) => { + if (e.keyCode === 27) { + + // parentEpml.request('closeCopyTextMenu', null) + } + } + } + + // _textMenu(event) { + + // const getSelectedText = () => { + // var text = ""; + // if (typeof window.getSelection != "undefined") { + // text = window.getSelection().toString(); + // } else if (typeof this.shadowRoot.selection != "undefined" && this.shadowRoot.selection.type == "Text") { + // text = this.shadowRoot.selection.createRange().text; + // } + // return text; + // } + + // const checkSelectedTextAndShowMenu = () => { + // let selectedText = getSelectedText(); + // if (selectedText && typeof selectedText === 'string') { + + // let _eve = { pageX: event.pageX, pageY: event.pageY, clientX: event.clientX, clientY: event.clientY } + + // let textMenuObject = { selectedText: selectedText, eventObject: _eve, isFrame: true } + + // parentEpml.request('openCopyTextMenu', textMenuObject) + // } + // } + + // checkSelectedTextAndShowMenu() + // } + + isEmptyArray(arr) { + if (!arr) { return true } + return arr.length === 0 + } +} + +window.customElements.define('chain-messaging', ChainMessaging) diff --git a/qortal-ui-plugins/plugins/core/messaging/chain-messaging/index.html b/qortal-ui-plugins/plugins/core/messaging/chain-messaging/index.html new file mode 100644 index 00000000..ff935638 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/messaging/chain-messaging/index.html @@ -0,0 +1,45 @@ + + + + + + + + + + + + + + diff --git a/qortal-ui-plugins/plugins/core/messaging/index.html b/qortal-ui-plugins/plugins/core/messaging/index.html new file mode 100644 index 00000000..da899288 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/messaging/index.html @@ -0,0 +1,45 @@ + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/qortal-ui-plugins/plugins/core/messaging/messaging.src.js b/qortal-ui-plugins/plugins/core/messaging/messaging.src.js new file mode 100644 index 00000000..079b6bc0 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/messaging/messaging.src.js @@ -0,0 +1,223 @@ +import { LitElement, html, css } from 'lit-element' +import { Epml } from '../../../epml.js' + +const parentEpml = new Epml({ type: 'WINDOW', source: window.parent }) + +class Messaging extends LitElement { + static get properties() { + return {} + } + + static get styles() { + return css` + * { + --mdc-theme-primary: rgb(3, 169, 244); + } + #page { + background: #fff; + padding: 12px 24px; + } + + h2 { + margin:0; + font-weight: 400; + } + + h3, h4, h5 { + color:#333; + font-weight: 400; + } + + .major-title { + color: rgb(3, 169, 244); + margin-top: 1rem; + font-weight: 400; + font-size: 28px; + text-align: center; + } + + .sub-title { + color: rgb(3, 169, 244); + margin-top: .5rem; + font-weight: 400; + /* font-size: 19px; */ + text-align: center; + } + + .sub-title:hover { + cursor: pointer; + } + + .sub-url { + font-size: 19px; + text-decoration: underline; + } + + .sub-url:hover { + cursor: pointer; + } + + .divCard { + border: 1px solid #eee; + padding: 1em; + /** box-shadow: 0 1px 1px 0 rgba(0,0,0,0.14), 0 2px 1px -1px rgba(0,0,0,0.12), 0 1px 2px 0 rgba(0,0,0,0.20); **/ + box-shadow: 0 .3px 1px 0 rgba(0,0,0,0.14), 0 1px 1px -1px rgba(0,0,0,0.12), 0 1px 2px 0 rgba(0,0,0,0.20); + margin-bottom: 1.5rem; + } + + p { + color:#333; + } + + ul, ul li { + color:#333; + } + ` + } + + constructor() { + super() + } + + render() { + return html` +
+
+

Welcome to the Qortal Messaging System!

+

With this system, you are able to accomplish multiple types of messaging available to you in Qortal:

+
    +
  • this.getUrl('chain-messaging')}>Chain Based Messaging
  • +
  • this.getUrl('q-chat')}>Q-Chat
  • +
+
+ +
+

this.getUrl('chain-messaging')}>Chain-Based Messaging

+

A long-term message that is stored ON CHAIN. + These messages are able to be sent to groups or individual accounts, and are essentially the 'e-mail' of Qortal. + Use these messages if you intend on the message being a PERMANENT message that stays when and where you send it.

+ + + +
    +
  • There are no @ in Qortal Chain Messaging, only 'registered names'. As the registered names on the chain can only be registered ONCE. Therefore, there are NO DUPLICATES.
  • +
  • Chain Messages LAST FOREVER
  • +
  • Encyption is DEFAULT, unless chosen to be NOT encrypted. (also known as a 'public message' which are readable by an api call from anyone.)
  • +
  • 'Attachments' will be possible in the future, with the use of the Qortal Data System.
  • +
  • Public Messages can be used for 'verification purposes' such as 'copyrights' or 'I did it first' notations. The terms 'copyright' and 'patent' are a thing of the past, if you did it first, put in a public message, and it is by default proven.
  • +
+ +
+ +
+

this.getUrl('q-chat')}>Q-Chat

+

Is a custom chat system that is UNLIKE ANY OTHER in existence. It is the FIRST OF ITS KIND IN THE WORLD. + It is a real-time, blockchain-based chat system that utilizes a memory-based PoW (Proof Of Work) algorithm, to implement a specialized transaction that is 'temporary', on the Qortal blockchain. + Q-Chat messages will DISSAPEAR AFTER 24 HOURS and therefore are not a great choice for things you wish to be permanent.

+ +
    +
  • In the future, there will be a 'pinning' system, that will allow you to convert, or send messages by default with, the ability to stay forever on the Qortal Blockchain. So that if you DO decide that you like a message enough to keep it forever, you may do so.
  • +
  • Q-chat messages are encrypted (at the moment in June, 2020, Q-chat PM's are encrypted, but the group messages are base58 encoded, meaning they aren't plain text, but if you're smart you can decode them. However, IN THE NEAR FUTURE, ALL MESSAGES REGARDLESS OF GROUP OR PM WILL BE DEFAULT ENCRYPTED WITH PUB/PRIV KEY OF YOUR QORTAL ACCOUNT.
  • +
  • Uses a UNIQUE memory-based PoW algorithm, to send messages FREE (no transaction fee)
  • +
  • Text-based messaging for the future.
  • +
+ +
+
+ ` + } + + getUrl(pageId) { + this.onPageNavigation(`/app/${pageId}`) + + } + + onPageNavigation(pageUrl) { + parentEpml.request('setPageUrl', pageUrl) + } + + + firstUpdated() { + + window.addEventListener("contextmenu", (event) => { + + event.preventDefault(); + this._textMenu(event) + }); + + window.addEventListener("click", () => { + + parentEpml.request('closeCopyTextMenu', null) + }); + + window.onkeyup = (e) => { + if (e.keyCode === 27) { + + parentEpml.request('closeCopyTextMenu', null) + } + } + + let configLoaded = false + + parentEpml.ready().then(() => { + parentEpml.subscribe('selected_address', async selectedAddress => { + this.selectedAddress = {} + selectedAddress = JSON.parse(selectedAddress) + if (!selectedAddress || Object.entries(selectedAddress).length === 0) return + this.selectedAddress = selectedAddress + }) + parentEpml.subscribe('config', c => { + if (!configLoaded) { + configLoaded = true + } + this.config = JSON.parse(c) + }) + parentEpml.subscribe('copy_menu_switch', async value => { + + if (value === 'false' && window.getSelection().toString().length !== 0) { + + this.clearSelection() + } + }) + }) + + + parentEpml.imReady() + } + + _textMenu(event) { + + const getSelectedText = () => { + var text = ""; + if (typeof window.getSelection != "undefined") { + text = window.getSelection().toString(); + } else if (typeof this.shadowRoot.selection != "undefined" && this.shadowRoot.selection.type == "Text") { + text = this.shadowRoot.selection.createRange().text; + } + return text; + } + + const checkSelectedTextAndShowMenu = () => { + let selectedText = getSelectedText(); + if (selectedText && typeof selectedText === 'string') { + + let _eve = { pageX: event.pageX, pageY: event.pageY, clientX: event.clientX, clientY: event.clientY } + + let textMenuObject = { selectedText: selectedText, eventObject: _eve, isFrame: true } + + parentEpml.request('openCopyTextMenu', textMenuObject) + } + } + + checkSelectedTextAndShowMenu() + } + + clearSelection() { + + window.getSelection().removeAllRanges() + window.parent.getSelection().removeAllRanges() + } + +} + +window.customElements.define('q-messaging', Messaging) diff --git a/qortal-ui-plugins/plugins/core/messaging/q-chat/index.html b/qortal-ui-plugins/plugins/core/messaging/q-chat/index.html new file mode 100644 index 00000000..927eddec --- /dev/null +++ b/qortal-ui-plugins/plugins/core/messaging/q-chat/index.html @@ -0,0 +1,46 @@ + + + + + + + + + + + + + + \ No newline at end of file diff --git a/qortal-ui-plugins/plugins/core/messaging/q-chat/q-chat.src.js b/qortal-ui-plugins/plugins/core/messaging/q-chat/q-chat.src.js new file mode 100644 index 00000000..175e02f4 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/messaging/q-chat/q-chat.src.js @@ -0,0 +1,710 @@ +import { LitElement, html, css } from 'lit-element' +import { render } from 'lit-html' +import { Epml } from '../../../../epml.js' + +// Components +import '../../components/ChatWelcomePage.js' +import '../../components/ChatHead.js' +import '../../components/ChatPage.js' + +import '@polymer/paper-spinner/paper-spinner-lite.js' + +import '@material/mwc-icon' +import '@material/mwc-button' +import '@material/mwc-dialog' + +const parentEpml = new Epml({ type: 'WINDOW', source: window.parent }) + +class Chat extends LitElement { + static get properties() { + return { + selectedAddress: { type: Object }, + chatTitle: { type: String }, + chatHeads: { type: Array }, + chatHeadsObj: { type: Object }, + chatId: { type: String }, + messages: { type: Array }, + btnDisable: { type: Boolean }, + isLoading: { type: Boolean }, + balance: { type: Number } + } + } + + static get styles() { + return css` + + * { + --mdc-theme-primary: rgb(3, 169, 244); + --paper-input-container-focus-color: var(--mdc-theme-primary); + } + + paper-spinner-lite{ + height: 24px; + width: 24px; + --paper-spinner-color: var(--mdc-theme-primary); + --paper-spinner-stroke-width: 2px; + } + + *, + *:before, + *:after { + box-sizing: border-box; + } + + ul { + list-style: none; + padding: 0; + } + + .container { + margin: 0 auto; + width: 100%; + background: #fff; + } + + .people-list { + width: 20vw; + float: left; + height: 100vh; + overflow-y: hidden; + border-right: 3px #ddd solid; + } + + .people-list .search { + padding: 20px; + } + + .people-list .create-chat { + border-radius: 3px; + border: none; + display: inline-block; + padding: 14px; + color: white; + background: #6a6c75; + width: 90%; + font-size: 15px; + text-align: center; + cursor: pointer; + } + + .people-list .create-chat:hover { + opacity: .8; + box-shadow: 0 3px 5px rgba(0, 0, 0, .2); + } + + .people-list ul { + padding: 0; + height: 85vh; + overflow-y: auto; + overflow-x: hidden; + } + + .chat { + width: 80vw; + height: 100vh; + float: left; + background: #fff; + border-top-right-radius: 5px; + border-bottom-right-radius: 5px; + color: #434651; + box-sizing: border-box; + } + + .chat .new-message-bar { + display: flex; + flex: 0 1 auto; + align-items: center; + justify-content: space-between; + padding: 0px 25px; + font-size: 14px; + font-weight: 500; + top: 0; + position: absolute; + left: 20vw; + right: 0; + z-index: 5; + background: #6a6c75; + color: white; + border-radius: 0 0 8px 8px; + min-height: 25px; + transition: opacity .15s; + text-transform: capitalize; + opacity: .85; + cursor: pointer; + } + + .chat .new-message-bar:hover { + opacity: .75; + transform: translateY(-1px); + box-shadow: 0 3px 7px rgba(0, 0, 0, .2); + } + + .hide-new-message-bar { + display: none !important; + } + + .chat .chat-history { + position: absolute; + top: 0; + right: 0; + bottom: 100%; + left: 20vw; + border-bottom: 2px solid white; + overflow-y: hidden; + height: 100vh; + box-sizing: border-box; + } + + .chat .chat-message { + padding: 10px; + height: 10%; + display: inline-block; + width: 100%; + background-color: #eee; + } + + .chat .chat-message textarea { + width: 90%; + border: none; + font-size: 16px; + padding: 10px 20px; + border-radius: 5px; + resize: none; + } + + .chat .chat-message button { + float: right; + color: #94c2ed; + font-size: 16px; + text-transform: uppercase; + border: none; + cursor: pointer; + font-weight: bold; + background: #f2f5f8; + padding: 10px; + margin-top: 4px; + margin-right: 4px; + } + + .chat .chat-message button:hover { + color: #75b1e8; + } + + .online, + .offline, + .me { + margin-right: 3px; + font-size: 10px; + } + + .clearfix:after { + visibility: hidden; + display: block; + font-size: 0; + content: " "; + clear: both; + height: 0; + } + .red { + --mdc-theme-primary: red; + } + + h2 { + margin:0; + } + + h2, h3, h4, h5 { + color:#333; + font-weight: 400; + } + + [hidden] { + display: hidden !important; + visibility: none !important; + } + .details { + display: flex; + font-size: 18px; + } + .title { + font-weight:600; + font-size:12px; + line-height: 32px; + opacity: 0.66; + } + .input { + width: 100%; + border: none; + display: inline-block; + font-size: 16px; + padding: 10px 20px; + border-radius: 5px; + resize: none; + background: #eee; + } + .textarea { + width: 100%; + border: none; + display: inline-block; + font-size: 16px; + padding: 10px 20px; + border-radius: 5px; + height: 120px; + resize: none; + background: #eee; + } + ` + } + + constructor() { + super() + this.selectedAddress = {} + this.config = { + user: { + node: { + + } + } + } + this.chatTitle = "" + this.chatHeads = [] + this.chatHeadsObj = {} + this.chatId = '' + this.balance = 1 + this.messages = [] + this.btnDisable = false + this.isLoading = false + + this.showNewMesssageBar = this.showNewMesssageBar.bind(this) + this.hideNewMesssageBar = this.hideNewMesssageBar.bind(this) + } + + render() { + return html` + + +
+
+ +
    + ${this.isEmptyArray(this.chatHeads) ? "Loading..." : this.renderChatHead(this.chatHeads)} +
+
+ +
+
this.scrollToBottom()}> + New Message + (Click to scroll down) keyboard_arrow_down +
+ +
+ ${window.parent.location.pathname !== "/app/q-chat" ? html`${this.renderChatPage(this.chatId)}` : html`${this.renderChatWelcomePage()}`} +
+
+ + + +
+

New Private Message

+
+
+ +

Type the name or address of who you want to chat with to send a private message!

+ + +

+ +

+ + + ${this.isLoading === false ? "Send" : html``} + + + Close + +
+
+ + ` + } + + renderChatWelcomePage() { + return html`` + } + + renderChatHead(chatHeadArr) { + + let tempUrl = document.location.href + let splitedUrl = decodeURI(tempUrl).split('?') + let activeChatHeadUrl = splitedUrl[1] === undefined ? '' : splitedUrl[1] + + return chatHeadArr.map(eachChatHead => { + return html`` + }) + } + + renderChatPage(chatId) { + // Check for the chat ID from and render chat messages + // Else render Welcome to Q-CHat + + // TODO: DONE: Do the above in the ChatPage + + return html`` + } + + setChatHeads(chatObj) { + + let groupList = chatObj.groups.map(group => group.groupId === 0 ? { groupId: group.groupId, url: `group/${group.groupId}`, groupName: "Qortal General Chat", timestamp: group.timestamp === undefined ? 2 : group.timestamp } : { ...group, timestamp: group.timestamp === undefined ? 1 : group.timestamp, url: `group/${group.groupId}` }) + let directList = chatObj.direct.map(dc => { + return { ...dc, url: `direct/${dc.address}` } + }) + const compareNames = (a, b) => { + return a.groupName.localeCompare(b.groupName) + } + groupList.sort(compareNames) + let chatHeadMasterList = [...groupList, ...directList] + + const compareArgs = (a, b) => { + return b.timestamp - a.timestamp + } + + this.chatHeads = chatHeadMasterList.sort(compareArgs) + } + + getChatHeadFromState(chatObj) { + + if (chatObj === undefined) { + return + } else { + + this.chatHeadsObj = chatObj + this.setChatHeads(chatObj) + } + } + + + firstUpdated() { + + const stopKeyEventPropagation = (e) => { + e.stopPropagation(); + return false; + } + + this.shadowRoot.getElementById('sendTo').addEventListener('keydown', stopKeyEventPropagation); + this.shadowRoot.getElementById('messageBox').addEventListener('keydown', stopKeyEventPropagation); + + const getDataFromURL = () => { + let tempUrl = document.location.href + let splitedUrl = decodeURI(tempUrl).split('?') + let urlData = splitedUrl[1] + if (urlData !== undefined) { + + this.chatId = urlData + } + } + + const runFunctionsAfterPageLoad = () => { + // Functions to exec after render while waiting for page info... + getDataFromURL() + + try { + let key = `${window.parent.reduxStore.getState().app.selectedAddress.address.substr(0, 10)}_chat-heads` + let localChatHeads = localStorage.getItem(key) + this.setChatHeads(JSON.parse(localChatHeads)) + } catch (e) { + // TODO: Could add error handling in case there's a weird one... (-_-) + return + } + + // Clear Interval... + if (this.selectedAddress.address !== undefined) { + clearInterval(runFunctionsAfterPageLoadInterval) + return + } + } + + let runFunctionsAfterPageLoadInterval = setInterval(runFunctionsAfterPageLoad, 100); + + window.addEventListener("contextmenu", (event) => { + + event.preventDefault(); + this._textMenu(event) + }); + + window.addEventListener("click", () => { + + parentEpml.request('closeCopyTextMenu', null) + parentEpml.request('closeFramePasteMenu', null) + }); + + window.onkeyup = (e) => { + if (e.keyCode === 27) { + + parentEpml.request('closeCopyTextMenu', null) + parentEpml.request('closeFramePasteMenu', null) + + } + } + + let configLoaded = false + parentEpml.ready().then(() => { + parentEpml.subscribe('selected_address', async selectedAddress => { + this.selectedAddress = {} + selectedAddress = JSON.parse(selectedAddress) + if (!selectedAddress || Object.entries(selectedAddress).length === 0) return + this.selectedAddress = selectedAddress + }) + parentEpml.subscribe('config', c => { + if (!configLoaded) { + configLoaded = true + } + this.config = JSON.parse(c) + }) + parentEpml.subscribe('chat_heads', chatHeads => { + chatHeads = JSON.parse(chatHeads) + // setTimeout(() => { + this.getChatHeadFromState(chatHeads) + // }, 5000) + }) + parentEpml.request('apiCall', { + url: `/addresses/balance/${window.parent.reduxStore.getState().app.selectedAddress.address}` + }).then(res => { + this.balance = res + }) + parentEpml.subscribe('copy_menu_switch', async value => { + + if (value === 'false' && window.getSelection().toString().length !== 0) { + + this.clearSelection() + } + }) + }) + + parentEpml.imReady() + } + + _sendMessage() { + + this.isLoading = true + + const recipient = this.shadowRoot.getElementById('sendTo').value + const messageBox = this.shadowRoot.getElementById('messageBox') + const messageText = messageBox.value + + if (recipient.length === 0) { + this.isLoading = false + } else if (messageText.length === 0) { + this.isLoading = false + } else { + this.sendMessage() + } + } + + async sendMessage(e) { + + this.isLoading = true + + const _recipient = this.shadowRoot.getElementById('sendTo').value + const messageBox = this.shadowRoot.getElementById('messageBox') + const messageText = messageBox.value + let recipient + + const validateName = async (receiverName) => { + + let myRes + let myNameRes = await parentEpml.request('apiCall', { + type: 'api', + url: `/names/${receiverName}` + }) + + if (myNameRes.error === 401) { + myRes = false + } else { + myRes = myNameRes + } + + return myRes + } + + const myNameRes = await validateName(_recipient) + if (!myNameRes) { + + recipient = _recipient + } else { + + recipient = myNameRes.owner + } + + let _reference = new Uint8Array(64); + window.crypto.getRandomValues(_reference); + + let sendTimestamp = Date.now() + + let reference = window.parent.Base58.encode(_reference) + + const getAddressPublicKey = async () => { + let isEncrypted + let _publicKey + + let addressPublicKey = await parentEpml.request('apiCall', { + type: 'api', + url: `/addresses/publickey/${recipient}` + }) + + if (addressPublicKey.error === 102) { + _publicKey = false + parentEpml.request('showSnackBar', "Invalid Name / Address, Check the name / address and retry...") + this.isLoading = false + } else if (addressPublicKey !== false) { + isEncrypted = 1 + _publicKey = addressPublicKey + sendMessageRequest(isEncrypted, _publicKey) + } else { + isEncrypted = 0 + _publicKey = this.selectedAddress.address + sendMessageRequest(isEncrypted, _publicKey) + } + }; + + const sendMessageRequest = async (isEncrypted, _publicKey) => { + + let chatResponse = await parentEpml.request('chat', { + type: 18, + nonce: this.selectedAddress.nonce, + params: { + timestamp: sendTimestamp, + recipient: recipient, + recipientPublicKey: _publicKey, + message: messageText, + lastReference: reference, + proofOfWorkNonce: 0, + isEncrypted: isEncrypted, + isText: 1 + } + }) + + _computePow(chatResponse) + } + + const _computePow = async (chatBytes) => { + + const _chatBytesArray = Object.keys(chatBytes).map(function (key) { return chatBytes[key]; }); + const chatBytesArray = new Uint8Array(_chatBytesArray) + + + const chatBytesHash = new window.parent.Sha256().process(chatBytesArray).finish().result + + const hashPtr = window.parent.sbrk(32, window.parent.heap); + const hashAry = new Uint8Array(window.parent.memory.buffer, hashPtr, 32); + hashAry.set(chatBytesHash); + + const difficulty = this.balance === 0 ? 14 : 8; + + const workBufferLength = 8 * 1024 * 1024; + const workBufferPtr = window.parent.sbrk(workBufferLength, window.parent.heap); + + let nonce = window.parent.computePow(hashPtr, workBufferPtr, workBufferLength, difficulty) + + let _response = await parentEpml.request('sign_chat', { + nonce: this.selectedAddress.nonce, + chatBytesArray: chatBytesArray, + chatNonce: nonce + }) + + getSendChatResponse(_response) + } + + const getSendChatResponse = (response) => { + + if (response === true) { + messageBox.value = "" + parentEpml.request('showSnackBar', "Message Sent Successfully!") + this.isLoading = false + } else if (response.error) { + parentEpml.request('showSnackBar', response.message) + this.isLoading = false + } else { + parentEpml.request('showSnackBar', "Sending failed, Please retry...") + this.isLoading = false + } + } + + // Exec.. + getAddressPublicKey() + } + + _textMenu(event) { + + const getSelectedText = () => { + var text = ""; + if (typeof window.getSelection != "undefined") { + text = window.getSelection().toString(); + } else if (typeof this.shadowRoot.selection != "undefined" && this.shadowRoot.selection.type == "Text") { + text = this.shadowRoot.selection.createRange().text; + } + return text; + } + + const checkSelectedTextAndShowMenu = () => { + let selectedText = getSelectedText(); + if (selectedText && typeof selectedText === 'string') { + + let _eve = { pageX: event.pageX, pageY: event.pageY, clientX: event.clientX, clientY: event.clientY } + + let textMenuObject = { selectedText: selectedText, eventObject: _eve, isFrame: true } + + parentEpml.request('openCopyTextMenu', textMenuObject) + } + } + + checkSelectedTextAndShowMenu() + } + + _textArea(e) { + + if (e.keyCode === 13 && !e.shiftKey) this._sendMessage() + } + + clearSelection() { + + window.getSelection().removeAllRanges() + window.parent.getSelection().removeAllRanges() + } + + onPageNavigation(pageUrl) { + parentEpml.request('setPageUrl', pageUrl) + } + + isEmptyArray(arr) { + if (!arr) { return true } + return arr.length === 0 + } + + scrollToBottom() { + + const viewElement = this.shadowRoot.querySelector('chat-page').shadowRoot.querySelector('chat-scroller').shadowRoot.getElementById('viewElement'); + viewElement.scroll({ top: viewElement.scrollHeight, left: 0, behavior: 'smooth' }) + } + + showNewMesssageBar() { + this.shadowRoot.getElementById('newMessageBar').classList.remove('hide-new-message-bar') + } + + hideNewMesssageBar() { + this.shadowRoot.getElementById('newMessageBar').classList.add('hide-new-message-bar') + } +} + +window.customElements.define('q-chat', Chat) diff --git a/qortal-ui-plugins/plugins/core/minting/index.html b/qortal-ui-plugins/plugins/core/minting/index.html new file mode 100644 index 00000000..f58f39db --- /dev/null +++ b/qortal-ui-plugins/plugins/core/minting/index.html @@ -0,0 +1,45 @@ + + + + + + + + + + + + + + \ No newline at end of file diff --git a/qortal-ui-plugins/plugins/core/minting/minting-info.src.js b/qortal-ui-plugins/plugins/core/minting/minting-info.src.js new file mode 100644 index 00000000..5462ee54 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/minting/minting-info.src.js @@ -0,0 +1,733 @@ +import { LitElement, html, css } from "lit-element"; +import { render } from "lit-html"; +import { Epml } from "../../../epml.js"; + +import "@material/mwc-icon"; +import "@material/mwc-button"; +import "@material/mwc-dialog"; +import "@material/mwc-textfield"; + +const parentEpml = new Epml({ type: 'WINDOW', source: window.parent }); + +class MintingInfo extends LitElement { + static get properties() { + return { + selectedAddress: { type: Object }, + loading: { type: Boolean }, + adminInfo: { type: Array }, + nodeInfo: { type: Array }, + sampleBlock: { type: Array }, + addressInfo: { type: Array }, + addressLevel: { type: Array }, + } + } + + static get styles() { + return css` + @keyframes moveInBottom { + 0% { + opacity: 0; + transform: translateY(30px); + } + + 100% { + opacity: 1; + transform: translate(0); + } + } + + [hidden] { + display: hidden !important; + visibility: none !important; + } + + h4 { + font-weight:600; + font-size:20px; + line-height: 28px; + color:#000000; + } + + .header-title { + display: block; + overflow: hidden; + font-size: 40px; + color: black; + font-weight: 400; + text-align: center; + white-space: pre-wrap; + overflow-wrap: break-word; + word-break: break-word; + cursor: inherit; + margin-top: 2rem; + } + + .level-black { + font-size: 32px; + color: black; + font-weight: 400; + text-align: center; + margin-top: 2rem; + } + + .level-blue { + display: inline-block; + font-size: 32px; + color: #03a9f4; + font-weight: 400; + text-align: center; + margin-top: 2rem; + } + + .sub-main { + position: relative; + text-align: center; + width: 100%; + } + + .center-box { + position: absolute; + width: 100%; + top: 50%; + left: 50%; + transform: translate(-50%, 0%); + text-align: center; + } + + .content-box { + border: 1px solid #a1a1a1; + border-radius: 10px; + padding: 10px 25px; + text-align: center; + display: inline-block; + min-width: 250px; + margin-left: 10px; + margin-bottom: 5px; + } + + .help-icon { + color: #f44336; + } + + .details { + display: flex; + font-size: 18px; + } + + .title { + font-weight:600; + font-size:20px; + line-height: 28px; + opacity: 0.66; + color: #03a9f4; + } + + .sub-title { + font-weight:600; + font-size:20px; + line-height: 24px; + opacity: 0.66; + } + + .input { + width: 90%; + border: none; + display: inline-block; + font-size: 20px; + padding: 10px 20px; + border-radius: 5px; + resize: none; + background: #eee; + } + + .textarea { + width: 90%; + border: none; + display: inline-block; + font-size: 16px; + padding: 10px 20px; + border-radius: 5px; + height: 120px; + resize: none; + background: #eee; + } + + .not-minter { + display: inline-block; + font-size: 32px; + color: #03a9f4; + font-weight: 400; + margin-top: 2rem; + } + + .blue { + color: #03a9f4; + } + + .black { + color: #000000; + } + + .red { + color: #f44336; + } + + .red-button { + --mdc-theme-primary: red; + --mdc-theme-on-primary: white; + } + + mwc-button.red-button { + --mdc-theme-primary: red; + --mdc-theme-on-primary: white; + } + ` + } + + constructor() { + super() + this.selectedAddress = window.parent.reduxStore.getState().app.selectedAddress.address + this.adminInfo = []; + this.nodeInfo = []; + this.sampleBlock = []; + this.addressInfo = []; + this.addressLevel = []; + } + + render() { + if (this.renderMintingPage() === "false") { + return html` +
+
+ General Minting Details +
+
+
+
+
+ Blockchain Statistics +
+

+
+ Avg. Qortal Blocktime +
+

${this._averageBlockTime()} Seconds

+
+
+ Avg. Blocks Per Day +
+

${this._timeCalc()} Blocks

+
+
+ Avg. Created QORT Per Day +
+

${this._dayReward()} QORT

+



+
+ ${this.renderActivateHelp()} +
+

+
+
+ + + +
+

Activate Your Account

+
+
+
+

Introduction


+ To activate your account you must have an transaction in your account. + You can ask within Q-Chat or wherever else and someone will happily send you some small QORT. + After somebody send you some QORT, logout and after login again. Your account is activated. +
+ Close +
+
+ `} else { + return html` +
+
+ General Minting Details +
+
+
+
+
+ Blockchain Statistics +
+

+
+ Avg. Qortal Blocktime +
+

${this._averageBlockTime()} Seconds

+
+
+ Avg. Blocks Per Day +
+

${this._timeCalc()} Blocks

+
+
+ Avg. Created QORT Per Day +
+

${this._dayReward()} QORT

+



+
+ ${this.renderMintingHelp()} +
+

+
+ Current Status +
+

${this._mintingStatus()}

+
+
+ Current Level +
+

Level ${this.addressInfo.level}

+
+
+ Blocks To Next Level +
+

${this._levelUpBlocks()} Blocks

+

+
+ If you continue minting 24/7 you will reach level
${this._levelUp()}
in
${this._levelUpDays()}
days !
+



+
+ Minting Rewards Info +
+

+
+ Current Tier +
+

${this._currentTier()}

+
+
+ Total Minters in The Tier +
+

${this._countLevels()} Minters

+
+
+ Tier Share Per Block +
+

${this._tierPercent()} %

+
+
+ Est. Reward Per Block +
+

${this._countReward()} QORT

+
+
+ Est. Reward Per Day +
+

${this._countRewardDay()} QORT

+
+
+
+ + + +
+

Become A Minter

+
+
+
+

Introduction


+ In Qortal, in order to become a minter and begin earning QORT rewards with your increase in Minter Level, you must first become ‘sponsored’. + A sponsor in Qortal is any other minter of level 5 or higher, or a Qortal Founder. You will obtain a sponsorship key from the sponsor, and use that key to get to level 1. + Once you have reached level 1, you will be able to create your own minting key and start earning rewards for helping secure the Qortal Blockchain. +
+
+

Sponsorship


+ Your sponsor will issue you a ‘Sponsorship Key’ which you will use to add to your node, and begin minting (for no rewards until reaching level 1.) + Once you reach level 1, you create/assign your own ‘Minting Key’ and begin earning rewards. You have XXXX blocks remaining in your sponsorship period. +
+ Simply reach out to a minter in Qortal who is high enough level to issue a sponsorship key, obtain that key, then come back here and input the key to begin your minting journey ! +
+ Close +
+ +
+ `} + } + + firstUpdated() { + const getAdminInfo = () => { + parentEpml.request("apiCall", {url: `/admin/info`}).then((res) => { + setTimeout(() => {this.adminInfo = res;}, 1); + }); + setTimeout(getAdminInfo, 30000); + }; + + const getNodeInfo = () => { + parentEpml.request("apiCall", {url: `/admin/status`}).then((res) => { + this.nodeInfo = res; + // Now look up the sample block + getSampleBlock() + }); + setTimeout(getNodeInfo, 30000); + }; + + const getSampleBlock = () => { + let callBlock = parseFloat(this.nodeInfo.height) - 10000; + parentEpml.request("apiCall", {url: `/blocks/byheight/${callBlock}`}).then((res) => { + setTimeout(() => {this.sampleBlock = res;}, 1); + }); + }; + + const getAddressInfo = () => { + parentEpml.request('apiCall', {url: `/addresses/${window.parent.reduxStore.getState().app.selectedAddress.address}`}).then((res) => { + setTimeout(() => {this.addressInfo = res;}, 1); + }); + setTimeout(getAddressInfo, 30000); + }; + + const getAddressLevel = () => { + parentEpml.request('apiCall', {url: `/addresses/online/levels`}).then((res) => { + setTimeout(() => {this.addressLevel = res;}, 1); + }); + setTimeout(getAddressLevel, 30000); + }; + + let configLoaded = false; + + parentEpml.ready().then(() => { + parentEpml.subscribe('selected_address', async selectedAddress => { + this.selectedAddress = {} + selectedAddress = JSON.parse(selectedAddress) + if (!selectedAddress || Object.entries(selectedAddress).length === 0) return + this.selectedAddress = selectedAddress + }) + }); + + parentEpml.ready().then(() => { + parentEpml.subscribe("config", async c => { + if (!configLoaded) { + setTimeout(getAdminInfo, 1); + setTimeout(getNodeInfo, 1); + setTimeout(getAddressInfo, 1); + setTimeout(getAddressLevel, 1); + configLoaded = true; + } + this.config = JSON.parse(c); + }) + parentEpml.subscribe('copy_menu_switch', async value => { + if (value === 'false' && window.getSelection().toString().length !== 0) this.clearSelection(); + }) + }); + + parentEpml.imReady(); + } + + renderMintingPage() { + if (this.addressInfo.error === 124) { + return "false" + } else { + return "true" + } + } + + renderActivateHelp() { + if (this.renderMintingPage() === "false") { + return html `Activate Account Details
==>
Not Activated
this.shadowRoot.querySelector("#activateAccountDialog").show()}>help_outline Press For Help`; + } else { + return "No Details"; + } + } + _averageBlockTime() { + let avgBlockString = (this.adminInfo.currentTimestamp - this.sampleBlock.timestamp).toString(); + let averageTimeString = ((avgBlockString / 1000) / 10000).toFixed(2); + let averageBlockTimeString = (averageTimeString).toString(); + return "" + averageBlockTimeString; + } + + _timeCalc() { + let timeString = (this.adminInfo.currentTimestamp - this.sampleBlock.timestamp).toString(); + let averageString = ((timeString / 1000) / 10000).toFixed(2); + let averageBlockDay = (86400 / averageString).toFixed(2); + let averageBlockDayString = (averageBlockDay).toString(); + return "" + averageBlockDayString; + } + + _dayReward() { + let rewardString = (this._timeCalc() * this._blockReward()).toFixed(2); + let rewardDayString = (rewardString).toString(); + return "" + rewardDayString ; + } + + _mintingStatus() { + if (this.nodeInfo.isMintingPossible === true && this.nodeInfo.isSynchronizing === true) { + this.cssMinting = "blue" + return "Minting" + } else if (this.nodeInfo.isMintingPossible === true && this.nodeInfo.isSynchronizing === false) { + this.cssMinting = "blue" + return "Minting" + } else if (this.nodeInfo.isMintingPossible === false && this.nodeInfo.isSynchronizing === true) { + this.cssMinting = "red" + return `(Synchronizing... ${this.nodeInfo.syncPercent !== undefined ? this.nodeInfo.syncPercent + '%' : ''})` + } else if (this.nodeInfo.isMintingPossible === false && this.nodeInfo.isSynchronizing === false) { + this.cssMinting = "red" + return "Not Minting" + } else { + return "No Status" + } + } + + renderMintingHelp() { + if (this._mintingStatus() === "Not Minting") { + return html `Minting Account Details
==>
Not A Minter
this.shadowRoot.querySelector("#becomeMinterDialog").show()}>help_outline Press For Help`; + } else { + return "Minting Account Details"; + } + } + + _levelUpDays() { + let countDays = ((this._blocksNeed() - (this.addressInfo.blocksMinted + this.addressInfo.blocksMintedAdjustment)) / this._timeCalc()).toFixed(2); + let countString = (countDays).toString(); + return "" + countString; + } + + _levelUpBlocks() { + let countBlocksString = (this._blocksNeed() - (this.addressInfo.blocksMinted + this.addressInfo.blocksMintedAdjustment)).toString(); + return "" + countBlocksString; + } + + _blocksNeed() { + if (this.addressInfo.level === 0) { + return "7200" + } else if (this.addressInfo.level === 1) { + return "72000" + } else if (this.addressInfo.level === 2) { + return "201600" + } else if (this.addressInfo.level === 3) { + return "374400" + } else if (this.addressInfo.level === 4) { + return "618400" + } else if (this.addressInfo.level === 5) { + return "964000" + } else if (this.addressInfo.level === 6) { + return "1482400" + } else if (this.addressInfo.level === 7) { + return "2173600" + } else if (this.addressInfo.level === 8) { + return "3037600" + } else if (this.addressInfo.level === 9) { + return "4074400" + } + } + + _levelUp() { + if (this.addressInfo.level === 0) { + return "1" + } else if (this.addressInfo.level === 1) { + return "2" + } else if (this.addressInfo.level === 2) { + return "3" + } else if (this.addressInfo.level === 3) { + return "4" + } else if (this.addressInfo.level === 4) { + return "5" + } else if (this.addressInfo.level === 5) { + return "6" + } else if (this.addressInfo.level === 6) { + return "7" + } else if (this.addressInfo.level === 7) { + return "8" + } else if (this.addressInfo.level === 8) { + return "9" + } else if (this.addressInfo.level === 9) { + return "10" + } + } + + _currentTier() { + if (this.addressInfo.level === 0) { + return "Tier 0 (Level 0)" + } else if (this.addressInfo.level === 1) { + return "Tier 1 (Level 1 + 2)" + } else if (this.addressInfo.level === 2) { + return "Tier 1 (Level 1 + 2)" + } else if (this.addressInfo.level === 3) { + return "Tier 2 (Level 3 + 4)" + } else if (this.addressInfo.level === 4) { + return "Tier 2 (Level 3 + 4)" + } else if (this.addressInfo.level === 5) { + return "Tier 3 (Level 5 + 6)" + } else if (this.addressInfo.level === 6) { + return "Tier 3 (Level 5 + 6)" + } else if (this.addressInfo.level === 7) { + return "Tier 4 (Level 7 + 8)" + } else if (this.addressInfo.level === 8) { + return "Tier 4 (Level 7 + 8)" + } else if (this.addressInfo.level === 9) { + return "Tier 5 (Level 9 + 10)" + } else if (this.addressInfo.level === 10) { + return "Tier 5 (Level 9 + 10)" + } + } + + _tierPercent() { + if (this.addressInfo.level === 0) { + return "0" + } else if (this.addressInfo.level === 1) { + return "5" + } else if (this.addressInfo.level === 2) { + return "5" + } else if (this.addressInfo.level === 3) { + return "10" + } else if (this.addressInfo.level === 4) { + return "10" + } else if (this.addressInfo.level === 5) { + return "15" + } else if (this.addressInfo.level === 6) { + return "15" + } else if (this.addressInfo.level === 7) { + return "20" + } else if (this.addressInfo.level === 8) { + return "20" + } else if (this.addressInfo.level === 9) { + return "25" + } else if (this.addressInfo.level === 10) { + return "25" + } + } + + _blockReward() { + if (this.nodeInfo.height < 259201) { + return "5.00" + } else if (this.nodeInfo.height < 518401) { + return "4.75" + } else if (this.nodeInfo.height < 777601) { + return "4.50" + } else if (this.nodeInfo.height < 1036801) { + return "4.25" + } else if (this.nodeInfo.height < 1296001) { + return "4.00" + } else if (this.nodeInfo.height < 1555201) { + return "3.75" + } else if (this.nodeInfo.height < 1814401) { + return "3.50" + } else if (this.nodeInfo.height < 2073601) { + return "3.25" + } else if (this.nodeInfo.height < 2332801) { + return "3.00" + } else if (this.nodeInfo.height < 2592001) { + return "2.75" + } else if (this.nodeInfo.height < 2851201) { + return "2.50" + } else if (this.nodeInfo.height < 3110401) { + return "2.25" + } else { + return "2.00" + } + } + + _countLevels() { + if (this.addressInfo.level === 0) { + return "0" + } else if (this.addressInfo.level === 1) { + let countTier10 = (this.addressLevel[0].count + this.addressLevel[1].count).toString(); + return "" + countTier10; + } else if (this.addressInfo.level === 2) { + let countTier11 = (this.addressLevel[0].count + this.addressLevel[1].count).toString(); + return "" + countTier11; + } else if (this.addressInfo.level === 3) { + let countTier20 = (this.addressLevel[2].count + this.addressLevel[3].count).toString(); + return "" + countTier20; + } else if (this.addressInfo.level === 4) { + let countTier21 = (this.addressLevel[2].count + this.addressLevel[3].count).toString(); + return "" + countTier21; + } else if (this.addressInfo.level === 5) { + let countTier30 = (this.addressLevel[4].count + this.addressLevel[5].count).toString(); + return "" + countTier30; + } else if (this.addressInfo.level === 6) { + let countTier31 = (this.addressLevel[4].count + this.addressLevel[5].count).toString(); + return "" + countTier31; + } else if (this.addressInfo.level === 10) { + let countTier101 = (this.addressLevel[6].count).toString(); + return "" + countTier101; + } + } + + _countReward() { + if (this.addressInfo.level === 0) { + return "0" + } else if (this.addressInfo.level === 1) { + let countReward10 = ((this._blockReward() / 100 * this._tierPercent()) / (this.addressLevel[0].count + this.addressLevel[1].count)).toFixed(8); + let countReward11 = (countReward10).toString(); + return "" + countReward11; + } else if (this.addressInfo.level === 2) { + let countReward20 = ((this._blockReward() / 100 * this._tierPercent()) / (this.addressLevel[0].count + this.addressLevel[1].count)).toFixed(8); + let countReward21 = (countReward20).toString(); + return "" + countReward21; + } else if (this.addressInfo.level === 3) { + let countReward30 = ((this._blockReward() / 100 * this._tierPercent()) / (this.addressLevel[2].count + this.addressLevel[3].count)).toFixed(8); + let countReward31 = (countReward30).toString(); + return "" + countReward31; + } else if (this.addressInfo.level === 4) { + let countReward40 = ((this._blockReward() / 100 * this._tierPercent()) / (this.addressLevel[2].count + this.addressLevel[3].count)).toFixed(8); + let countReward41 = (countReward40).toString(); + return "" + countReward41; + } else if (this.addressInfo.level === 5) { + let countReward50 = ((this._blockReward() / 100 * this._tierPercent()) / (this.addressLevel[4].count + this.addressLevel[5].count)).toFixed(8); + let countReward51 = (countReward50).toString(); + return "" + countReward51; + } else if (this.addressInfo.level === 6) { + let countReward60 = ((this._blockReward() / 100 * this._tierPercent()) / (this.addressLevel[4].count + this.addressLevel[5].count)).toFixed(8); + let countReward61 = (countReward60).toString(); + return "" + countReward61; + } else if (this.addressInfo.level === 10) { + let countReward100 = ((this._blockReward() / 100 * this._tierPercent()) / this.addressLevel[6].count).toFixed(8); + let countReward101 = (countReward100).toString(); + return "" + countReward101; + } + } + + _countRewardDay() { + if (this.addressInfo.level === 0) { + return "0" + } else if (this.addressInfo.level === 1) { + let countRewardDay10 = ((this._blockReward() / 100 * this._tierPercent()) / (this.addressLevel[0].count + this.addressLevel[1].count) * this._timeCalc()).toFixed(8); + let countRewardDay11 = (countRewardDay10).toString(); + return "" + countRewardDay11; + } else if (this.addressInfo.level === 2) { + let countRewardDay20 = ((this._blockReward() / 100 * this._tierPercent()) / (this.addressLevel[0].count + this.addressLevel[1].count) * this._timeCalc()).toFixed(8); + let countRewardDay21 = (countRewardDay20).toString(); + return "" + countRewardDay21; + } else if (this.addressInfo.level === 3) { + let countRewardDay30 = ((this._blockReward() / 100 * this._tierPercent()) / (this.addressLevel[2].count + this.addressLevel[3].count) * this._timeCalc()).toFixed(8); + let countRewardDay31 = (countRewardDay30).toString(); + return "" + countRewardDay31; + } else if (this.addressInfo.level === 4) { + let countRewardDay40 = ((this._blockReward() / 100 * this._tierPercent()) / (this.addressLevel[2].count + this.addressLevel[3].count) * this._timeCalc()).toFixed(8); + let countRewardDay41 = (countRewardDay40).toString(); + return "" + countRewardDay41; + } else if (this.addressInfo.level === 5) { + let countRewardDay50 = ((this._blockReward() / 100 * this._tierPercent()) / (this.addressLevel[4].count + this.addressLevel[5].count) * this._timeCalc()).toFixed(8); + let countRewardDay51 = (countRewardDay50).toString(); + return "" + countRewardDay51; + } else if (this.addressInfo.level === 6) { + let countRewardDay60 = ((this._blockReward() / 100 * this._tierPercent()) / (this.addressLevel[4].count + this.addressLevel[5].count) * this._timeCalc()).toFixed(8); + let countRewardDay61 = (countRewardDay60).toString(); + return "" + countRewardDay61; + } else if (this.addressInfo.level === 10) { + let countRewardDay100 = ((this._blockReward() / 100 * this._tierPercent()) / (this.addressLevel[6].count) * this._timeCalc()).toFixed(8); + let countRewardDay101 = (countRewardDay100).toString(); + return "" + countRewardDay101; + } + } + + clearSelection() { + window.getSelection().removeAllRanges() + window.parent.getSelection().removeAllRanges() + } + + isEmptyArray(arr) { + if (!arr) return true; + return arr.length === 0; + } +} + +window.customElements.define('minting-info', MintingInfo) diff --git a/qortal-ui-plugins/plugins/core/name-registration/README b/qortal-ui-plugins/plugins/core/name-registration/README new file mode 100644 index 00000000..afc54a40 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/name-registration/README @@ -0,0 +1 @@ +This needs work. Should have been done simpler. diff --git a/qortal-ui-plugins/plugins/core/name-registration/index.html b/qortal-ui-plugins/plugins/core/name-registration/index.html new file mode 100644 index 00000000..4ec6e455 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/name-registration/index.html @@ -0,0 +1,45 @@ + + + + + + + + + + + + + + \ No newline at end of file diff --git a/qortal-ui-plugins/plugins/core/name-registration/name-registration.src.js b/qortal-ui-plugins/plugins/core/name-registration/name-registration.src.js new file mode 100644 index 00000000..fefacde8 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/name-registration/name-registration.src.js @@ -0,0 +1,332 @@ +// import '@webcomponents/webcomponentsjs/webcomponents-loader.js' +// /* Es6 browser but transpi;led code */ +// import '@webcomponents/webcomponentsjs/custom-elements-es5-adapter.js' + +import { LitElement, html, css } from 'lit-element' +import { Epml } from '../../../epml.js' + +import '@material/mwc-icon' +import '@material/mwc-button' +import '@material/mwc-textfield' +import '@material/mwc-dialog' + +import '@polymer/paper-spinner/paper-spinner-lite.js' +import '@vaadin/vaadin-grid/vaadin-grid.js' +import '@vaadin/vaadin-grid/theme/material/all-imports.js' + +const parentEpml = new Epml({ type: 'WINDOW', source: window.parent }) + +class NameRegistration extends LitElement { + static get properties() { + return { + loading: { type: Boolean }, + names: { type: Array }, + recipientPublicKey: { type: String }, + selectedAddress: { type: Object }, + btnDisable: { type: Boolean }, + registerNameLoading: { type: Boolean }, + error: { type: Boolean }, + message: { type: String }, + removeError: { type: Boolean }, + removeMessage: { type: String } + } + } + + static get styles() { + return css` + * { + --mdc-theme-primary: rgb(3, 169, 244); + --mdc-theme-secondary: var(--mdc-theme-primary); + --paper-input-container-focus-color: var(--mdc-theme-primary); + } + #name-registration-page { + background: #fff; + padding: 12px 24px; + } + + .divCard { + border: 1px solid #eee; + padding: 1em; + /** box-shadow: 0 1px 1px 0 rgba(0,0,0,0.14), 0 2px 1px -1px rgba(0,0,0,0.12), 0 1px 2px 0 rgba(0,0,0,0.20); **/ + box-shadow: 0 .3px 1px 0 rgba(0,0,0,0.14), 0 1px 1px -1px rgba(0,0,0,0.12), 0 1px 2px 0 rgba(0,0,0,0.20); + } + + h2 { + margin:0; + } + + h2, h3, h4, h5 { + color:#333; + font-weight: 400; + } + ` + } + + constructor() { + super() + this.selectedAddress = {} + this.names = [] + this.recipientPublicKey = '' + this.btnDisable = false + this.registerNameLoading = false + } + + render() { + return html` +
+
+

Name Registration

+ this.shadowRoot.querySelector('#registerNameDialog').show()}>addRegister Name +
+ +
+

Registered Names

+ + + + + ${this.isEmptyArray(this.names) ? html` + No names registered by this account! + `: ''} +
+ + + +
Register a Name!
+
+ +

+ +

+
+ + + Doing something delicious   + + + + ${this.message} + +
+ + + Register + + + Close + +
+
+ ` + } + + // getNamesGrid() { + + // const myGrid = this.shadowRoot.querySelector('#namesGrid') + + // myGrid.addEventListener('click', (e) => { + // this.tempMintingAccount = myGrid.getEventContext(e).item + + // this.shadowRoot.querySelector('#removeRewardShareDialog').show() + // }) + + // } + + + firstUpdated() { + + // Call getNamesGrid + // this.getNamesGrid() + + window.addEventListener("contextmenu", (event) => { + + event.preventDefault(); + this._textMenu(event) + }); + + window.addEventListener("click", () => { + + parentEpml.request('closeCopyTextMenu', null) + }); + + window.onkeyup = (e) => { + if (e.keyCode === 27) { + + parentEpml.request('closeCopyTextMenu', null) + } + } + + const fetchNames = () => { + // console.log('=========================================') + parentEpml.request('apiCall', { + url: `/names/address/${this.selectedAddress.address}?limit=0&reverse=true` + }).then(res => { + + setTimeout(() => { this.names = res }, 1) + }) + setTimeout(fetchNames, this.config.user.nodeSettings.pingInterval) + } + + let configLoaded = false + + parentEpml.ready().then(() => { + parentEpml.subscribe('selected_address', async selectedAddress => { + this.selectedAddress = {} + selectedAddress = JSON.parse(selectedAddress) + if (!selectedAddress || Object.entries(selectedAddress).length === 0) return + this.selectedAddress = selectedAddress + }) + parentEpml.subscribe('config', c => { + if (!configLoaded) { + setTimeout(fetchNames, 1) + configLoaded = true + } + this.config = JSON.parse(c) + }) + parentEpml.subscribe('copy_menu_switch', async value => { + + if (value === 'false' && window.getSelection().toString().length !== 0) { + + this.clearSelection() + } + }) + }) + + + parentEpml.imReady() + } + + clearSelection() { + + window.getSelection().removeAllRanges() + window.parent.getSelection().removeAllRanges() + } + + async registerName(e) { + this.error = false + this.message = '' + const nameInput = this.shadowRoot.getElementById("nameInput").value + const descInput = this.shadowRoot.getElementById("descInput").value + + // Check for valid...^ + this.registerNameLoading = true + + // Get Last Ref + const getLastRef = async () => { + let myRef = await parentEpml.request('apiCall', { + type: 'api', + url: `/addresses/lastreference/${this.selectedAddress.address}` + }) + return myRef + }; + + // Get Account Details + const validateName = async () => { + let isValid = await parentEpml.request('apiCall', { + type: 'api', + url: `/names/${nameInput}` + }) + + return isValid + }; + + const validateReceiver = async () => { + let nameInfo = await validateName(); + let lastRef = await getLastRef(); + + if (nameInfo.error === 401) { + this.error = false + this.message = '' + let myTransaction = await makeTransactionRequest(lastRef) + getTxnRequestResponse(myTransaction) + } else { + this.error = true + this.message = `Name Already Exists!` + } + } + + // Make Transaction Request + const makeTransactionRequest = async (lastRef) => { + + let myTxnrequest = await parentEpml.request('transaction', { + type: 3, + nonce: this.selectedAddress.nonce, + params: { + name: nameInput, + value: descInput, + lastReference: lastRef, + } + }) + + return myTxnrequest + } + + // FAILED txnResponse = {success: false, message: "User declined transaction"} + // SUCCESS txnResponse = { success: true, data: true } + + const getTxnRequestResponse = (txnResponse) => { + + if (txnResponse.success === false && txnResponse.message) { + this.error = true + this.message = txnResponse.message + throw new Error(txnResponse) + } else if (txnResponse.success === true && !txnResponse.data.error) { + this.message = 'Name Registration Successful!' + this.error = false + } else { + this.error = true + this.message = txnResponse.data.message + throw new Error(txnResponse) + } + } + + validateReceiver() + + this.registerNameLoading = false + } + + _textMenu(event) { + + const getSelectedText = () => { + var text = ""; + if (typeof window.getSelection != "undefined") { + text = window.getSelection().toString(); + } else if (typeof this.shadowRoot.selection != "undefined" && this.shadowRoot.selection.type == "Text") { + text = this.shadowRoot.selection.createRange().text; + } + return text; + } + + const checkSelectedTextAndShowMenu = () => { + let selectedText = getSelectedText(); + if (selectedText && typeof selectedText === 'string') { + + let _eve = { pageX: event.pageX, pageY: event.pageY, clientX: event.clientX, clientY: event.clientY } + + let textMenuObject = { selectedText: selectedText, eventObject: _eve, isFrame: true } + + parentEpml.request('openCopyTextMenu', textMenuObject) + } + } + + checkSelectedTextAndShowMenu() + } + + isEmptyArray(arr) { + if (!arr) { return true } + return arr.length === 0 + } +} + +window.customElements.define('name-registration', NameRegistration) diff --git a/qortal-ui-plugins/plugins/core/node-management/index.html b/qortal-ui-plugins/plugins/core/node-management/index.html new file mode 100644 index 00000000..a1a60432 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/node-management/index.html @@ -0,0 +1,45 @@ + + + + + + + + + + + + + + \ No newline at end of file diff --git a/qortal-ui-plugins/plugins/core/node-management/node-management.src.js b/qortal-ui-plugins/plugins/core/node-management/node-management.src.js new file mode 100644 index 00000000..6f995616 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/node-management/node-management.src.js @@ -0,0 +1,506 @@ +import { LitElement, html, css } from "lit-element"; +import { render } from 'lit-html' +import { Epml } from "../../../epml.js"; + +import "@polymer/paper-spinner/paper-spinner-lite.js"; +import "@vaadin/vaadin-grid/vaadin-grid.js"; +import "@vaadin/vaadin-grid/theme/material/all-imports.js"; +import "@material/mwc-icon"; +import "@material/mwc-textfield"; +import "@material/mwc-button"; +import "@material/mwc-dialog"; + +const parentEpml = new Epml({ type: "WINDOW", source: window.parent }); + +class NodeManagement extends LitElement { + static get properties() { + return { + loading: { type: Boolean }, + upTime: { type: String }, + mintingAccounts: { type: Array }, + peers: { type: Array }, + addMintingAccountLoading: { type: Boolean }, + removeMintingAccountLoading: { type: Boolean }, + addPeerLoading: { type: Boolean }, + confPeerLoading: { type: Boolean }, + addMintingAccountKey: { type: String }, + removeMintingAccountKey: { type: String }, + addPeerMessage: { type: String }, + confPeerMessage: { type: String }, + addMintingAccountMessage: { type: String }, + removeMintingAccountMessage: { type: String }, + tempMintingAccount: { type: Object }, + nodeConfig: { type: Object }, + nodeDomain: { type: String }, + }; + } + + static get styles() { + return css` + * { + --mdc-theme-primary: rgb(3, 169, 244); + --paper-input-container-focus-color: var(--mdc-theme-primary); + } + + paper-spinner-lite { + height: 24px; + width: 24px; + --paper-spinner-color: var(--mdc-theme-primary); + --paper-spinner-stroke-width: 2px; + } + + #node-management-page { + background: #fff; + } + + mwc-textfield { + width: 100%; + } + + .red { + --mdc-theme-primary: #F44336; + } + + .red-button { + --mdc-theme-primary: red; + --mdc-theme-on-primary: white; + } + + mwc-button.red-button { + --mdc-theme-primary: red; + --mdc-theme-on-primary: white; + } + + .node-card { + /* margin:12px; */ + padding: 12px 24px; + background: #fff; + border-radius: 2px; + box-shadow: 11; + } + + h2 { + margin: 0; + } + + h2, + h3, + h4, + h5 { + color: #333; + font-weight: 400; + } + + [hidden] { + display: hidden !important; + visibility: none !important; + } + .details { + display: flex; + font-size: 18px; + } + `; + } + + constructor() { + super(); + this.upTime = ""; + this.mintingAccounts = []; + this.peers = []; + this.addPeerLoading = false; + this.confPeerLoading = false; + this.addMintingAccountLoading = false; + this.removeMintingAccountLoading = false; + this.addMintingAccountKey = ""; + this.addPeerMessage = ""; + this.confPeerMessage = ""; + this.addMintingAccountMessage = ""; + this.tempMintingAccount = {}; + this.config = { + user: { + node: {}, + }, + }; + this.nodeConfig = {}; + this.nodeDomain = ""; + } + + render() { + return html` +
+
+

Node management for: ${this.nodeDomain}

+
Node has been online for: ${this.upTime}
+ +

+
+
+

+ Node's minting accounts +

+ + this.shadowRoot + .querySelector("#addMintingAccountDialog") + .show()} + >addAdd minting account +
+ + + +
+ If you would like to mint with your own account you will need to + create a rewardshare transaction to yourself (with rewardshare + percent set to 0), and then mint with the rewardshare key it + gives you. +
+
+ +
+ + ${this.addMintingAccountMessage}   + + + + Doing something delicious   + + +
+ + Add + + + Close + +
+ + + + + { + render(html` this.removeMintingAccount(data.item.publicKey)}>createRemove`, root) + }}> + + + ${this.isEmptyArray(this.mintingAccounts) ? html` No minting accounts found for this node ` : ""} +
+ +
+
+
+

+ Peers connected to node + (${this.peers.length}) +

+ this.shadowRoot.querySelector("#addPeerDialog").show()}>addAdd peer +
+ + +
Type the peer you wish to add's address below
+
+ +
+ ${this.addPeerMessage}   + + + +
+ + Add + + + Close + +
+ + + + + + + { + render(html` this.removePeer(data.item.address, data.index)}>deleteRemove this.forceSyncPeer(data.item.address, data.index)}>Force Sync`, root) + }}> + + + ${this.isEmptyArray(this.peers) ? html` Node has no connected peers ` : ""} +
+
+
+
+ `; + } + + forceSyncPeer (peerAddress, rowIndex) { + parentEpml + .request("apiCall", { + url: `/admin/forcesync`, + method: "POST", + body: peerAddress, + }) + .then((res) => { + parentEpml.request('showSnackBar', "Starting Sync with Peer: " + peerAddress ); + }); + } + + removePeer(peerAddress, rowIndex) { + parentEpml + .request("apiCall", { + url: `/peers`, + method: "DELETE", + body: peerAddress, + }) + .then((res) => { + parentEpml.request('showSnackBar', "Successfully removed Peer: " + peerAddress ); + this.peers.splice(rowIndex, 1); + }); + } + + onPageNavigation(pageUrl) { + parentEpml.request("setPageUrl", pageUrl); + } + + addPeer(e) { + this.addPeerLoading = true; + const addPeerAddress = this.shadowRoot.querySelector("#addPeerAddress") + .value; + + parentEpml + .request("apiCall", { + url: `/peers`, + method: "POST", + body: addPeerAddress, + }) + .then((res) => { + this.addPeerMessage = res.message; + this.addPeerLoading = false; + }); + } + + addMintingAccount(e) { + this.addMintingAccountLoading = true; + this.addMintingAccountMessage = "Loading..."; + + this.addMintingAccountKey = this.shadowRoot.querySelector( + "#addMintingAccountKey" + ).value; + + parentEpml + .request("apiCall", { + url: `/admin/mintingaccounts`, + method: "POST", + body: this.addMintingAccountKey, + }) + .then((res) => { + if (res === true) { + this.updateMintingAccounts(); + this.addMintingAccountKey = ""; + this.addMintingAccountMessage = "Minting Node Added Successfully!"; + this.addMintingAccountLoading = false; + } else { + this.addMintingAccountKey = ""; + this.addMintingAccountMessage = "Failed to Add Minting Node!"; // Corrected an error here thanks to crow (-_-) + this.addMintingAccountLoading = false; + } + }); + } + + updateMintingAccounts() { + parentEpml.request("apiCall", { + url: `/admin/mintingaccounts`, + }).then((res) => { + setTimeout(() => this.mintingAccounts = res, 1); + }); + } + + _textMenu(event) { + + const getSelectedText = () => { + var text = ""; + if (typeof window.getSelection != "undefined") { + text = window.getSelection().toString(); + } else if (typeof this.shadowRoot.selection != "undefined" && this.shadowRoot.selection.type == "Text") { + text = this.shadowRoot.selection.createRange().text; + } + return text; + } + + const checkSelectedTextAndShowMenu = () => { + let selectedText = getSelectedText(); + if (selectedText && typeof selectedText === 'string') { + + let _eve = { pageX: event.pageX, pageY: event.pageY, clientX: event.clientX, clientY: event.clientY } + + let textMenuObject = { selectedText: selectedText, eventObject: _eve, isFrame: true } + + parentEpml.request('openCopyTextMenu', textMenuObject) + } + } + + checkSelectedTextAndShowMenu() + } + + removeMintingAccount(publicKey) { + this.removeMintingAccountLoading = true; + + parentEpml.request("apiCall", { + url: `/admin/mintingaccounts`, + method: "DELETE", + body: publicKey, + }).then((res) => { + if (res === true) { + this.updateMintingAccounts(); + this.removeMintingAccountLoading = false; + parentEpml.request('showSnackBar', "Successfully Removed Minting Account!"); + } else { + this.removeMintingAccountLoading = false; + parentEpml.request('showSnackBar', "Failed to Remove Minting Account!"); + } + }); + } + + firstUpdated() { + + // Call updateMintingAccounts + this.updateMintingAccounts(); + + window.addEventListener("contextmenu", (event) => { + event.preventDefault(); + this._textMenu(event) + }); + window.addEventListener("click", () => { + parentEpml.request('closeCopyTextMenu', null) + }); + window.onkeyup = (e) => { + if (e.keyCode === 27) parentEpml.request('closeCopyTextMenu', null) + } + + // Calculate HH MM SS from Milliseconds... + const convertMsToTime = (milliseconds) => { + let day, hour, minute, seconds; + seconds = Math.floor(milliseconds / 1000); + minute = Math.floor(seconds / 60); + seconds = seconds % 60; + hour = Math.floor(minute / 60); + minute = minute % 60; + day = Math.floor(hour / 24); + hour = hour % 24; + if (isNaN(day)) { + return "offline"; + } + return day + "d " + hour + "h " + minute + "m"; + }; + + const getNodeUpTime = () => { + parentEpml + .request("apiCall", { + url: `/admin/uptime`, + }) + .then((res) => { + this.upTime = ""; + setTimeout(() => { + this.upTime = convertMsToTime(res); + }, 1); + }); + + setTimeout(getNodeUpTime, this.config.user.nodeSettings.pingInterval); + }; + + const updatePeers = () => { + parentEpml + .request("apiCall", { + url: `/peers`, + }) + .then((res) => { + setTimeout(() => { + this.peers = res; + }, 1); + }); + + setTimeout(updatePeers, this.config.user.nodeSettings.pingInterval); + }; + + const getNodeConfig = () => { + parentEpml.request("getNodeConfig").then((res) => { + setTimeout(() => { + this.nodeConfig = res; + }, 1); + let myNode = window.parent.reduxStore.getState().app.nodeConfig + .knownNodes[window.parent.reduxStore.getState().app.nodeConfig.node]; + this.nodeDomain = myNode.domain + ":" + myNode.port; + }); + + setTimeout(getNodeConfig, 1000); + }; + + let configLoaded = false; + parentEpml.ready().then(() => { + parentEpml.subscribe("config", async c => { + if (!configLoaded) { + setTimeout(getNodeUpTime, 1); + setTimeout(updatePeers, 1); + setTimeout(this.updateMintingAccounts, 1); + setTimeout(getNodeConfig, 1); + configLoaded = true; + } + this.config = JSON.parse(c); + }) + parentEpml.subscribe('copy_menu_switch', async value => { + if (value === 'false' && window.getSelection().toString().length !== 0) this.clearSelection(); + }) + }); + parentEpml.imReady(); + } + + clearSelection() { + window.getSelection().removeAllRanges() + window.parent.getSelection().removeAllRanges() + } + + isEmptyArray(arr) { + if (!arr) return true; + return arr.length === 0; + } +} + +window.customElements.define("node-management", NodeManagement); diff --git a/qortal-ui-plugins/plugins/core/reward-share/index.html b/qortal-ui-plugins/plugins/core/reward-share/index.html new file mode 100644 index 00000000..72f42a9d --- /dev/null +++ b/qortal-ui-plugins/plugins/core/reward-share/index.html @@ -0,0 +1,45 @@ + + + + + + + + + + + + + + \ No newline at end of file diff --git a/qortal-ui-plugins/plugins/core/reward-share/reward-share.src.js b/qortal-ui-plugins/plugins/core/reward-share/reward-share.src.js new file mode 100644 index 00000000..7f2778a5 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/reward-share/reward-share.src.js @@ -0,0 +1,562 @@ +import { LitElement, html, css } from 'lit-element' +import { render } from 'lit-html' +import { Epml } from '../../../epml.js' + +import '@material/mwc-icon' +import '@material/mwc-button' +import '@material/mwc-textfield' +import '@material/mwc-dialog' +import '@material/mwc-slider' + +import '@polymer/paper-spinner/paper-spinner-lite.js' +import '@vaadin/vaadin-grid/vaadin-grid.js' +import '@vaadin/vaadin-grid/theme/material/all-imports.js' + +const parentEpml = new Epml({ type: 'WINDOW', source: window.parent }) + +class RewardShare extends LitElement { + static get properties() { + return { + loading: { type: Boolean }, + rewardShares: { type: Array }, + recipientPublicKey: { type: String }, + selectedAddress: { type: Object }, + btnDisable: { type: Boolean }, + createRewardShareLoading: { type: Boolean }, + removeRewardShareLoading: { type: Boolean }, + rewardSharePercentage: { type: Number }, + error: { type: Boolean }, + message: { type: String } + } + } + + static get styles() { + return css` + * { + --mdc-theme-primary: rgb(3, 169, 244); + --mdc-theme-secondary: var(--mdc-theme-primary); + --paper-input-container-focus-color: var(--mdc-theme-primary); + } + #reward-share-page { + background: #fff; + padding: 12px 24px; + } + + h2 { + margin:0; + } + + h2, h3, h4, h5 { + color:#333; + font-weight: 400; + } + + .red { + --mdc-theme-primary: #F44336; + } + ` + } + + constructor() { + super() + this.selectedAddress = {} + this.rewardShares = [] + this.recipientPublicKey = '' + this.rewardSharePercentage = 0 + this.btnDisable = false + this.createRewardShareLoading = false + this.removeRewardShareLoading = false + } + + render() { + return html` +
+
+

Rewardshares involving this account

+ this.shadowRoot.querySelector('#createRewardShareDialog').show()}>addCreate reward share +
+ + + + + + { + render(html`${this.renderRemoveRewardShareButton(data.item)}`, root) + }}> + + + +
Level 1 - 4 can create a Self Share and Level 5 or above can create a Reward Share!
+
+ +

+ Reward share percentage: ${this.rewardSharePercentage} + +

+ + +
+ + + Doing something delicious   + + + + ${this.message} + +
+ + + + Add + + + Close + +
+ + ${this.isEmptyArray(this.rewardShares) ? html` + Account is not involved in any reward shares + `: ''} +
+ ` + } + + renderRemoveRewardShareButton(rewardShareObject) { + + if (rewardShareObject.mintingAccount === this.selectedAddress.address) { + + return html` this.removeRewardShare(rewardShareObject)}>createRemove` + } else { + return "" + } + } + + firstUpdated() { + + window.addEventListener("contextmenu", (event) => { + + event.preventDefault(); + this._textMenu(event) + }); + + window.addEventListener("click", () => { + + parentEpml.request('closeCopyTextMenu', null) + }); + + window.onkeyup = (e) => { + if (e.keyCode === 27) { + + parentEpml.request('closeCopyTextMenu', null) + } + } + + const textBox = this.shadowRoot.getElementById("recipientPublicKey") + + const updateRewardshares = () => { + + parentEpml.request('apiCall', { + url: `/addresses/rewardshares?involving=${this.selectedAddress.address}` + }).then(res => { + setTimeout(() => { this.rewardShares = res }, 1) + }) + setTimeout(updateRewardshares, this.config.user.nodeSettings.pingInterval) + } + + let configLoaded = false + + parentEpml.ready().then(() => { + + parentEpml.subscribe('selected_address', async selectedAddress => { + this.selectedAddress = {} + selectedAddress = JSON.parse(selectedAddress) + if (!selectedAddress || Object.entries(selectedAddress).length === 0) return + this.selectedAddress = selectedAddress + }) + parentEpml.subscribe('config', c => { + if (!configLoaded) { + setTimeout(updateRewardshares, 1) + configLoaded = true + } + this.config = JSON.parse(c) + }) + parentEpml.subscribe('copy_menu_switch', async value => { + + if (value === 'false' && window.getSelection().toString().length !== 0) { + + this.clearSelection() + } + }) + parentEpml.subscribe('frame_paste_menu_switch', async res => { + + res = JSON.parse(res) + if (res.isOpen === false && this.isPasteMenuOpen === true) { + + this.pasteToTextBox(textBox) + this.isPasteMenuOpen = false + } + }) + }) + + parentEpml.imReady() + + textBox.addEventListener('contextmenu', (event) => { + + const getSelectedText = () => { + var text = ""; + if (typeof window.getSelection != "undefined") { + text = window.getSelection().toString(); + } else if (typeof this.shadowRoot.selection != "undefined" && this.shadowRoot.selection.type == "Text") { + text = this.shadowRoot.selection.createRange().text; + } + return text; + } + + const checkSelectedTextAndShowMenu = () => { + let selectedText = getSelectedText(); + if (selectedText && typeof selectedText === 'string') { + // ... + } else { + + this.pasteMenu(event) + this.isPasteMenuOpen = true + + // Prevent Default and Stop Event Bubbling + event.preventDefault() + event.stopPropagation() + + } + } + + checkSelectedTextAndShowMenu() + + }) + } + + async createRewardShare(e) { + + this.error = false + this.message = '' + const recipientPublicKey = this.shadowRoot.getElementById("recipientPublicKey").value + const percentageShare = this.shadowRoot.getElementById("rewardSharePercentageSlider").value + + // Check for valid...^ + this.createRewardShareLoading = true + + let recipientAddress = window.parent.base58PublicKeyToAddress(recipientPublicKey) + + // Get Last Ref + const getLastRef = async () => { + + let myRef = await parentEpml.request('apiCall', { + type: 'api', + url: `/addresses/lastreference/${this.selectedAddress.address}` + }) + return myRef + }; + + // Get Account Details + const getAccountDetails = async () => { + + let myAccountDetails = await parentEpml.request('apiCall', { + type: 'api', + url: `/addresses/${this.selectedAddress.address}` + }) + return myAccountDetails + }; + + // Get Reward Relationship if it already exists + const getRewardShareRelationship = async (minterAddr) => { + + let isRewardShareExisting = false + let myRewardShareArray = await parentEpml.request('apiCall', { + type: 'api', + url: `/addresses/rewardshares?minters=${minterAddr}&recipients=${recipientAddress}` + }) + + isRewardShareExisting = myRewardShareArray.length !== 0 ? true : false + return isRewardShareExisting + + // THOUGHTS: At this point, I think I dont wanna further do any check... + // myRewardShareArray.forEach(rewsh => { + // if (rewsh.mintingAccount) { + + // } + // }) + } + + // Validate Reward Share by Level + const validateReceiver = async () => { + + let accountDetails = await getAccountDetails(); + let lastRef = await getLastRef(); + let isExisting = await getRewardShareRelationship(this.selectedAddress.address) + + // Check for creating self share at different levels (also adding check for flags...) + if (accountDetails.flags === 1) { + this.error = false + this.message = '' + let myTransaction = await makeTransactionRequest(lastRef) + if (isExisting === true) { + + this.error = true + this.message = `Cannot Create Multiple Reward Shares!` + } else { + // Send the transaction for confirmation by the user + this.error = false + this.message = '' + getTxnRequestResponse(myTransaction) + } + } else if (accountDetails.address === recipientAddress) { + + if (accountDetails.level >= 1 && accountDetails.level <= 4) { + + this.error = false + this.message = '' + let myTransaction = await makeTransactionRequest(lastRef) + if (isExisting === true) { + + this.error = true + this.message = `Cannot Create Multiple Self Shares!` + } else { + // Send the transaction for confirmation by the user + this.error = false + this.message = '' + getTxnRequestResponse(myTransaction) + } + } else if (accountDetails.level >= 5) { + + this.error = false + this.message = '' + let myTransaction = await makeTransactionRequest(lastRef) + if (isExisting === true) { + + this.error = true + this.message = `Cannot Create Multiple Self Shares!` + } else { + // Send the transaction for confirmation by the user + this.error = false + this.message = '' + getTxnRequestResponse(myTransaction) + } + } else { + this.error = true + this.message = `CANNOT CREATE SELF SHARE! at level ${accountDetails.level}` + } + } else { //Check for creating reward shares + + if (accountDetails.level >= 5) { + + this.error = false + this.message = '' + let myTransaction = await makeTransactionRequest(lastRef) + if (isExisting === true) { + + this.error = true + this.message = `Cannot Create Multiple Reward Shares!` + } else { + // Send the transaction for confirmation by the user + this.error = false + this.message = '' + getTxnRequestResponse(myTransaction) + } + } else { + + this.error = true + this.message = `CANNOT CREATE REWARD SHARE! at level ${accountDetails.level}` + } + } + } + + // Make Transaction Request + const makeTransactionRequest = async (lastRef) => { + + let mylastRef = lastRef + + let myTxnrequest = await parentEpml.request('transaction', { + type: 38, + nonce: this.selectedAddress.nonce, + params: { + recipientPublicKey, + percentageShare, + lastReference: mylastRef, + } + }) + + return myTxnrequest + } + + // FAILED txnResponse = {success: false, message: "User declined transaction"} + // SUCCESS txnResponse = { success: true, data: true } + + const getTxnRequestResponse = (txnResponse) => { + + if (txnResponse.success === false && txnResponse.message) { + this.error = true + this.message = txnResponse.message + throw new Error(txnResponse) + } else if (txnResponse.success === true && !txnResponse.data.error) { + this.message = 'Reward Share Successful!' + this.error = false + } else { + this.error = true + this.message = txnResponse.data.message + throw new Error(txnResponse) + } + } + + validateReceiver() + + this.createRewardShareLoading = false + } + + async removeRewardShare(rewardShareObject) { + + const myPercentageShare = -1 + + // Check for valid...^ + this.removeRewardShareLoading = true + + // Get Last Ref + const getLastRef = async () => { + + let myRef = await parentEpml.request('apiCall', { + type: 'api', + url: `/addresses/lastreference/${this.selectedAddress.address}` + }) + return myRef + }; + + // Remove Reward Share + const removeReceiver = async () => { + + let lastRef = await getLastRef(); + + let myTransaction = await makeTransactionRequest(lastRef) + getTxnRequestResponse(myTransaction) + + } + + // Make Transaction Request + const makeTransactionRequest = async (lastRef) => { + + let mylastRef = lastRef + + let myTxnrequest = await parentEpml.request('transaction', { + type: 381, + nonce: this.selectedAddress.nonce, + params: { + rewardShareKeyPairPublicKey: rewardShareObject.rewardSharePublicKey, + recipient: rewardShareObject.recipient, + percentageShare: myPercentageShare, + lastReference: mylastRef, + } + }) + + return myTxnrequest + } + + // FAILED txnResponse = {success: false, message: "User declined transaction"} + // SUCCESS txnResponse = { success: true, data: true } + + const getTxnRequestResponse = (txnResponse) => { + + if (txnResponse.success === false && txnResponse.message) { + + this.removeRewardShareLoading = false + parentEpml.request('showSnackBar', txnResponse.message) + throw new Error(txnResponse) + } else if (txnResponse.success === true && !txnResponse.data.error) { + + this.removeRewardShareLoading = false + parentEpml.request('showSnackBar', 'Reward Share Removed Successfully!') + } else { + + this.removeRewardShareLoading = false + parentEpml.request('showSnackBar', txnResponse.data.message) + throw new Error(txnResponse) + } + } + + removeReceiver() + + } + + pasteToTextBox(textBox) { + + // Return focus to the window + window.focus() + + navigator.clipboard.readText().then(clipboardText => { + + textBox.value += clipboardText + textBox.focus() + }); + } + + pasteMenu(event) { + + let eventObject = { pageX: event.pageX, pageY: event.pageY, clientX: event.clientX, clientY: event.clientY } + parentEpml.request('openFramePasteMenu', eventObject) + } + + _textMenu(event) { + + const getSelectedText = () => { + var text = ""; + if (typeof window.getSelection != "undefined") { + text = window.getSelection().toString(); + } else if (typeof this.shadowRoot.selection != "undefined" && this.shadowRoot.selection.type == "Text") { + text = this.shadowRoot.selection.createRange().text; + } + return text; + } + + const checkSelectedTextAndShowMenu = () => { + let selectedText = getSelectedText(); + if (selectedText && typeof selectedText === 'string') { + + let _eve = { pageX: event.pageX, pageY: event.pageY, clientX: event.clientX, clientY: event.clientY } + + let textMenuObject = { selectedText: selectedText, eventObject: _eve, isFrame: true } + + parentEpml.request('openCopyTextMenu', textMenuObject) + } + } + + checkSelectedTextAndShowMenu() + } + + isEmptyArray(arr) { + if (!arr) { return true } + return arr.length === 0 + } + + clearSelection() { + + window.getSelection().removeAllRanges() + window.parent.getSelection().removeAllRanges() + } +} + +window.customElements.define('reward-share', RewardShare) diff --git a/qortal-ui-plugins/plugins/core/send-coin/index.html b/qortal-ui-plugins/plugins/core/send-coin/index.html new file mode 100644 index 00000000..01fb5b1a --- /dev/null +++ b/qortal-ui-plugins/plugins/core/send-coin/index.html @@ -0,0 +1,44 @@ + + + + + + + + + + + + + + \ No newline at end of file diff --git a/qortal-ui-plugins/plugins/core/send-coin/send-coin.src.js b/qortal-ui-plugins/plugins/core/send-coin/send-coin.src.js new file mode 100644 index 00000000..39c2be81 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/send-coin/send-coin.src.js @@ -0,0 +1,858 @@ +import { LitElement, html, css } from 'lit-element' +import { render } from 'lit-html' +import { Epml } from '../../../epml' + +import '@material/mwc-button' +import '@material/mwc-textfield' +import '@material/mwc-select' +import '@material/mwc-list/mwc-list-item.js' +import '@material/mwc-slider' +import '@polymer/paper-progress/paper-progress.js' + +const parentEpml = new Epml({ type: 'WINDOW', source: window.parent }) + +class SendMoneyPage extends LitElement { + static get properties() { + return { + addresses: { type: Array }, + amount: { type: Number }, + errorMessage: { type: String }, + sendMoneyLoading: { type: Boolean }, + btnDisable: { type: Boolean }, + data: { type: Object }, + selectedAddress: { type: Object }, + recipient: { type: String }, + isValidAmount: { type: Boolean }, + balance: { type: Number }, + qortBalance: { type: Number }, + btcBalance: { type: Number }, + ltcBalance: { type: Number }, + dogeBalance: { type: Number }, + selectedCoin: { type: String }, + satFeePerByte: { type: Number }, + } + } + + static get observers() { + return ['_kmxKeyUp(amount)'] + } + + static get styles() { + return css` + * { + --mdc-theme-primary: rgb(3, 169, 244); + --mdc-theme-secondary: var(--mdc-theme-primary); + --paper-input-container-focus-color: var(--mdc-theme-primary); + } + #sendMoneyWrapper { + /* Extra 3px for left border */ + /* overflow: hidden; */ + } + + /* #sendMoneyWrapper>* { + width: auto !important; + padding: 0 15px; + } */ + + #sendMoneyWrapper paper-button { + float: right; + } + + #sendMoneyWrapper .buttons { + /* --paper-button-ink-color: var(--paper-green-500); + color: var(--paper-green-500); */ + width: auto !important; + } + + .address-item { + --paper-item-focused: { + background: transparent; + } + --paper-item-focused-before: { + opacity: 0; + } + } + + .address-balance { + font-size: 42px; + font-weight: 100; + } + + .show-transactions { + cursor: pointer; + } + + .address-icon { + border-radius: 50%; + border: 5px solid; + /*border-left: 4px solid;*/ + padding: 8px; + } + + mwc-textfield { + margin: 0; + } + + .selectedBalance { + display: none; + font-size: 14px; + } + + .selectedBalance .balance { + font-size: 22px; + font-weight: 100; + } + + .coinName::before { + content: ""; + display: inline-block; + height: 25px; + width: 25px; + position: absolute; + background-repeat: no-repeat; + background-size: cover; + left: 10px; + top: 10px; + } + .qort.coinName:before { + background-image: url('/img/qort.png'); + } + .btc.coinName:before { + background-image: url('/img/btc.png'); + } + .ltc.coinName:before { + background-image: url('/img/ltc.png'); + } + .doge.coinName:before { + background-image: url('/img/doge.png'); + } + .coinName { + display: inline-block; + height: 25px; + padding-left: 25px; + } + + paper-progress { + --paper-progress-active-color: var(--mdc-theme-primary); + } + ` + } + + render() { + return html` +
+
+ +
+

Send Coin

+ +
+ available for transfer from + +
+
+
+

+ this.selectCoin(e)} style="min-width: 130px; max-width:100%; width:100%;"> + QORT + BTC + LTC + DOGE + +

+

+ { + this._checkAmount(e) + }} + type="number" + auto-validate="false" + value="${this.amount}" + > + +

+

+ +

+ +
+

Fee per byte: ${(this.satFeePerByte / 1e8).toFixed(8)} ${this.selectedCoin === 'invalid' ? 'QORT' : this.selectedCoin.toLocaleUpperCase()}

+ + +
+ +

${this.errorMessage}

+

${this.successMessage}

+ + ${this.sendMoneyLoading ? html` ` : ''} + +
+
+ this.doSend(e)}>Send   +
+
+
+
+ ` + } + + _floor(num) { + return Math.floor(num) + } + + // Helper Functions (Re-Used in Most part of the UI ) + + /** + * Check and Validate Amount Helper Function + * @param { Event } e + * + * @description Gets called oninput in an input element + */ + + _checkAmount(e) { + const targetAmount = e.target.value + const target = e.target + + if (targetAmount.length === 0) { + this.isValidAmount = false + this.btnDisable = true + + // Quick Hack to lose and regain focus inorder to display error message without user having to click outside the input field + e.target.blur() + e.target.focus() + + e.target.invalid = true + e.target.validationMessage = 'Invalid Amount!' + } else { + this.btnDisable = false + } + + e.target.blur() + e.target.focus() + + e.target.validityTransform = (newValue, nativeValidity) => { + if (newValue.includes('-') === true) { + this.btnDisable = true + target.validationMessage = 'Invalid Amount!' + + return { + valid: false, + } + } else if (!nativeValidity.valid) { + if (newValue.includes('.') === true) { + let myAmount = newValue.split('.') + if (myAmount[1].length > 8) { + this.btnDisable = true + target.validationMessage = 'Invalid Amount!' + } else { + return { + valid: true, + } + } + } + } else { + this.btnDisable = false + } + } + } + + textColor(color) { + return color == 'light' ? 'rgba(255,255,255,0.7)' : 'rgba(0,0,0,0.87)' + } + + pasteToTextBox(elementId) { + // Return focus to the window + window.focus() + + navigator.clipboard.readText().then((clipboardText) => { + let element = this.shadowRoot.getElementById(elementId) + element.value += clipboardText + element.focus() + }) + } + + pasteMenu(event, elementId) { + let eventObject = { pageX: event.pageX, pageY: event.pageY, clientX: event.clientX, clientY: event.clientY, elementId } + parentEpml.request('openFramePasteMenu', eventObject) + } + + doSend(e) { + if (this.selectedCoin === 'invalid') { + parentEpml.request('showSnackBar', 'Invalid Selection!') + } else if (this.selectedCoin === 'qort') { + this.sendQort() + } else if (this.selectedCoin === 'btc') { + this.sendBtc() + } else if (this.selectedCoin === 'ltc') { + this.sendLtc() + } else if (this.selectedCoin === 'doge') { + this.sendDoge() + } + } + + async sendQort() { + const amount = this.shadowRoot.getElementById('amountInput').value + let recipient = this.shadowRoot.getElementById('recipient').value + + this.sendMoneyLoading = true + this.btnDisable = true + + if (parseFloat(amount) + parseFloat(0.001) > parseFloat(this.balance)) { + this.sendMoneyLoading = false + this.btnDisable = false + + parentEpml.request('showSnackBar', 'Insufficient Funds!') + return false + } + + if (parseFloat(amount) <= 0) { + this.sendMoneyLoading = false + this.btnDisable = false + + parentEpml.request('showSnackBar', 'Invalid Amount!') + return false + } + + if (recipient.length === 0) { + this.sendMoneyLoading = false + this.btnDisable = false + + parentEpml.request('showSnackBar', 'Receiver cannot be empty!') + return false + } + + const getLastRef = async () => { + let myRef = await parentEpml.request('apiCall', { + type: 'api', + url: `/addresses/lastreference/${this.selectedAddress.address}`, + }) + return myRef + } + + const validateName = async (receiverName) => { + let myRes + let myNameRes = await parentEpml.request('apiCall', { + type: 'api', + url: `/names/${receiverName}`, + }) + + if (myNameRes.error === 401) { + myRes = false + } else { + myRes = myNameRes + } + + return myRes + } + + const validateAddress = async (receiverAddress) => { + let myAddress = await window.parent.validateAddress(receiverAddress) + return myAddress + } + + const validateReceiver = async (recipient) => { + let lastRef = await getLastRef() + let isAddress + + try { + isAddress = await validateAddress(recipient) + } catch (err) { + isAddress = false + } + + if (isAddress) { + let myTransaction = await makeTransactionRequest(recipient, lastRef) + getTxnRequestResponse(myTransaction) + } else { + let myNameRes = await validateName(recipient) + if (myNameRes !== false) { + let myNameAddress = myNameRes.owner + let myTransaction = await makeTransactionRequest(myNameAddress, lastRef) + getTxnRequestResponse(myTransaction) + } else { + console.error('INVALID_RECEIVER') + this.errorMessage = 'INVALID_RECEIVER' + this.sendMoneyLoading = false + this.btnDisable = false + } + } + } + + const makeTransactionRequest = async (receiver, lastRef) => { + let myReceiver = receiver + let mylastRef = lastRef + + let myTxnrequest = await parentEpml.request('transaction', { + type: 2, + nonce: this.selectedAddress.nonce, + params: { + recipient: myReceiver, + amount: amount, + lastReference: mylastRef, + fee: 0.001, + }, + }) + + return myTxnrequest + } + + const getTxnRequestResponse = (txnResponse) => { + if (txnResponse.success === false && txnResponse.message) { + this.errorMessage = txnResponse.message + this.sendMoneyLoading = false + this.btnDisable = false + throw new Error(txnResponse) + } else if (txnResponse.success === true && !txnResponse.data.error) { + this.shadowRoot.getElementById('amountInput').value = '' + this.shadowRoot.getElementById('recipient').value = '' + this.errorMessage = '' + this.recipient = '' + this.amount = 0 + this.successMessage = 'Transaction Successful!' + this.sendMoneyLoading = false + this.btnDisable = false + } else { + this.errorMessage = txnResponse.data.message + this.sendMoneyLoading = false + this.btnDisable = false + throw new Error(txnResponse) + } + } + + validateReceiver(recipient) + } + + async sendBtc() { + const amount = this.shadowRoot.getElementById('amountInput').value + let recipient = this.shadowRoot.getElementById('recipient').value + const xprv58 = this.selectedAddress.btcWallet.derivedMasterPrivateKey + + this.sendMoneyLoading = true + this.btnDisable = true + + const makeRequest = async () => { + const opts = { + xprv58: xprv58, + receivingAddress: recipient, + bitcoinAmount: amount, + feePerByte: (this.satFeePerByte / 1e8).toFixed(8), + } + const response = await parentEpml.request('sendBtc', opts) + return response + } + + const manageResponse = (response) => { + if (response.length === 64) { + this.shadowRoot.getElementById('amountInput').value = 0 + this.shadowRoot.getElementById('recipient').value = '' + this.errorMessage = '' + this.recipient = '' + this.amount = 0 + this.successMessage = 'Transaction Successful!' + this.sendMoneyLoading = false + this.btnDisable = false + } else if (response === false) { + this.errorMessage = 'Transaction Failed!' + this.sendMoneyLoading = false + this.btnDisable = false + throw new Error(txnResponse) + } else { + this.errorMessage = response.message + this.sendMoneyLoading = false + this.btnDisable = false + throw new Error(response) + } + } + + // Call makeRequest + const res = await makeRequest() + manageResponse(res) + } + + async sendLtc() { + const amount = this.shadowRoot.getElementById('amountInput').value + let recipient = this.shadowRoot.getElementById('recipient').value + const xprv58 = this.selectedAddress.ltcWallet.derivedMasterPrivateKey + + this.sendMoneyLoading = true + this.btnDisable = true + + const makeRequest = async () => { + const opts = { + xprv58: xprv58, + receivingAddress: recipient, + litecoinAmount: amount, + feePerByte: (this.satFeePerByte / 1e8).toFixed(8), + } + const response = await parentEpml.request('sendLtc', opts) + return response + } + + const manageResponse = (response) => { + if (response.length === 64) { + this.shadowRoot.getElementById('amountInput').value = 0 + this.shadowRoot.getElementById('recipient').value = '' + this.errorMessage = '' + this.recipient = '' + this.amount = 0 + this.successMessage = 'Transaction Successful!' + this.sendMoneyLoading = false + this.btnDisable = false + } else if (response === false) { + this.errorMessage = 'Transaction Failed!' + this.sendMoneyLoading = false + this.btnDisable = false + throw new Error(txnResponse) + } else { + this.errorMessage = response.message + this.sendMoneyLoading = false + this.btnDisable = false + throw new Error(response) + } + } + + // Call makeRequest + const res = await makeRequest() + manageResponse(res) + } + + async sendDoge() { + const amount = this.shadowRoot.getElementById('amountInput').value + let recipient = this.shadowRoot.getElementById('recipient').value + const xprv58 = this.selectedAddress.dogeWallet.derivedMasterPrivateKey + + this.sendMoneyLoading = true + this.btnDisable = true + + const makeRequest = async () => { + const opts = { + xprv58: xprv58, + receivingAddress: recipient, + dogecoinAmount: amount, + feePerByte: (this.satFeePerByte / 1e8).toFixed(8), + } + const response = await parentEpml.request('sendDoge', opts) + return response + } + + const manageResponse = (response) => { + if (response.length === 64) { + this.shadowRoot.getElementById('amountInput').value = 0 + this.shadowRoot.getElementById('recipient').value = '' + this.errorMessage = '' + this.recipient = '' + this.amount = 0 + this.successMessage = 'Transaction Successful!' + this.sendMoneyLoading = false + this.btnDisable = false + } else if (response === false) { + this.errorMessage = 'Transaction Failed!' + this.sendMoneyLoading = false + this.btnDisable = false + throw new Error(txnResponse) + } else { + this.errorMessage = response.message + this.sendMoneyLoading = false + this.btnDisable = false + throw new Error(response) + } + } + + // Call makeRequest + const res = await makeRequest() + manageResponse(res) + } + + _textMenu(event) { + const getSelectedText = () => { + var text = '' + if (typeof window.getSelection != 'undefined') { + text = window.getSelection().toString() + } else if (typeof this.shadowRoot.selection != 'undefined' && this.shadowRoot.selection.type == 'Text') { + text = this.shadowRoot.selection.createRange().text + } + return text + } + + const checkSelectedTextAndShowMenu = () => { + let selectedText = getSelectedText() + if (selectedText && typeof selectedText === 'string') { + let _eve = { pageX: event.pageX, pageY: event.pageY, clientX: event.clientX, clientY: event.clientY } + + let textMenuObject = { selectedText: selectedText, eventObject: _eve, isFrame: true } + + parentEpml.request('openCopyTextMenu', textMenuObject) + } + } + + checkSelectedTextAndShowMenu() + } + + updateAccountBalance() { + clearTimeout(this.updateAccountBalanceTimeout) + parentEpml + .request('apiCall', { + url: `/addresses/balance/${this.selectedAddress.address}`, + }) + .then((res) => { + this.qortBalance = res + this.updateAccountBalanceTimeout = setTimeout(() => this.updateAccountBalance(), 4000) + }) + } + + constructor() { + super() + this.recipient = '' + this.errorMessage = '' + this.sendMoneyLoading = false + this.btnDisable = false + this.selectedAddress = {} + this.amount = 0 + this.satFeePerByte = 100000 // TODO: Set to 0.001 QORT (100000 in sats) + this.btcSatMinFee = 20 + this.btcSatMaxFee = 150 + this.btcDefaultFee = 100 // 0.000001 BTC per byte + this.ltcSatMinFee = 10 + this.ltcSatMaxFee = 100 + this.ltcDefaultFee = 30 // 0.0000003 LTC per byte + this.dogeSatMinFee = 100000 + this.dogeSatMaxFee = 1000000 + this.dogeDefaultFee = 500000 // 0.005 DOGE per byte + this.isValidAmount = false + this.qortBalance = 0 + this.btcBalance = 0 + this.ltcBalance = 0 + this.dogeBalance = 0 + this.selectedCoin = 'invalid' + + let configLoaded = false + parentEpml.ready().then(() => { + parentEpml.subscribe('selected_address', async (selectedAddress) => { + this.selectedAddress = {} + selectedAddress = JSON.parse(selectedAddress) + if (!selectedAddress || Object.entries(selectedAddress).length === 0) return + this.selectedAddress = selectedAddress + const addr = selectedAddress.address + + this.updateAccountBalance() + }) + parentEpml.subscribe('config', (c) => { + if (!configLoaded) { + configLoaded = true + } + this.config = JSON.parse(c) + }) + parentEpml.subscribe('copy_menu_switch', async (value) => { + if (value === 'false' && window.getSelection().toString().length !== 0) { + this.clearSelection() + } + }) + parentEpml.subscribe('frame_paste_menu_switch', async (res) => { + res = JSON.parse(res) + if (res.isOpen === false && this.isPasteMenuOpen === true) { + this.pasteToTextBox(res.elementId) + this.isPasteMenuOpen = false + } + }) + }) + } + + firstUpdated() { + // Get BTC Balance + this.updateBTCAccountBalance() + + // Get LTC Balance + this.updateLTCAccountBalance() + + // Get DOGE Balance + this.updateDOGEAccountBalance() + + window.addEventListener('contextmenu', (event) => { + event.preventDefault() + this._textMenu(event) + }) + + window.addEventListener('click', () => { + parentEpml.request('closeCopyTextMenu', null) + }) + + window.onkeyup = (e) => { + if (e.keyCode === 27) { + parentEpml.request('closeCopyTextMenu', null) + } + } + + // TODO: Rewrite the context menu event listener to support more elements (for now, I'll do write everything out manually ) + this.shadowRoot.getElementById('amountInput').addEventListener('contextmenu', (event) => { + const getSelectedText = () => { + var text = '' + if (typeof window.getSelection != 'undefined') { + text = window.getSelection().toString() + } else if (typeof this.shadowRoot.selection != 'undefined' && this.shadowRoot.selection.type == 'Text') { + text = this.shadowRoot.selection.createRange().text + } + return text + } + + const checkSelectedTextAndShowMenu = () => { + let selectedText = getSelectedText() + if (selectedText && typeof selectedText === 'string') { + } else { + this.pasteMenu(event, 'amountInput') + this.isPasteMenuOpen = true + + // Prevent Default and Stop Event Bubbling + event.preventDefault() + event.stopPropagation() + } + } + + checkSelectedTextAndShowMenu() + }) + + this.shadowRoot.getElementById('recipient').addEventListener('contextmenu', (event) => { + const getSelectedText = () => { + var text = '' + if (typeof window.getSelection != 'undefined') { + text = window.getSelection().toString() + } else if (typeof this.shadowRoot.selection != 'undefined' && this.shadowRoot.selection.type == 'Text') { + text = this.shadowRoot.selection.createRange().text + } + return text + } + + const checkSelectedTextAndShowMenu = () => { + let selectedText = getSelectedText() + if (selectedText && typeof selectedText === 'string') { + } else { + this.pasteMenu(event, 'recipient') + this.isPasteMenuOpen = true + + // Prevent Default and Stop Event Bubbling + event.preventDefault() + event.stopPropagation() + } + } + + checkSelectedTextAndShowMenu() + }) + } + + selectCoin(e) { + const coinType = this.shadowRoot.getElementById('coinType').value + this.selectedCoin = coinType + + this.amount = 0 + this.recipient = '' + this.shadowRoot.getElementById('amountInput').value = 0 + this.shadowRoot.getElementById('recipient').value = '' + this.successMessage = '' + this.errorMessage = '' + + if (coinType === 'qort') { + this.shadowRoot.getElementById('balance').textContent = `${this.qortBalance} QORT` + this.shadowRoot.getElementById('address').textContent = this.selectedAddress.address + this.shadowRoot.querySelector('.selectedBalance').style.display = 'block' + this.shadowRoot.getElementById('amountInput').label = 'Amount (QORT)' + this.shadowRoot.getElementById('recipient').label = 'To (address or name)' + this.satFeePerByte = 100000 + } else if (coinType === 'btc') { + this.shadowRoot.getElementById('balance').textContent = `${this.btcBalance} BTC` + this.shadowRoot.getElementById('address').textContent = this.selectedAddress.btcWallet.address + this.shadowRoot.querySelector('.selectedBalance').style.display = 'block' + this.shadowRoot.getElementById('amountInput').label = 'Amount (BTC)' + this.shadowRoot.getElementById('recipient').label = 'To (BTC address)' + this.shadowRoot.getElementById('feeSlider').min = this.btcSatMinFee + this.shadowRoot.getElementById('feeSlider').max = this.btcSatMaxFee + this.satFeePerByte = this.btcDefaultFee + } else if (coinType === 'ltc') { + this.shadowRoot.getElementById('balance').textContent = `${this.ltcBalance} LTC` + this.shadowRoot.getElementById('address').textContent = this.selectedAddress.ltcWallet.address + this.shadowRoot.querySelector('.selectedBalance').style.display = 'block' + this.shadowRoot.getElementById('amountInput').label = 'Amount (LTC)' + this.shadowRoot.getElementById('recipient').label = 'To (LTC address)' + this.shadowRoot.getElementById('feeSlider').min = this.ltcSatMinFee + this.shadowRoot.getElementById('feeSlider').max = this.ltcSatMaxFee + this.satFeePerByte = this.ltcDefaultFee + } else if (coinType === 'doge') { + this.shadowRoot.getElementById('balance').textContent = `${this.dogeBalance} DOGE` + this.shadowRoot.getElementById('address').textContent = this.selectedAddress.dogeWallet.address + this.shadowRoot.querySelector('.selectedBalance').style.display = 'block' + this.shadowRoot.getElementById('amountInput').label = 'Amount (DOGE)' + this.shadowRoot.getElementById('recipient').label = 'To (DOGE address)' + this.shadowRoot.getElementById('feeSlider').min = this.dogeSatMinFee + this.shadowRoot.getElementById('feeSlider').max = this.dogeSatMaxFee + this.satFeePerByte = this.dogeDefaultFee + } else { + this.selectedCoin = 'invalid' + } + } + + updateBTCAccountBalance() { + parentEpml + .request('apiCall', { + url: `/crosschain/btc/walletbalance`, + method: 'POST', + body: window.parent.reduxStore.getState().app.selectedAddress.btcWallet.derivedMasterPublicKey, + }) + .then((res) => { + if (isNaN(Number(res))) { + parentEpml.request('showSnackBar', 'Failed to Fetch BTC Balance. Try again!') + } else { + this.btcBalance = (Number(res) / 1e8).toFixed(8) + } + }) + } + + updateLTCAccountBalance() { + parentEpml + .request('apiCall', { + url: `/crosschain/ltc/walletbalance`, + method: 'POST', + body: window.parent.reduxStore.getState().app.selectedAddress.ltcWallet.derivedMasterPublicKey, + }) + .then((res) => { + if (isNaN(Number(res))) { + parentEpml.request('showSnackBar', 'Failed to Fetch LTC Balance. Try again!') + } else { + this.ltcBalance = (Number(res) / 1e8).toFixed(8) + } + }) + } + + updateDOGEAccountBalance() { + parentEpml + .request('apiCall', { + url: `/crosschain/doge/walletbalance`, + method: 'POST', + body: window.parent.reduxStore.getState().app.selectedAddress.dogeWallet.derivedMasterPublicKey, + }) + .then((res) => { + if (isNaN(Number(res))) { + parentEpml.request('showSnackBar', 'Failed to Fetch DOGE Balance. Try again!') + } else { + this.dogeBalance = (Number(res) / 1e8).toFixed(8) + } + }) + } + + clearSelection() { + window.getSelection().removeAllRanges() + window.parent.getSelection().removeAllRanges() + } +} + +window.customElements.define('send-coin-page', SendMoneyPage) diff --git a/qortal-ui-plugins/plugins/core/streams/onNewBlock.js.old b/qortal-ui-plugins/plugins/core/streams/onNewBlock.js.old new file mode 100644 index 00000000..eaf4e934 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/streams/onNewBlock.js.old @@ -0,0 +1,63 @@ +import { parentEpml } from '../connect.js' +import { EpmlStream } from 'epml' + +const BLOCK_CHECK_INTERVAL = 3000 // You should be runn off config.user.nodeSettings.pingInterval... +const BLOCK_CHECK_TIMEOUT = 3000 + +export const BLOCK_STREAM_NAME = 'new_block' + +const onNewBlockFunctions = [] + +let mostRecentBlock = { + height: -1 +} + +export const onNewBlock = newBlockFn => onNewBlockFunctions.push(newBlockFn) + +export const check = () => { + const c = doCheck() + c.then(() => { + setTimeout(() => check(), BLOCK_CHECK_INTERVAL) + }) + c.catch(() => { + setTimeout(() => check(), BLOCK_CHECK_INTERVAL) + }) +} + +const doCheck = async () => { + let timeout = setTimeout(() => { + throw new Error('Block check timed out') + }, BLOCK_CHECK_TIMEOUT) + + let _nodeStatus = {} + + const block = await parentEpml.request('apiCall', { + url: '/blocks/last' + }) + + const _nodeInfo = await parentEpml.request('apiCall', { + url: '/admin/info' + }) + + let nodeConfig = await parentEpml.request('getNodeConfig') + + if (nodeConfig.node === 0 || nodeConfig.node === 1) { + _nodeStatus = await parentEpml.request('apiCall', { + url: '/admin/status' + }) + } + + let appInfo = { + block: block, + nodeInfo: _nodeInfo, + nodeStatus: _nodeStatus + } + parentEpml.request('updateAppInfo', appInfo) + + clearTimeout(timeout) + + if (block.height > mostRecentBlock.height) { + mostRecentBlock = block + onNewBlockFunctions.forEach(fn => fn(mostRecentBlock)) + } +} diff --git a/qortal-ui-plugins/plugins/core/trade-portal/index.html b/qortal-ui-plugins/plugins/core/trade-portal/index.html new file mode 100644 index 00000000..18ec05f4 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/trade-portal/index.html @@ -0,0 +1,46 @@ + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/qortal-ui-plugins/plugins/core/trade-portal/trade-portal.src.js b/qortal-ui-plugins/plugins/core/trade-portal/trade-portal.src.js new file mode 100644 index 00000000..df85edf2 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/trade-portal/trade-portal.src.js @@ -0,0 +1,2089 @@ +import { LitElement, html, css } from 'lit-element'; +import { render } from 'lit-html'; +import { Epml } from '../../../epml.js'; + +import '@material/mwc-button'; +import '@material/mwc-textfield'; +import '@material/mwc-icon-button'; +import '@material/mwc-dialog'; +import '@material/mwc-tab-bar'; +import '@material/mwc-tab'; +import '@material/mwc-list/mwc-list-item'; +import '@material/mwc-select'; +import '@polymer/paper-spinner/paper-spinner-lite.js'; +import '@vaadin/vaadin-grid/vaadin-grid.js'; +import '@vaadin/vaadin-grid/vaadin-grid-sorter'; +import '@vaadin/vaadin-grid/theme/material/all-imports.js'; + +const parentEpml = new Epml({ type: 'WINDOW', source: window.parent }); + +let workers = new Map(); + +class TradePortal extends LitElement { + static get properties() { + return { + selectedAddress: { type: Object }, + config: { type: Object }, + listedCoins: { type: Map }, + sellBtnDisable: { type: Boolean }, + isSellLoading: { type: Boolean }, + isBuyLoading: { type: Boolean }, + buyBtnDisable: { type: Boolean }, + initialAmount: { type: Number }, + cancelBtnDisable: { type: Boolean }, + cancelStuckOfferBtnDisable: { type: Boolean }, + selectedCoin: { type: String }, + isLoadingHistoricTrades: { type: Boolean }, + isLoadingOpenTrades: { type: Boolean }, + isLoadingMyOpenOrders: { type: Boolean }, + } + } + + static get styles() { + return css` + * { + --mdc-theme-primary: rgb(3, 169, 244); + --mdc-theme-secondary: var(--mdc-theme-primary); + --paper-input-container-focus-color: var(--mdc-theme-primary); + } + + #tabs-1 { + --mdc-tab-height: 50px; + border-left: 1px solid rgb(102, 102, 102); + border-top: 1px solid rgb(102, 102, 102); + border-right: 1px solid rgb(102, 102, 102); + } + + #tab-buy[active] { + --mdc-theme-primary: rgba(55, 160, 51, 0.9); + } + + #tabs-1-content { + height: 100%; + padding-bottom: 10px; + } + + #tabs-1-content > div { + height: 100%; + border: 1px solid rgb(102, 102, 102); + } + + #tabs-1-content .card { + border: none; + } + + #tabs-1-content .btn-clear { + --mdc-icon-button-size: 40px; + } + + #tab-sell[active] { + --mdc-theme-primary: rgb(255, 89, 89); + } + + #trade-portal-page { + background: #fff; + padding: 12px 24px; + } + + .divCard { + border: 1px solid #eee; + padding: 1em; + box-shadow: 0 0.3px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 1px -1px rgba(0, 0, 0, 0.12), 0 1px 2px 0 rgba(0, 0, 0, 0.2); + } + + h2 { + margin: 0; + } + + h2, + h3, + h4, + h5 { + color: #333; + font-weight: 400; + } + + header { + display: flex; + flex: 0 1 auto; + align-items: center; + justify-content: center; + padding: 0px 15px; + font-size: 16px; + color: #fff; + background-color: rgb(106, 108, 117); + min-height: 40px; + } + + p { + margin-bottom: 15px; + } + + #trade-portal { + max-width: 100vw; + margin-left: auto; + margin-right: auto; + } + + .box { + margin: 0; + padding: 0; + display: flex; + flex-flow: column; + height: 100%; + } + + #first-trade-section { + margin-bottom: 10px; + } + + #first-trade-section > div { + } + + #second-trade-section { + margin-bottom: 10px; + } + + #second-trade-section > div { + } + + #third-trade-section { + margin-bottom: 10px; + } + + #third-trade-section > div { + } + + .trade-chart { + background-color: #eee; + border: 2px #ddd solid; + text-align: center; + } + + .open-trades { + text-align: center; + } + + .no-last-seen { + background: rgb(255, 89, 89); + padding: 9px 1.3px; + border-radius: 50%; + width: 1rem; + margin: 0 auto; + } + + .open-market-container { + text-align: center; + } + + .buy-sell { + } + + .card { + padding: 1em; + border: 1px #666 solid; + flex: 1 1 auto; + display: flex; + flex-flow: column; + justify-content: space-evenly; + min-height: inherit; + } + + .cancel { + --mdc-theme-primary: rgb(255, 89, 89); + } + + .border-wrapper { + border: 1px #666 solid; + overflow: hidden; + } + + .you-have { + color: #555; + font-size: 15px; + text-align: right; + margin-top: 2px; + margin-bottom: 10px; + } + + .historic-trades { + text-align: center; + } + + .my-open-orders { + text-align: center; + } + + .my-historic-trades { + text-align: center; + } + + .buttons { + width: auto !important; + } + + .buy-button { + --mdc-theme-primary: rgba(55, 160, 51, 0.9); + } + + .sell-button { + --mdc-theme-primary: rgb(255, 89, 89); + } + + .full-width { + background-color: #fff; + border: 2px #ddd solid; + height: 100px; + text-align: center; + } + + vaading-grid{ + font-size: .8em; + } + + vaadin-grid-column { + flex-grow: 1; + } + + .loadingContainer { + height: 100%; + width: 100%; + } + + .loading, + .loading:after { + border-radius: 50%; + width: 5em; + height: 5em; + } + + .loading { + margin: 45% auto; + border-width: .6em; + border-style: solid; + border-color: rgba(3, 169, 244, 0.2) rgba(3, 169, 244, 0.2) rgba(3, 169, 244, 0.2) rgb(3, 169, 244); + font-size: 10px; + position: relative; + text-indent: -9999em; + transform: translateZ(0px); + animation: 1.1s linear 0s infinite normal none running loadingAnimation; + } + + mwc-select#coinSelectionMenu { + font-size: 24px; + } + + mwc-select#coinSelectionMenu mwc-list-item { + line-height: 30px; + } + + .coinName::before { + content: ""; + display: inline-block; + height: 26px; + width: 45px; + position: absolute; + background-repeat: no-repeat; + background-size: cover; + left: 10px; + top: 10px; + } + + .ltc.coinName:before { + background-image: url('/img/qortltc.png'); + } + + .doge.coinName:before { + background-image: url('/img/qortdoge.png'); + } + + .coinName { + display: inline-block; + height: 26px; + padding-left: 45px; + } + + @-webkit-keyframes loadingAnimation { + 0% { + -webkit-transform: rotate(0deg); + transform: rotate(0deg); + } + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); + } + } + + @keyframes loadingAnimation { + 0% { + -webkit-transform: rotate(0deg); + transform: rotate(0deg); + } + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); + } + } + + @media (min-width: 701px) { + * { + } + + #trade-portal {} + + #first-trade-section { + display: grid; + grid-template-columns:1fr 1fr 2fr; + grid-auto-rows: max(450px); + column-gap: 0.5em; + row-gap: 0.4em; + justify-items: stretch; + align-items: stretch; + margin-bottom: 10px; + } + + #second-trade-section { + display: grid; + grid-template-columns: 2fr 1fr; + grid-auto-rows: max(450px); + column-gap: 0.5em; + row-gap: 0.4em; + justify-items: stretch; + align-items: stretch; + margin-bottom: 10px; + } + + .buy-sell { + display: grid; + grid-template-columns: 1fr 1fr; + grid-auto-rows: max(450px); + column-gap: 0.5em; + row-gap: 0.4em; + } + + } + `; + } + + constructor() { + super() + let qortal = { + name: "QORTAL", + balance: "0", + coinCode: "QORT", + } + + let litecoin = { + name: "LITECOIN", + balance: "0", + coinCode: "LTC", + openOrders: [], + openFilteredOrders: [], + historicTrades: [], + myOrders: [], + myHistoricTrades: [], + myOfferingOrders: [], + openTradeOrders: null, + tradeOffersSocketCounter: 1 + } + + let dogecoin = { + name: "DOGECOIN", + balance: "0", + coinCode: "DOGE", + openOrders: [], + openFilteredOrders: [], + historicTrades: [], + myOrders: [], + myHistoricTrades: [], + myOfferingOrders: [], + openTradeOrders: null, + tradeOffersSocketCounter: 1 + } + + this.listedCoins = new Map() + this.listedCoins.set("QORTAL", qortal) + this.listedCoins.set("LITECOIN", litecoin) + this.listedCoins.set("DOGECOIN", dogecoin) + + workers.set("QORTAL", { + tradesConnectedWorker: null, + handleStuckTradesConnectedWorker: null + }) + + workers.set("LITECOIN", { + tradesConnectedWorker: null, + handleStuckTradesConnectedWorker: null + }) + + workers.set("DOGECOIN", { + tradesConnectedWorker: null, + handleStuckTradesConnectedWorker: null + }) + + this.selectedCoin = "LITECOIN" + this.selectedAddress = {} + this.config = {} + this.sellBtnDisable = false + this.isSellLoading = false + this.buyBtnDisable = true + this.isBuyLoading = false + this.initialAmount = 0 + this.cancelBtnDisable = false + this.cancelStuckOfferBtnDisable = false + this.isLoadingHistoricTrades = true + this.isLoadingOpenTrades = true + this.isLoadingMyOpenOrders = false + } + + // TODO: Move each template to a separate components! Maybe + historicTradesTemplate() { + return html` +
+
+
HISTORIC MARKET TRADES
+
+
Loading...
+ + + { + const price = this.round(parseFloat(data.item.foreignAmount) / parseFloat(data.item.qortAmount)) + render(html`${price}`, root) + }} + > + + { + render(html` ${data.item.foreignAmount} `, root) + }} + > + + +
+
+
+ `; + } + + openTradesTemplate() { + return html` +
+
+
OPEN MARKET SELL ORDERS
+
+
Loading...
+ + { + render(html` ${this.round(data.item.qortAmount)} `, root) + }} + > + + { + render(html` ${this.round(data.item.price)} `, root) + }} + > + + { + render(html` ${data.item.foreignAmount} `, root) + }} + > + + { + render(html` ${data.item.qortalCreator} `, root) + }} + > + + +
+
+
+ `; + } + + openMarketTemplate() { + return html` +
+
+ + this.displayTabContent('buy')}> + this.displayTabContent('sell')}> + + +
+
+
+ this.clearBuyForm()}> +
+

+ + +

+

+ + +

+

+ + + +

+ You have: ${this.listedCoins.get(this.selectedCoin).balance} ${this.listedCoins.get(this.selectedCoin).coinCode} +
+
+ this.buyAction(e)}> + ${this.isBuyLoading === false ? 'BUY' : html``} + +
+
+
+
+
+
+
+ this.clearSellForm()}> +
+

+ {this._checkSellAmount(e)}} + type="number" + auto-validate="false" + outlined value="${this.initialAmount}" + > + +

+

+ {this._checkSellAmount(e)}} + type="number" + auto-validate="false" + outlined value="${this.initialAmount}" + > + +

+

+ + +

+ You have: ${this.listedCoins.get("QORTAL").balance} QORT +
+
+ this.sellAction()}> + ${this.isSellLoading === false ? 'SELL' : html``} + +
+
+
+
+
+
+ + `; + } + + myOpenOrdersTemplate() { + return html` +
+
+
MY ORDERS this.showStuckOrdersDialog()}>
+
+
Loading...
+ + { + const dateString = new Date(data.item.timestamp).toLocaleString() + render(html`${dateString}`, root) + }} + > + + { + render(html` ${data.item._tradeState} `, root) + }} + > + + { + const price = this.round(parseFloat(data.item.foreignAmount) / parseFloat(data.item.qortAmount)) + render(html`${price}`, root) + }} + > + + + + + + { + render(html`${this.renderCancelButton(data.item)}`, root) + }} + > + + +
+
+
+ `; + } + + myHistoricTradesTemplate() { + return html` +
+
+
MY TRADE HISTORY
+
+ + { + const dateString = new Date(data.item.timestamp).toLocaleString() + render(html`${dateString}`, root) + }} + > + + { + if (data.item.mode === 'SOLD') return render(html` ${data.item.mode} `, root) + if (data.item.mode === 'BOUGHT') return render(html` ${data.item.mode} `, root) + return render(html` ${data.item.mode} `, root) + }} + > + + { + const price = this.round(parseFloat(data.item.foreignAmount) / parseFloat(data.item.qortAmount)) + render(html`${price}`, root) + }} + > + + + + { + render(html` ${data.item.foreignAmount} `, root) + }} + > + + +
+
+
+ `; + } + + render() { + return html` +
+
+

Qortal Trade Portal -  

+ + QORT / LTC + QORT / DOGE + +
+
+
+ ${this.historicTradesTemplate()} + ${this.myHistoricTradesTemplate()} + ${this.openTradesTemplate()} +
+
+ ${this.myOpenOrdersTemplate()} + ${this.openMarketTemplate()} +
+
+
+ + +
+

Stuck Offers

+
+
+
+ + + + + { render(html`${this.renderCancelStuckOfferButton(data.item)}`, root) }}> + +
+ Close +
+ `; + } + + setForeignCoin(coin) { + let _this = this + this.selectedCoin = coin + this.isLoadingHistoricTrades = true + this.isLoadingOpenTrades = true + this.createConnection() + this._openOrdersGrid.querySelector('#priceColumn').headerRenderer = function (root) { + root.innerHTML = 'Price (' + _this.listedCoins.get(_this.selectedCoin).coinCode + ')' + } + this.clearSellForm() + this.clearBuyForm() + this.updateWalletBalance() + } + + displayTabContent(tab) { + const tabBuyContent = this.shadowRoot.getElementById('tab-buy-content') + const tabSellContent = this.shadowRoot.getElementById('tab-sell-content') + tabBuyContent.style.display = (tab === 'buy') ? 'block' : 'none' + tabSellContent.style.display = (tab === 'sell') ? 'block' : 'none' + } + + reRenderHistoricTrades() { + this.requestUpdate() + this.isLoadingHistoricTrades = false + } + + reRenderOpenFilteredOrders() { + this.requestUpdate() + this.isLoadingOpenTrades = false + } + + reRenderMyOpenOrders() { + this.requestUpdate() + this.isLoadingMyOpenOrders = false + } + + firstUpdated() { + let _this = this + setTimeout(() => { + this.displayTabContent('buy') + }, 0) + + // Set Trade Panes + this._openOrdersGrid = this.shadowRoot.getElementById('openOrdersGrid') + this._openOrdersGrid.querySelector('#priceColumn').headerRenderer = function (root) { + root.innerHTML = 'Price (' + _this.listedCoins.get(_this.selectedCoin).coinCode + ')' + } + + this._openOrdersGrid.querySelector('#qortAmountColumn').headerRenderer = function (root) { + root.innerHTML = 'Amount (QORT)' + } + + this._myOrdersGrid = this.shadowRoot.getElementById('myOrdersGrid') + this._historicTradesGrid = this.shadowRoot.getElementById('historicTradesGrid') + this._myHistoricTradesGrid = this.shadowRoot.getElementById('myHistoricTradesGrid') + this._stuckOrdersGrid = this.shadowRoot.getElementById('stuckOrdersGrid') + + // call getOpenOrdersGrid + this.getOpenOrdersGrid() + + window.addEventListener( + 'contextmenu', + (event) => { + event.preventDefault() + this._textMenu(event) + }, + { passive: true } + ) + + window.addEventListener( + 'click', + () => { + parentEpml.request('closeCopyTextMenu', null) + }, + { passive: true } + ) + + window.onkeyup = (e) => { + if (e.keyCode === 27) parentEpml.request('closeCopyTextMenu', null) + } + + let configLoaded = false + + parentEpml.ready().then(() => { + parentEpml.subscribe('selected_address', async (selectedAddress) => { + this.selectedAddress = {} + selectedAddress = JSON.parse(selectedAddress) + if (!selectedAddress || Object.entries(selectedAddress).length === 0) return + this.selectedAddress = selectedAddress + this.updateAccountBalance() + }) + + parentEpml.subscribe('config', (c) => { + if (!configLoaded) configLoaded = true + this.config = JSON.parse(c) + }) + + parentEpml.subscribe('copy_menu_switch', async (value) => { + if (value === 'false' && window.getSelection().toString().length !== 0) this.clearSelection() + }) + + let coinSelectionMenu = this.shadowRoot.getElementById("coinSelectionMenu") + + coinSelectionMenu.addEventListener('change', function () { + _this.setForeignCoin(coinSelectionMenu.value) + }) + + _this.setForeignCoin(coinSelectionMenu.value) + }) + parentEpml.imReady() + + // Set Last Seen column's title on OpenOrders grid + setTimeout(() => this.shadowRoot.querySelector('[slot="vaadin-grid-cell-content-3"]').setAttribute('title', 'Last Seen'), 3000) + } + + fillBuyForm(sellerRequest) { + this.shadowRoot.getElementById('buyAmountInput').value = parseFloat(sellerRequest.qortAmount) + this.shadowRoot.getElementById('buyPriceInput').value = this.round(parseFloat(sellerRequest.foreignAmount) / parseFloat(sellerRequest.qortAmount)) + this.shadowRoot.getElementById('buyTotalInput').value = parseFloat(sellerRequest.foreignAmount) + this.shadowRoot.getElementById('qortalAtAddress').value = sellerRequest.qortalAtAddress + this.buyBtnDisable = false + } + + getOpenOrdersGrid() { + const myGrid = this.shadowRoot.querySelector('#openOrdersGrid') + myGrid.addEventListener( + 'click', (e) => { + let myItem = myGrid.getEventContext(e).item + if (myItem !== undefined && myItem.qortalCreator !== this.selectedAddress.address) { + this.fillBuyForm(myItem) + } + }, + { passive: true } + ) + } + + processOfferingTrade(offer) { + const offerItem = { + ...offer, + qortAmount: parseFloat(offer.qortAmount), + price: parseFloat(offer.foreignAmount) / parseFloat(offer.qortAmount), + } + const addOffer = () => { + this.listedCoins.get(this.selectedCoin).openOrders.unshift(offerItem) + } + const initOffer = () => { + this.listedCoins.get(this.selectedCoin).openOrders.push(offerItem) + } + this.listedCoins.get(this.selectedCoin).openOrders.length === 0 ? initOffer() : addOffer() + this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter > 1 ? this._openOrdersGrid.clearCache() : null + } + + processRedeemedTrade(offer) { + // If trade is mine, add it to my historic trades and also add it to historic trades + if (offer.qortalCreator === this.selectedAddress.address) { + // Check and Update Wallet Balance + if (this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter > 1) { + this.updateWalletBalance() + } + const offerItem = { + ...offer, + mode: 'SOLD', + } + // Add to my historic trades + this._myHistoricTradesGrid.items.unshift(offerItem) + this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter > 1 ? this._myHistoricTradesGrid.clearCache() : null + } else if (offer.partnerQortalReceivingAddress === this.selectedAddress.address) { + // Check and Update Wallet Balance + if (this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter > 1) { + this.updateWalletBalance() + } + const offerItem = { + ...offer, + mode: 'BOUGHT', + } + // Add to my historic trades + this._myHistoricTradesGrid.items.unshift(offerItem) + this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter > 1 ? this._myHistoricTradesGrid.clearCache() : null + } + // Add to historic trades + const addNewHistoricTrade = () => { + this._historicTradesGrid.items.unshift(offer) + this._historicTradesGrid.clearCache() + } + this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter > 1 ? addNewHistoricTrade() : null + } + + processTradingTrade(offer) { + // Remove from open market orders + if (offer.qortalCreator === this.selectedAddress.address && this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter > 1) { + // Check and Update Wallet Balance + this.updateWalletBalance() + } + this._openOrdersGrid.items.forEach((item, index) => { + if (item.qortalAtAddress === offer.qortalAtAddress) { + this._openOrdersGrid.items.splice(index, 1) + this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter > 1 ? this._openOrdersGrid.clearCache() : null + } + }) + this.listedCoins.get(this.selectedCoin).openOrders = this.listedCoins.get(this.selectedCoin).openOrders.filter((order) => order.qortalAtAddress !== offer.qortalAtAddress) + } + + processRefundedTrade(offer) { + if (offer.qortalCreator === this.selectedAddress.address) { + // Check and Update Wallet Balance + if (this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter > 1) { + this.updateWalletBalance() + } + // Add to my historic trades + this._myHistoricTradesGrid.items.unshift(offer) + this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter > 1 ? this._myHistoricTradesGrid.clearCache() : null + } + } + + processCancelledTrade(offer) { + if (offer.qortalCreator === this.selectedAddress.address) { + // Check and Update Wallet Balance + if (this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter > 1) { + this.updateWalletBalance() + } + // Add to my historic trades + this._myHistoricTradesGrid.items.unshift(offer) + this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter > 1 ? this._myHistoricTradesGrid.clearCache() : null + } + this._openOrdersGrid.items.forEach((item, index) => { + if (item.qortalAtAddress === offer.qortalAtAddress) { + this._openOrdersGrid.items.splice(index, 1) + this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter > 1 ? this._openOrdersGrid.clearCache() : null + } + }) + this.listedCoins.get(this.selectedCoin).openOrders = this.listedCoins.get(this.selectedCoin).openOrders.filter((order) => order.qortalAtAddress !== offer.qortalAtAddress) + this._stuckOrdersGrid.items.forEach((item, index) => { + if (item.qortalAtAddress === offer.qortalAtAddress) { + this._stuckOrdersGrid.items.splice(index, 1) + this._stuckOrdersGrid.clearCache() + } + }) + } + + /** + * TRADE OFFER STATES or MODE + * - OFFERING + * - REDEEMED + * - TRADING + * - REFUNDED + * - CANCELLED + */ + + processTradeOffers(offers) { + offers.forEach((offer) => { + if (offer.mode === 'OFFERING') { + this.processOfferingTrade(offer) + this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter > 1 ? this._openOrdersGrid.clearCache() : null + } else if (offer.mode === 'REDEEMED') { + this.processRedeemedTrade(offer) + } else if (offer.mode === 'TRADING') { + this.processTradingTrade(offer) + } else if (offer.mode === 'REFUNDED') { + this.processRefundedTrade(offer) + } else if (offer.mode === 'CANCELLED') { + this.processCancelledTrade(offer) + } + }) + } + + /** + * TradeBot Note by cat + * + * trade-bot entry states: + * - when you do /crosschain/tradebot/create, + * - it returns unsigned DEPLOY_AT for you to sign & broadcast + * - so initial trade-bot state is BOB_WAITING_FOR_AT_CONFIRM, because trade-bot is waiting for UI to sign & broadcast txn and for that txn to be confirmed into a block + * - once that happens & Bob's trade-bot notices that DEPLOY_AT has confirmed (and hence AT created and running), then it switches to BOB_WAITING_FOR_MESSAGE + * - which is Bob's trade-bot waiting for a message from Alice's trade-bot telling it (Bob's trade-bot) that Alice's trade-bot has funded P2SH-A and some other details + * - when that message is sent, Bob's trade-bot processes that message and sends its own message to the AT (which switches it to TRADING mode) + * - but the next state for Bob's trade-bot is to wait for Alice to spot AT is locked to her and for her to fund P2SH-B, hence BOB_WAITING_FOR_P2SH_B + * - at this point, Bob's trade-bot finds P2SH-B on the litecoin blockchain and can send secret-B to P2SH-B + * - when this happens, Alice uses secret-B and secret-A to redeem the QORT from the AT, so until Alice does this, Bob's trade-bot state is BOB_WAITING_FOR_AT_REDEEM + * - after Alice redeems QORT from AT, Bob can extract secret-A and capture the actual LTC funds from P2SH-A to his own litecoin account and hence his trade-bot moves to BOB_DONE + * - if anything goes wrong then refunds occur and Bob's trade-bot ends up at BOB_REFUNDED instead + * - I think you can probably guess the corresponding meaning of states for Alice's point of view, but if not I can go through those too? + * - Alice calls /crosschain/tradebot/respond which funds P2SH-A + * - so her trade-bot waits for that to appear in litecoin blockchain, so until then is ALICE_WAITING_FOR_P2SH_A + * - once the P2SH-A funding confirms, Alice's trade-bot can MESSAGE Bob's trade-bot with the details and changes to ALICE_WAITING_FOR_AT_LOCK + * - Bob's AT should then lock to trading with Alice (via those MESSAGEs above) and Alice's trade-bot notices this, (minimally) funds P2SH-B and waits until Bob 'spends' P2SH-B, hence ALICE_WATCH_P2SH_B + * - if Bob spends P2SH-B, then Alice can send secret-B and secret-A to the AT, claim the QORT and she's ALICE_DONE + * - if something goes wrong then her trade-bot needs to refund P2SH-B (if applicable) first (ALICE_REFUNDING_B) + * - and when that's done refund P2SH-A (ALICE_REFUNDING_A) + * - and when that's done her trade-bot ends up at ALICE_REFUNDED + * + * (PHEW) + */ + + processTradeBotStates(tradeStates) { + + /** + * BitcoinACCTv1 TRADEBOT STATES + * - BOB_WAITING_FOR_AT_CONFIRM + * - BOB_WAITING_FOR_MESSAGE + * - BOB_WAITING_FOR_P2SH_B + * - BOB_WAITING_FOR_AT_REDEEM + * - BOB_DONE + * - BOB_REFUNDED + * - ALICE_WAITING_FOR_P2SH_A + * - ALICE_WAITING_FOR_AT_LOCK + * - ALICE_WATCH_P2SH_B + * - ALICE_DONE + * - ALICE_REFUNDING_B + * - ALICE_REFUNDING_A + * - ALICE_REFUNDED + * + * @param {[{}]} states + */ + + const BitcoinACCTv1 = (states) => { + // Reverse the states + states.reverse() + states.forEach((state) => { + if (state.creatorAddress === this.selectedAddress.address) { + if (state.tradeState == 'BOB_WAITING_FOR_AT_CONFIRM') { + this.changeTradeBotState(state, 'PENDING') + } else if (state.tradeState == 'BOB_WAITING_FOR_MESSAGE') { + this.changeTradeBotState(state, 'LISTED') + } else if (state.tradeState == 'BOB_WAITING_FOR_P2SH_B') { + this.changeTradeBotState(state, 'TRADING') + } else if (state.tradeState == 'BOB_WAITING_FOR_AT_REDEEM') { + this.changeTradeBotState(state, 'REDEEMING') + } else if (state.tradeState == 'BOB_DONE') { + this.handleCompletedState(state) + } else if (state.tradeState == 'BOB_REFUNDED') { + this.handleCompletedState(state) + } else if (state.tradeState == 'ALICE_WAITING_FOR_P2SH_A') { + this.changeTradeBotState(state, 'PENDING') + } else if (state.tradeState == 'ALICE_WAITING_FOR_AT_LOCK') { + this.changeTradeBotState(state, 'TRADING') + } else if (state.tradeState == 'ALICE_WATCH_P2SH_B') { + this.changeTradeBotState(state, 'TRADING') + } else if (state.tradeState == 'ALICE_DONE') { + this.handleCompletedState(state) + } else if (state.tradeState == 'ALICE_REFUNDING_B') { + this.changeTradeBotState(state, 'REFUNDING') + } else if (state.tradeState == 'ALICE_REFUNDING_A') { + this.changeTradeBotState(state, 'REFUNDING') + } else if (state.tradeState == 'ALICE_REFUNDED') { + this.handleCompletedState(state) + } + } + }) + } + + /** + * LitecoinACCTv1 TRADEBOT STATES + * - BOB_WAITING_FOR_AT_CONFIRM + * - BOB_WAITING_FOR_MESSAGE + * - BOB_WAITING_FOR_AT_REDEEM + * - BOB_DONE + * - BOB_REFUNDED + * - ALICE_WAITING_FOR_AT_LOCK + * - ALICE_DONE + * - ALICE_REFUNDING_A + * - ALICE_REFUNDED + * + * @param {[{}]} states + */ + + const LitecoinACCTv1 = (states) => { + // Reverse the states + states.reverse() + states.forEach((state) => { + if (state.creatorAddress === this.selectedAddress.address) { + if (state.tradeState == 'BOB_WAITING_FOR_AT_CONFIRM') { + this.changeTradeBotState(state, 'PENDING') + } else if (state.tradeState == 'BOB_WAITING_FOR_MESSAGE') { + this.changeTradeBotState(state, 'LISTED') + } else if (state.tradeState == 'BOB_WAITING_FOR_AT_REDEEM') { + this.changeTradeBotState(state, 'TRADING') + } else if (state.tradeState == 'BOB_DONE') { + this.handleCompletedState(state) + } else if (state.tradeState == 'BOB_REFUNDED') { + this.handleCompletedState(state) + } else if (state.tradeState == 'ALICE_WAITING_FOR_AT_LOCK') { + this.changeTradeBotState(state, 'BUYING') + } else if (state.tradeState == 'ALICE_DONE') { + this.handleCompletedState(state) + } else if (state.tradeState == 'ALICE_REFUNDING_A') { + this.changeTradeBotState(state, 'REFUNDING') + } else if (state.tradeState == 'ALICE_REFUNDED') { + this.handleCompletedState(state) + } + } + }) + } + + /** + * DogecoinACCTv1 TRADEBOT STATES + * - BOB_WAITING_FOR_AT_CONFIRM + * - BOB_WAITING_FOR_MESSAGE + * - BOB_WAITING_FOR_AT_REDEEM + * - BOB_DONE + * - BOB_REFUNDED + * - ALICE_WAITING_FOR_AT_LOCK + * - ALICE_DONE + * - ALICE_REFUNDING_A + * - ALICE_REFUNDED + * + * @param {[{}]} states + */ + + const DogecoinACCTv1 = (states) => { + // Reverse the states + states.reverse() + states.forEach((state) => { + if (state.creatorAddress === this.selectedAddress.address) { + if (state.tradeState == 'BOB_WAITING_FOR_AT_CONFIRM') { + this.changeTradeBotState(state, 'PENDING') + } else if (state.tradeState == 'BOB_WAITING_FOR_MESSAGE') { + this.changeTradeBotState(state, 'LISTED') + } else if (state.tradeState == 'BOB_WAITING_FOR_AT_REDEEM') { + this.changeTradeBotState(state, 'TRADING') + } else if (state.tradeState == 'BOB_DONE') { + this.handleCompletedState(state) + } else if (state.tradeState == 'BOB_REFUNDED') { + this.handleCompletedState(state) + } else if (state.tradeState == 'ALICE_WAITING_FOR_AT_LOCK') { + this.changeTradeBotState(state, 'BUYING') + } else if (state.tradeState == 'ALICE_DONE') { + this.handleCompletedState(state) + } else if (state.tradeState == 'ALICE_REFUNDING_A') { + this.changeTradeBotState(state, 'REFUNDING') + } else if (state.tradeState == 'ALICE_REFUNDED') { + this.handleCompletedState(state) + } + } + }) + } + + switch (this.selectedCoin) { + case 'BITCOIN': + BitcoinACCTv1(tradeStates) + break + case 'LITECOIN': + LitecoinACCTv1(tradeStates) + break + case 'DOGECOIN': + DogecoinACCTv1(tradeStates) + break + default: + break + } + + // Fill Historic Trades and Filter Stuck Trades + if (this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter === 1) { + setTimeout(() => this.filterStuckTrades(tradeStates), 50) + } + } + + changeTradeBotState(state, tradeState) { + // Set Loading state + this.isLoadingMyOpenOrders = true + const stateItem = { + ...state, + _tradeState: tradeState, + } + const item = this._myOrdersGrid.querySelector(`#${state.atAddress}`) + const addStateItem = () => { + this.reRenderMyOpenOrders() + this._myOrdersGrid.items.unshift(stateItem) + this._myOrdersGrid.clearCache() + } + const updateStateItem = () => { + this._myOrdersGrid.items.forEach((item, index) => { + if (item.atAddress === state.atAddress) { + this._myOrdersGrid.items.splice(index, 1) + this._myOrdersGrid.items.unshift(stateItem) + this._myOrdersGrid.clearCache() + } + }) + } + item ? updateStateItem() : addStateItem() + } + + // ONLY USE FOR BOB_DONE, BOB_REFUNDED, ALICE_DONE, ALICE_REFUNDED + handleCompletedState(state) { + this._myOrdersGrid.items.forEach((item, index) => { + if (item.atAddress === state.atAddress) { + this._myOrdersGrid.items.splice(index, 1) + this._myOrdersGrid.clearCache() + } + }) + } + + initSocket() { + let _relatedCoin = "" + let presenceTxns = null + let offeringTrades = null + let filteredOffers = [] + + self.addEventListener('message', function (event) { + switch (event.data.type) { + case 'open_orders': + offeringTrades = event.data.content + handleOfferingTrades() + break + case 'set_coin': + _relatedCoin = event.data.content + break + default: + break + } + }) + + const lessThanThirtyMinsAgo = (timestamp) => { + const THIRTYMINS = 1000 * 60 * 30 + const thirtyMinsAgo = Date.now() - THIRTYMINS + return timestamp > thirtyMinsAgo + } + + const processOffersWithPresence = () => { + const waitFor = (ms) => new Promise((r) => setTimeout(r, ms)) + async function asyncForEach(array, callback) { + for (let index = 0; index < array.length; index++) { + await callback(array[index], index, array) + } + } + const startOfferPresenceMapping = async () => { + await asyncForEach(presenceTxns, async (presence) => { + await waitFor(5) + let offerIndex = offeringTrades.findIndex((offeringTrade) => offeringTrade.qortalCreatorTradeAddress === presence.address) + offerIndex !== -1 ? (offeringTrades[offerIndex].lastSeen = presence.timestamp) : null + }) + filteredOffers = offeringTrades.filter((offeringTrade) => lessThanThirtyMinsAgo(offeringTrade.lastSeen)) + self.postMessage({ type: 'PRESENCE', data: { offers: offeringTrades, filteredOffers: filteredOffers, relatedCoin: _relatedCoin } }) + filteredOffers = [] + } + startOfferPresenceMapping() + } + + const handleOfferingTrades = () => { + if (presenceTxns === null) return + processOffersWithPresence() + } + + const handlePresence = () => { + if (offeringTrades === null) return + processOffersWithPresence() + } + + const initTradeOffersWebSocket = (restarted = false) => { + let tradeOffersSocketCounter = 0 + let socketTimeout + let socketLink = `ws://NODEURL/websockets/crosschain/tradeoffers?foreignBlockchain=FOREIGN_BLOCKCHAIN&includeHistoric=true` + const socket = new WebSocket(socketLink) + // Open Connection + socket.onopen = () => { + setTimeout(pingSocket, 50) + tradeOffersSocketCounter += 1 + } + // Message Event + socket.onmessage = (e) => { + e.relatedCoin = _relatedCoin + self.postMessage({ + type: 'TRADE_OFFERS', + data: e.data, + counter: tradeOffersSocketCounter, + isRestarted: restarted, + }) + tradeOffersSocketCounter += 1 + restarted = false + } + // Closed Event + socket.onclose = () => { + clearTimeout(socketTimeout) + // Restart Socket Connection + restartTradeOffersWebSocket() + } + // Error Event + socket.onerror = (e) => { + clearTimeout(socketTimeout) + } + const pingSocket = () => { + socket.send('ping') + socketTimeout = setTimeout(pingSocket, 295000) + } + } + + const initTradeBotWebSocket = (restarted = false) => { + let socketTimeout + let socketLink = `ws://NODEURL/websockets/crosschain/tradebot?foreignBlockchain=FOREIGN_BLOCKCHAIN` + const socket = new WebSocket(socketLink) + // Open Connection + socket.onopen = () => { + setTimeout(pingSocket, 50) + } + // Message Event + socket.onmessage = (e) => { + e.relatedCoin = _relatedCoin + self.postMessage({ + type: 'TRADE_BOT', + data: e.data, + isRestarted: restarted, + }) + restarted = false + } + // Closed Event + socket.onclose = () => { + clearTimeout(socketTimeout) + // Restart Socket Connection + restartTradeBotWebSocket() + } + // Error Event + socket.onerror = (e) => { + clearTimeout(socketTimeout) + } + const pingSocket = () => { + socket.send('ping') + socketTimeout = setTimeout(pingSocket, 295000) + } + } + + const initPresenceWebSocket = (restarted = false) => { + let socketTimeout + let socketLink = `ws://NODEURL/websockets/presence?presenceType=TRADE_BOT` + const socket = new WebSocket(socketLink) + // Open Connection + socket.onopen = () => { + setTimeout(pingSocket, 50) + } + // Message Event + socket.onmessage = (e) => { + presenceTxns = JSON.parse(e.data) + handlePresence() + restarted = false + } + // Closed Event + socket.onclose = () => { + clearTimeout(socketTimeout) + // Restart Socket Connection + restartPresenceWebSocket() + } + // Error Event + socket.onerror = (e) => { + clearTimeout(socketTimeout) + } + const pingSocket = () => { + socket.send('ping') + socketTimeout = setTimeout(pingSocket, 295000) + } + } + + const restartPresenceWebSocket = () => { + setTimeout(() => initPresenceWebSocket(true), 3000) + } + + const restartTradeOffersWebSocket = () => { + setTimeout(() => initTradeOffersWebSocket(true), 3000) + } + + const restartTradeBotWebSocket = () => { + setTimeout(() => initTradeBotWebSocket(true), 3000) + } + + // Start TradeOffersWebSocket + initTradeOffersWebSocket() + + // Start PresenceWebSocket + initPresenceWebSocket() + + // Start TradeBotWebSocket + initTradeBotWebSocket() + } + + async sellAction() { + this.isSellLoading = true + this.sellBtnDisable = true + const sellAmountInput = this.shadowRoot.getElementById('sellAmountInput').value + const sellTotalInput = this.shadowRoot.getElementById('sellTotalInput').value + const fundingQortAmount = this.round(parseFloat(sellAmountInput) + 0.001) + + const makeRequest = async () => { + let _receivingAddress = null + switch (this.selectedCoin) { + case 'LITECOIN': + _receivingAddress = this.selectedAddress.ltcWallet.address + break + case 'DOGECOIN': + _receivingAddress = this.selectedAddress.dogeWallet.address + break + default: + break + } + const response = await parentEpml.request('tradeBotCreateRequest', { + creatorPublicKey: this.selectedAddress.base58PublicKey, + qortAmount: parseFloat(sellAmountInput), + fundingQortAmount: parseFloat(fundingQortAmount), + foreignBlockchain: this.selectedCoin, + foreignAmount: parseFloat(sellTotalInput), + tradeTimeout: 60, + receivingAddress: _receivingAddress, + }) + return response + } + + const manageResponse = (response) => { + if (response === true) { + this.isSellLoading = false + this.sellBtnDisable = false + this.shadowRoot.getElementById('sellAmountInput').value = this.initialAmount + this.shadowRoot.getElementById('sellPriceInput').value = this.initialAmount + this.shadowRoot.getElementById('sellTotalInput').value = this.initialAmount + } else if (response === false) { + this.isSellLoading = false + this.sellBtnDisable = false + parentEpml.request('showSnackBar', 'Failed to Create Trade. Try again!') + } else { + this.isSellLoading = false + this.sellBtnDisable = false + parentEpml.request('showSnackBar', `Failed to Create Trade. ERROR_CODE: ${response.message}`) + } + } + + if (this.round(parseFloat(fundingQortAmount) + parseFloat(0.002)) > parseFloat(this.listedCoins.get("QORTAL").balance)) { + this.isSellLoading = false + this.sellBtnDisable = false + parentEpml.request('showSnackBar', 'Insufficient Funds!') + return false + } else { + const res = await makeRequest() + manageResponse(res) + } + } + + async buyAction() { + this.isBuyLoading = true + this.buyBtnDisable = true + const qortalAtAddress = this.shadowRoot.getElementById('qortalAtAddress').value + let _foreignKey = "" + + switch (this.selectedCoin) { + case 'LITECOIN': + _foreignKey = this.selectedAddress.ltcWallet.derivedMasterPrivateKey + break + case 'DOGECOIN': + _foreignKey = this.selectedAddress.dogeWallet.derivedMasterPrivateKey + break + default: + break + } + + const makeRequest = async () => { + const response = await parentEpml.request('tradeBotRespondRequest', { + atAddress: qortalAtAddress, + foreignKey: _foreignKey, + receivingAddress: this.selectedAddress.address, + }) + return response + } + + const manageResponse = (response) => { + if (response === true) { + this.isBuyLoading = false + this.buyBtnDisable = true + this.shadowRoot.getElementById('buyAmountInput').value = this.initialAmount + this.shadowRoot.getElementById('buyPriceInput').value = this.initialAmount + this.shadowRoot.getElementById('buyTotalInput').value = this.initialAmount + this.shadowRoot.getElementById('qortalAtAddress').value = '' + parentEpml.request('showSnackBar', 'Buy Request Successful!') + } else if (response === false) { + this.isBuyLoading = false + this.buyBtnDisable = false + parentEpml.request('showSnackBar', 'Buy Request Existing!') + } else { + this.isBuyLoading = false + this.buyBtnDisable = false + parentEpml.request('showSnackBar', `Failed to Create Trade. ERROR_CODE: ${response.message}`) + } + } + + // Call makeRequest + const res = await makeRequest() + manageResponse(res) + } + + async cancelAction(state) { + const button = this.shadowRoot.querySelector(`mwc-button#${state.atAddress}`) + button.innerHTML = `` + this.cancelBtnDisable = true + + const makeRequest = async () => { + const response = await parentEpml.request('deleteTradeOffer', { + creatorPublicKey: this.selectedAddress.base58PublicKey, + atAddress: state.atAddress, + }) + return response + } + + const manageResponse = (response) => { + if (response === true) { + button.remove() + this.cancelBtnDisable = false + parentEpml.request('showSnackBar', 'Trade Cancelling In Progress!') + } else if (response === false) { + button.innerHTML = 'CANCEL' + this.cancelBtnDisable = false + parentEpml.request('showSnackBar', 'Failed to Cancel Trade. Try again!') + } else { + button.innerHTML = 'CANCEL' + this.cancelBtnDisable = false + parentEpml.request('showSnackBar', `Failed to Cancel Trade. ERROR_CODE: ${response.message}`) + } + } + + // Call makeRequest + const res = await makeRequest() + manageResponse(res) + } + + updateAccountBalance() { + clearTimeout(this.updateAccountBalanceTimeout) + parentEpml.request('apiCall', { + url: `/addresses/balance/${this.selectedAddress.address}`, + }) + .then((res) => { + this.listedCoins.get("QORTAL").balance = res + this.updateAccountBalanceTimeout = setTimeout(() => this.updateAccountBalance(), 10000) + }) + } + + updateWalletBalance() { + let _url = `` + let _body = null + + switch (this.selectedCoin) { + case 'LITECOIN': + _url = `/crosschain/ltc/walletbalance` + _body = window.parent.reduxStore.getState().app.selectedAddress.ltcWallet.derivedMasterPublicKey + break + case 'DOGECOIN': + _url = `/crosschain/doge/walletbalance` + _body = window.parent.reduxStore.getState().app.selectedAddress.dogeWallet.derivedMasterPublicKey + break + default: + break + } + + parentEpml.request('apiCall', { + url: _url, + method: 'POST', + body: _body, + }) + .then((res) => { + if (isNaN(Number(res))) { + parentEpml.request('showSnackBar', 'Failed to Fetch Balance. Try again!') + } else { + this.listedCoins.get(this.selectedCoin).balance = (Number(res) / 1e8).toFixed(8) + } + }) + } + + renderCancelButton(stateItem) { + if (stateItem.tradeState === 'BOB_WAITING_FOR_MESSAGE') { + return html` this.cancelAction(stateItem)}>CANCEL` + } else { + return '' + } + } + + showStuckOrdersDialog() { + this.shadowRoot.querySelector('#manageStuckOrdersDialog').show() + } + + async cancelStuckOfferAction(offer) { + this.cancelStuckOfferBtnDisable = true + + const makeRequest = async () => { + const response = await parentEpml.request('deleteTradeOffer', { + creatorPublicKey: this.selectedAddress.base58PublicKey, + atAddress: offer.qortalAtAddress, + }) + return response + } + + const manageResponse = (response) => { + if (response === true) { + this.cancelStuckOfferBtnDisable = false + parentEpml.request('showSnackBar', 'Trade Cancelling In Progress!') + } else if (response === false) { + this.cancelStuckOfferBtnDisable = false + parentEpml.request('showSnackBar', 'Failed to Cancel Trade. Try again!') + } else { + this.cancelStuckOfferBtnDisable = false + parentEpml.request('showSnackBar', `Failed to Cancel Trade. ERROR_CODE: ${response.message}`) + } + } + + // Call makeRequest + const res = await makeRequest() + manageResponse(res) + } + + renderCancelStuckOfferButton(offerItem) { + if (offerItem.mode === 'OFFERING' && offerItem.qortalCreator === this.selectedAddress.address) { + return html` this.cancelStuckOfferAction(offerItem)}>CANCEL` + } else { + return '' + } + } + + // Helper Functions (Re-Used in Most part of the UI ) + _checkSellAmount(e) { + const targetAmount = e.target.value + const target = e.target + + if (targetAmount.length === 0) { + this.isValidAmount = false + this.sellBtnDisable = true + e.target.blur() + e.target.focus() + e.target.invalid = true + } else { + const sellAmountInput = this.shadowRoot.getElementById('sellAmountInput').value + const sellPriceInput = this.shadowRoot.getElementById('sellPriceInput').value + this.shadowRoot.getElementById('sellTotalInput').value = this.round(parseFloat(sellAmountInput) * parseFloat(sellPriceInput)) + this.sellBtnDisable = false + } + + e.target.blur() + e.target.focus() + + e.target.validityTransform = (newValue, nativeValidity) => { + if (newValue.includes('-') === true) { + this.sellBtnDisable = true + return { + valid: false, + } + } else if (!nativeValidity.valid) { + if (newValue.includes('.') === true) { + let myAmount = newValue.split('.') + if (myAmount[1].length > 8) { + this.sellBtnDisable = true + } else { + const sellAmountInput = this.shadowRoot.getElementById('sellAmountInput').value + const sellPriceInput = this.shadowRoot.getElementById('sellPriceInput').value + this.shadowRoot.getElementById('sellTotalInput').value = this.round(parseFloat(sellAmountInput) * parseFloat(sellPriceInput)) + this.sellBtnDisable = false + return { + valid: true, + } + } + } + } else { + const sellAmountInput = this.shadowRoot.getElementById('sellAmountInput').value + const sellPriceInput = this.shadowRoot.getElementById('sellPriceInput').value + this.shadowRoot.getElementById('sellTotalInput').value = this.round(parseFloat(sellAmountInput) * parseFloat(sellPriceInput)) + this.sellBtnDisable = false + } + } + } + + _checkBuyAmount(e) { + const targetAmount = e.target.value + const target = e.target + + if (targetAmount.length === 0) { + this.isValidAmount = false + this.sellBtnDisable = true + e.target.blur() + e.target.focus() + e.target.invalid = true + } else { + this.buyBtnDisable = false + } + + e.target.blur() + e.target.focus() + + e.target.validityTransform = (newValue, nativeValidity) => { + if (newValue.includes('-') === true) { + this.buyBtnDisable = true + return { + valid: false, + } + } else if (!nativeValidity.valid) { + if (newValue.includes('.') === true) { + let myAmount = newValue.split('.') + if (myAmount[1].length > 8) { + this.buyBtnDisable = true + } else { + this.buyBtnDisable = false + return { + valid: true, + } + } + } + } else { + this.buyBtnDisable = false + } + } + } + + clearSelection() { + window.getSelection().removeAllRanges() + window.parent.getSelection().removeAllRanges() + } + + _textMenu(event) { + const getSelectedText = () => { + var text = '' + if (typeof window.getSelection != 'undefined') { + text = window.getSelection().toString() + } else if (typeof this.shadowRoot.selection != 'undefined' && this.shadowRoot.selection.type == 'Text') { + text = this.shadowRoot.selection.createRange().text + } + return text + } + + const checkSelectedTextAndShowMenu = () => { + let selectedText = getSelectedText() + if (selectedText && typeof selectedText === 'string') { + let _eve = { + pageX: event.pageX, + pageY: event.pageY, + clientX: event.clientX, + clientY: event.clientY, + } + let textMenuObject = { + selectedText: selectedText, + eventObject: _eve, + isFrame: true, + } + parentEpml.request('openCopyTextMenu', textMenuObject) + } + } + checkSelectedTextAndShowMenu() + } + + clearBuyForm() { + this.shadowRoot.getElementById('buyAmountInput').value = this.initialAmount + this.shadowRoot.getElementById('buyPriceInput').value = this.initialAmount + this.shadowRoot.getElementById('buyTotalInput').value = this.initialAmount + this.shadowRoot.getElementById('qortalAtAddress').value = '' + this.buyBtnDisable = true + } + + clearSellForm() { + this.shadowRoot.getElementById('sellAmountInput').value = this.initialAmount + this.shadowRoot.getElementById('sellPriceInput').value = this.initialAmount + this.shadowRoot.getElementById('sellTotalInput').value = this.initialAmount + } + + isEmptyArray(arr) { + if (!arr) { + return true + } + return arr.length === 0 + } + + round(number) { + let result = (Math.round(parseFloat(number) * 1e8) / 1e8).toFixed(8) + return result + } + + /** + * Inline Worker - Takes in a function and a modifier then returns an instance of a Web Worker + * + * - Modifiers are simply an Array of Object containing placeholders (containers for variables used in the passedFunction ) in the and its values. + * These placeholders gets replaced with it value during instantiation of the function to be used by the Worker. + * - Example of modifiers: const modifiers = [ + * { searchValue: 'SELECTED_ADDRESS', replaceValue: this.selectedAddress.address, }, + * ] + * + * @param {Function} passedFunction + * @param {Array} modifiers + * @returns {Worker} Worker + */ + + inlineWorker(passedFunction, modifiers) { + let parsedFunction = `` + + modifiers.forEach((modifier) => { + let regex = new RegExp(modifier.searchValue, 'g') + parsedFunction = parsedFunction.length === 0 ? `(function ${passedFunction.toString().trim().replace(regex, modifier.replaceValue)})()` : parsedFunction.toString().trim().replace(regex, modifier.replaceValue) + }) + + const workerUrl = URL.createObjectURL(new Blob([parsedFunction], { type: 'text/javascript' })) + const worker = new Worker(workerUrl) + URL.revokeObjectURL(workerUrl) + return worker + } + + clearPaneCache() { + this._openOrdersGrid.clearCache() + this._myHistoricTradesGrid.clearCache() + this._historicTradesGrid.clearCache() + } + + createConnection() { + if (workers.get(this.selectedCoin).tradesConnectedWorker !== null) { + this.isLoadingHistoricTrades = false + this.isLoadingOpenTrades = false + return + } + + const handleMessage = (message) => { + switch (message.type) { + case 'TRADE_OFFERS': + if (!message.isRestarted) { + this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter = message.counter + this.processTradeOffers(JSON.parse(message.data)) + this.listedCoins.get(this.selectedCoin).tradeOffersSocketCounter === 1 ? this.clearPaneCache() : null + workers.get(this.selectedCoin).tradesConnectedWorker.postMessage(this.listedCoins.get(this.selectedCoin).openOrders) + workers.get(this.selectedCoin).tradesConnectedWorker.postMessage({ type: "open_orders", content: this.listedCoins.get(this.selectedCoin).openOrders }) + } + return null + case 'TRADE_BOT': + if (!message.isRestarted) this.processTradeBotStates(JSON.parse(message.data)) + return null + case 'PRESENCE': + this.listedCoins.get(message.data.relatedCoin).openOrders = message.data.offers + this.listedCoins.get(message.data.relatedCoin).openFilteredOrders = message.data.filteredOffers + this.reRenderOpenFilteredOrders() + return null + default: + break + } + } + + let myNode = window.parent.reduxStore.getState().app.nodeConfig.knownNodes[window.parent.reduxStore.getState().app.nodeConfig.node] + let nodeUrl = myNode.domain + ':' + myNode.port + + const modifiers = [ + { searchValue: 'NODEURL', replaceValue: nodeUrl }, + { searchValue: 'FOREIGN_BLOCKCHAIN', replaceValue: this.selectedCoin, }, + ] + + workers.get(this.selectedCoin).tradesConnectedWorker = this.inlineWorker(this.initSocket, modifiers) + + workers.get(this.selectedCoin).tradesConnectedWorker.addEventListener( + 'message', + function (event) { + handleMessage(event.data) + }, + { passive: true } + ) + + workers.get(this.selectedCoin).tradesConnectedWorker.postMessage({ type: "set_coin", content: this.selectedCoin }) + } + + handleStuckTrades() { + let tradeBotStates = [] + + self.addEventListener('message', function (event) { + tradeBotStates = event.data + }) + + const getCompletedTrades = async () => { + const url = `http://NODEURL/crosschain/trades?limit=100&reverse=true&foreignBlockchain=FOREIGN_BLOCKCHAIN` + const res = await fetch(url) + const historicTrades = await res.json() + const compareFn = (a, b) => { + return b.tradeTimestamp - a.tradeTimestamp + } + const sortedTrades = historicTrades.sort(compareFn) + self.postMessage({ type: 'HISTORIC_TRADES', data: sortedTrades }) + } + + const filterStuckOffers = (myOffers) => { + const myTradeBotStates = tradeBotStates.filter((state) => state.creatorAddress === 'SELECTED_ADDRESS') + const stuckOffers = myOffers.filter((myOffer) => { + let value = myTradeBotStates.some((myTradeBotState) => myOffer.qortalAtAddress === myTradeBotState.atAddress) + return !value + }) + return stuckOffers + } + + const getOffers = async () => { + const url = `http://NODEURL/crosschain/tradeoffers?foreignBlockchain=FOREIGN_BLOCKCHAIN` + const res = await fetch(url) + const openTradeOrders = await res.json() + const myOpenTradeOrders = await openTradeOrders.filter((order) => order.mode === 'OFFERING' && order.qortalCreator === 'SELECTED_ADDRESS') + const stuckOffers = filterStuckOffers(myOpenTradeOrders) + self.postMessage({ type: 'STUCK_OFFERS', data: stuckOffers }) + } + + // Get Historic Trades + getCompletedTrades() + + // Get Offers + getOffers() + } + + filterStuckTrades(states) { + if (workers.get(this.selectedCoin).handleStuckTradesConnectedWorker !== null) { + this.isLoadingOpenTrades = false + return + } + + //show the loading on historic trades + this.shadowRoot.getElementById('loadingHistoricTrades').style.display = "block"; + let isHandleTradesDone = false + let isHandleStuckOffersDone = false + + const handleMessage = (message) => { + switch (message.type) { + case 'HISTORIC_TRADES': + this.listedCoins.get(this.selectedCoin).historicTrades = message.data + this.reRenderHistoricTrades() + isHandleTradesDone = true + break + case 'STUCK_OFFERS': + doStuckOffers(message.data) + isHandleStuckOffersDone = true + break + default: + break + } + if (isHandleTradesDone === true && isHandleStuckOffersDone === true) return workers.get(this.selectedCoin).handleStuckTradesConnectedWorker.terminate() + } + + const doStuckOffers = (message) => { + const offers = message + const offerItem = (offer) => { + return { + ...offer, + price: this.round(parseFloat(offer.expectedForeignAmount) / parseFloat(offer.qortAmount)), + } + } + const addStuckOrders = (offerItem) => { + if (offerItem.qortalCreator === this.selectedAddress.address) { + this._stuckOrdersGrid.items.unshift(offerItem) + this._stuckOrdersGrid.clearCache() + } + } + const handleOffers = () => { + offers.forEach((offer) => { + addStuckOrders(offerItem(offer)) + }) + } + handleOffers() + } + + let myNode = window.parent.reduxStore.getState().app.nodeConfig.knownNodes[window.parent.reduxStore.getState().app.nodeConfig.node] + let nodeUrl = myNode.domain + ':' + myNode.port + + const modifiers = [ + { searchValue: 'NODEURL', replaceValue: nodeUrl }, + { searchValue: 'SELECTED_ADDRESS', replaceValue: this.selectedAddress.address, }, + { searchValue: 'FOREIGN_BLOCKCHAIN', replaceValue: this.selectedCoin, }, + ] + + workers.get(this.selectedCoin).handleStuckTradesConnectedWorker = this.inlineWorker(this.handleStuckTrades, modifiers) + workers.get(this.selectedCoin).handleStuckTradesConnectedWorker.postMessage(states) + workers.get(this.selectedCoin).handleStuckTradesConnectedWorker.addEventListener( + 'message', + function (event) { + handleMessage(event.data) + }, + { passive: true } + ) + } +} + +window.customElements.define('trade-portal', TradePortal) diff --git a/qortal-ui-plugins/plugins/core/wallet/index.html b/qortal-ui-plugins/plugins/core/wallet/index.html new file mode 100644 index 00000000..0a791185 --- /dev/null +++ b/qortal-ui-plugins/plugins/core/wallet/index.html @@ -0,0 +1,43 @@ + + + + + + + + + + + + diff --git a/qortal-ui-plugins/plugins/core/wallet/wallet-app.src.js b/qortal-ui-plugins/plugins/core/wallet/wallet-app.src.js new file mode 100644 index 00000000..f2b9c35f --- /dev/null +++ b/qortal-ui-plugins/plugins/core/wallet/wallet-app.src.js @@ -0,0 +1,1061 @@ +import { LitElement, html, css } from 'lit-element' +import { render } from 'lit-html' +import { Epml } from '../../../epml.js' + +import '../components/ButtonIconCopy' + +import '@material/mwc-icon' +import '@material/mwc-button' +import '@material/mwc-dialog' + +import '@polymer/paper-spinner/paper-spinner-lite.js' +import '@vaadin/vaadin-grid/vaadin-grid.js' +import '@vaadin/vaadin-grid/theme/material/all-imports.js' + +import '@github/time-elements' + +const parentEpml = new Epml({ type: 'WINDOW', source: window.parent }) +const coinsNames=['qort','btc','ltc','doge'] + +class MultiWallet extends LitElement { + static get properties() { + return { + loading: { type: Boolean }, + transactions: { type: Object }, + lastBlock: { type: Object }, + selectedTransaction: { type: Object }, + isTextMenuOpen: { type: Boolean }, + wallets:{type : Map}, + _selectedWallet:'qort', + balanceString:'Fetching balance ...' + } + } + + static get styles() { + return [ + css` + #pages { + display: flex; + flex-wrap: wrap; + /* margin: 20px; */ + padding: 10px 5px 5px 5px; + margin: 0px 20px 20px 20px; + } + + #pages > button { + user-select: none; + padding: 5px; + margin: 0 5px; + border-radius: 10%; + border: 0; + background: transparent; + font: inherit; + outline: none; + cursor: pointer; + } + + #pages > button:not([disabled]):hover, + #pages > button:focus { + color: #ccc; + background-color: #eee; + } + + #pages > button[selected] { + font-weight: bold; + color: white; + background-color: #ccc; + } + + #pages > button[disabled] { + opacity: 0.5; + cursor: default; + } + .red { + color: var(--paper-red-500); + } + .green { + color: var(--paper-green-500); + } + paper-spinner-lite { + height: 75px; + width: 75px; + --paper-spinner-color: var(--primary-color); + --paper-spinner-stroke-width: 2px; + } + .unconfirmed { + font-style: italic; + } + .roboto { + font-family: 'Roboto', sans-serif; + } + .mono { + font-family: 'Roboto Mono', monospace; + } + .weight-100 { + font-weight: 100; + } + + .text-white-primary { + color: var(--white-primary); + } + .text-white-secondary { + color: var(--white-secondary); + } + .text-white-disabled { + color: var(--white-disabled); + } + .text-white-hint { + color: var(--white-divider); + } + + table { + border: none; + } + table td, + th { + white-space: nowrap; + /* padding:10px; */ + text-align: left; + font-size: 14px; + padding: 0 12px; + font-family: 'Roboto', sans-serif; + } + table tr { + height: 48px; + } + table tr:hover td { + background: #eee; + } + table tr th { + color: #666; + font-size: 12px; + } + table tr td { + margin: 0; + } + .white-bg { + height: 100vh; + background: #fff; + } + span { + font-size: 18px; + word-break: break-all; + } + .title { + font-weight: 600; + font-size: 12px; + line-height: 32px; + opacity: 0.66; + } + #transactionList { + padding: 0; + } + #transactionList > * { + /* padding-left:24px; + padding-right:24px; */ + } + .color-in { + color: #02977e; + background-color: rgba(0, 201, 167, 0.2); + font-weight: 700; + font-size: 0.60938rem; + border-radius: 0.25rem !important; + padding: 0.2rem 0.5rem; + margin-left: 4px; + } + .color-out { + color: #b47d00; + background-color: rgba(219, 154, 4, 0.2); + font-weight: 700; + font-size: 0.60938rem; + border-radius: 0.25rem !important; + padding: 0.2rem 0.5rem; + margin-left: 4px; + } + * { + box-sizing: border-box; + } + + body { + margin: 0; + padding: 0; + background: white; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; + } + + h2 { + margin: 0; + font-weight: 400; + color: #707584; + font: 24px/24px 'Open Sans', sans-serif; + } + + h3 { + margin: 0 0 5px; + font-weight: 600; + font-size: 18px; + line-height: 18px; + } + + /* Styles for Larger Screen Sizes */ + @media (min-width: 765px) { + .wrapper { + display: grid; + grid-template-columns: 0.5fr 3.5fr; + } + } + + .wrapper { + margin: 0 auto; + height: 100%; + overflow: hidden; + border-radius: 8px; + background-color: #fff; + } + + .wallet { + width: 170px; + height: 100vh; + border-top-left-radius: inherit; + border-bottom-left-radius: inherit; + border-right: 1px solid #eee; + } + + .transactions-wrapper { + width: 100%; + padding: 50px 0 0 0; + height: 100%; + } + + .wallet-header { + margin: 0 20px; + } + + .wallet-address { + display: flex; + align-items: center; + font-size: 18px; + color: var(--mdc-theme-primary, #444750); + margin: 4px 0 20px; + } + + .wallet-balance { + display: inline-block; + font-weight: 600; + font-size: 32px; + color: var(--mdc-theme-primary, #444750); + } + + #transactions { + margin-top: 60px; + margin-left: 20px; + margin-right: 20px; + border-top: 1px solid #e5e5e5; + padding-top: 0px; + height: 100%; + /* overflow: auto; */ + } + + .show { + animation: fade-in 0.3s 1; + } + + .transaction-item { + display: flex; + justify-content: space-between; + position: relative; + padding-left: 40px; + margin-bottom: 45px; + margin-right: 50px; + } + .transaction-item::before { + position: absolute; + content: ''; + border: 2px solid #e1e1e1; + border-radius: 50%; + height: 25px; + width: 25px; + left: 0; + top: 10px; + box-sizing: border-box; + vertical-align: middle; + color: #666666; + } + + .credit::before { + content: '+'; + font-size: 25px; + line-height: 19px; + padding: 0 4px 0; + } + + .debit::before { + content: '-'; + font-size: 20px; + line-height: 21px; + padding: 0 5px; + } + + .transaction-item .details { + font-size: 14px; + line-height: 14px; + color: #999; + } + + .transaction-item_details { + width: 270px; + } + + .transaction-item_amount .amount { + font-weight: 600; + font-size: 18px; + line-height: 45px; + position: relative; + margin: 0; + display: inline-block; + } + + .currency-box { + display: flex; + background-color: #fff; + text-align: center; + padding: 12px; + cursor: pointer; + transition: 0.1s ease-in-out; + } + .currency-box:not(:last-child) { + border-bottom: 1px solid #eee; + } + + .active { + background: #ddd; + } + + .currency-image { + display: inline-block; + height: 42px; + width: 42px; + background-repeat: no-repeat; + background-size: cover; + border-radius: 3px; + filter: grayscale(100%); + } + .currency-box.active .currency-image, + .currency-box:hover .currency-image { + filter: none; + } + .currency-box:hover { + background: #bbb; + } + .currency-box.active, + .currency-box:hover .currency-text { + font-weight: 500; + } + + .currency-text { + margin: auto 0; + margin-left: 8px; + font-size: 20px; + color: #777; + } + + .qort .currency-image { + background-image: url('/img/qort.png'); + } + + .btc .currency-image { + background-image: url('/img/btc.png'); + } + + .ltc .currency-image { + background-image: url('/img/ltc.png'); + } + + .doge .currency-image { + background-image: url('/img/doge.png'); + } + + .card-list { + margin-top: 20px; + } + + .card-list .currency-image { + cursor: pointer; + margin-right: 15px; + transition: 0.1s; + } + + .card-list .currency-image:hover { + transform: scale(1.1); + } + + /* animations */ + @keyframes fade-in { + 0% { + opacity: 0; + } + 100% { + opacity: 1; + } + } + + /* media queries */ + @media (max-width: 863px) { + .wallet { + width: 100%; + height: max-content; + border-top-right-radius: inherit; + padding-bottom: 25px; + } + .cards { + margin-top: 25px; + } + .currency-box:nth-of-type(2) { + margin-right: 0; + } + } + + @media (max-width: 764px) { + .wallet { + width: 100%; + height: max-content; + border-top-right-radius: inherit; + padding-bottom: 25px; + } + .cards { + margin-top: 25px; + } + .currency-box { + width: calc(50% - 25px); + max-width: 260px; + display: inline-block; + margin-right: 25px; + margin-bottom: 25px; + } + .currency-box:nth-of-type(2) { + margin-right: 0; + } + } + + @media (max-width: 530px) { + h3 { + line-height: 24px; + } + .cards { + text-align: center; + } + .currency-box { + width: calc(100% - 25px); + max-width: 260px; + } + .currency-box:nth-of-type(2) { + margin-right: 25px; + } + .currency-box:last-of-type { + margin-bottom: 0; + } + .wallet-balance { + font-size: 22px; + } + } + + @media (max-width: 390px) { + .wallet { + height: max-content; + padding: 50px 25px; + } + .transactions-wrapper { + padding: 50px 25px; + } + h2 { + font: 18px/24px 'Open Sans', sans-serif; + } + } + `, + ] + } + + constructor() { + super() + + this.lastBlock = { + height: 0, + } + + + this.selectedTransaction = {} + this.isTextMenuOpen = false + this.loading = true + + this.selectWallet = this.selectWallet.bind(this) + + this.wallets=new Map() + let coinProp={ + balance:0, + wallet:null, + transactions:[], + fetchingWalletBalance:false, + fetchingWalletTransactions:false + } + coinsNames.forEach((c,i)=>{//reset fetching status, c:coin, i:index + this.wallets.set(c,{...coinProp}) + },this)//thisArg=this + + this.wallets.get('qort').wallet = window.parent.reduxStore.getState().app.selectedAddress + this.wallets.get('btc').wallet = window.parent.reduxStore.getState().app.selectedAddress.btcWallet + this.wallets.get('ltc').wallet = window.parent.reduxStore.getState().app.selectedAddress.ltcWallet + this.wallets.get('doge').wallet = window.parent.reduxStore.getState().app.selectedAddress.dogeWallet + + this._selectedWallet='qort' + + parentEpml.ready().then(() => { + parentEpml.subscribe('selected_address', async (selectedAddress) => { + selectedAddress = JSON.parse(selectedAddress) + if (!selectedAddress || Object.entries(selectedAddress).length === 0) return + + this.wallets.get('qort').wallet = selectedAddress + this.wallets.get('btc').wallet = window.parent.reduxStore.getState().app.selectedAddress.btcWallet + this.wallets.get('ltc').wallet = window.parent.reduxStore.getState().app.selectedAddress.ltcWallet + this.wallets.get('doge').wallet = window.parent.reduxStore.getState().app.selectedAddress.dogeWallet + // this.updateAccountTransactions(); + }) + + parentEpml.subscribe('copy_menu_switch', async (value) => { + if (value === 'false' && this.isTextMenuOpen === true) { + this.clearSelection() + this.isTextMenuOpen = false + } + }) + }) + } + + render() { + return html` +
+
+
Wallets
+
+
+
+
Qort
+
+
+
+
Bitcoin
+
+
+
+
Litecoin
+
+
+
+
Dogecoin
+
+
+
+ +
+

+ Current Wallet +
+ ${this.getSelectedWalletAddress()} + + +
+ ${this.balanceString} +

+
+ ${this.loading ? html`` : ''} +
+
+
+ +
+ +
+

Transaction Details

+
+
+
+ Transaction Type +
+
+ ${this.selectedTransaction.type} + ${this.selectedTransaction.txnFlow === 'OUT' ? html`OUT` : html`IN`} +
+ Sender +
+
${this.selectedTransaction.creatorAddress}
+ Receiver +
+
${this.selectedTransaction.recipient}
+ ${!this.selectedTransaction.amount + ? '' + : html` + Amount +
+
${this.selectedTransaction.amount} QORT
+ `} + Transaction Fee +
+
${this.selectedTransaction.fee}
+ + Block +
+
${this.selectedTransaction.blockHeight}
+ + Time +
+
${new Date(this.selectedTransaction.timestamp).toString()}
+ + Transaction Signature +
+
${this.selectedTransaction.signature}
+
+
+
+
+ ` + } + + getSelectedWalletAddress() { + return this._selectedWallet === 'qort' + ? this.wallets.get(this._selectedWallet).wallet.address + : this.wallets.get(this._selectedWallet).wallet.address + } + + + async getTransactionGrid(coin) { + this.transactionsGrid = this.shadowRoot.querySelector(`#${coin}TransactionsGrid`) + if (coin === 'qort') { + this.transactionsGrid.addEventListener( + 'click', + (e) => { + let myItem = this.transactionsGrid.getEventContext(e).item + this.showTransactionDetails(myItem, this.wallets.get(this._selectedWallet).transactions) + }, + { passive: true } + ) + } + + this.pagesControl = this.shadowRoot.querySelector('#pages') + this.pages = undefined + } + + async renderTransactions() { + if (this._selectedWallet === 'qort') { + render(this.renderQortTransactions(this.wallets.get(this._selectedWallet).transactions, this._selectedWallet), this.transactionsDOM) + } else { + render(this.renderBTCLikeTransactions(this.wallets.get(this._selectedWallet).transactions, this._selectedWallet), this.transactionsDOM) + } + } + + renderQortTransactions(transactions, coin) { + const requiredConfirmations = 3 // arbitrary value + // initially `currentBlockHeight` might not be set in the store + const currentBlockHeight = window.parent.reduxStore.getState().app.blockInfo.height + if (Array.isArray(transactions)) { + transactions = transactions.map(tx => { + tx.confirmations = (currentBlockHeight - (tx.blockHeight - 1)) || '' + return tx + }) + } + + return html` + + + +
Address has no transactions yet.
+ + { + if (!currentBlockHeight) { + return render(html``, root) + } + const confirmed = data.item.confirmations >= requiredConfirmations + if (confirmed) { + render(html`check`, root) + } else { + render(html`schedule`, root) + } + }} + > + + { + render(html` ${data.item.type} ${data.item.creatorAddress === this.wallets.get('qort').wallet.address ? html`OUT` : html`IN`} `, root) + }} + > + + + + + + { + const time = new Date(data.item.timestamp) + render(html` `, root) + }} + > + + +
+ ` + } + + renderBTCLikeTransactions(transactions, coin) { + return html` +
Address has no transactions yet.
+ + + { + const amount = (Number(data.item.totalAmount) / 1e8).toFixed(8) + render(html`${amount}`, root) + }} + > + + { + const time = new Date(data.item.timestamp * 1000) + render(html` `, root) + }} + > + + +
+ ` + } + + async updateItemsFromPage(page, changeWallet = false) { + if (page === undefined) { + return + } + + changeWallet === true ? (this.pagesControl.innerHTML = '') : null + + if (!this.pages) { + this.pages = Array.apply(null, { length: Math.ceil(this.wallets.get(this._selectedWallet).transactions.length / this.transactionsGrid.pageSize) }).map((item, index) => { + return index + 1 + }) + + const prevBtn = document.createElement('button') + prevBtn.textContent = '<' + prevBtn.addEventListener('click', () => { + const selectedPage = parseInt(this.pagesControl.querySelector('[selected]').textContent) + this.updateItemsFromPage(selectedPage - 1) + }) + this.pagesControl.appendChild(prevBtn) + + this.pages.forEach((pageNumber) => { + const pageBtn = document.createElement('button') + pageBtn.textContent = pageNumber + pageBtn.addEventListener('click', (e) => { + this.updateItemsFromPage(parseInt(e.target.textContent)) + }) + if (pageNumber === page) { + pageBtn.setAttribute('selected', true) + } + this.pagesControl.appendChild(pageBtn) + }) + + const nextBtn = window.document.createElement('button') + nextBtn.textContent = '>' + nextBtn.addEventListener('click', () => { + const selectedPage = parseInt(this.pagesControl.querySelector('[selected]').textContent) + this.updateItemsFromPage(selectedPage + 1) + }) + this.pagesControl.appendChild(nextBtn) + } + + const buttons = Array.from(this.pagesControl.children) + buttons.forEach((btn, index) => { + if (parseInt(btn.textContent) === page) { + btn.setAttribute('selected', true) + } else { + btn.removeAttribute('selected') + } + if (index === 0) { + if (page === 1) { + btn.setAttribute('disabled', '') + } else { + btn.removeAttribute('disabled') + } + } + if (index === buttons.length - 1) { + if (page === this.pages.length) { + btn.setAttribute('disabled', '') + } else { + btn.removeAttribute('disabled') + } + } + }) + let start = (page - 1) * this.transactionsGrid.pageSize + let end = page * this.transactionsGrid.pageSize + + this.transactionsGrid.items = this.wallets.get(this._selectedWallet).transactions.slice(start, end) + } + + _textMenu(event) { + const getSelectedText = () => { + var text = '' + if (typeof window.getSelection != 'undefined') { + text = window.getSelection().toString() + } else if (typeof this.shadowRoot.selection != 'undefined' && this.shadowRoot.selection.type == 'Text') { + text = this.shadowRoot.selection.createRange().text + } + return text + } + const checkSelectedTextAndShowMenu = () => { + let selectedText = getSelectedText() + if (selectedText && typeof selectedText === 'string') { + let _eve = { pageX: event.pageX, pageY: event.pageY, clientX: event.clientX, clientY: event.clientY } + + let textMenuObject = { selectedText: selectedText, eventObject: _eve, isFrame: true } + + parentEpml.request('openCopyTextMenu', textMenuObject) + } + } + + checkSelectedTextAndShowMenu() + } + + clearSelection() { + window.getSelection().removeAllRanges() + window.parent.getSelection().removeAllRanges() + } + + transactionItem(transactionObject) { + return ` +
+
+

${transactionObject.name}

+ ${transactionObject.category} ${transactionObject.ID} - ${transactionObject.date} +
+
+

${transactionObject.amount}

+
+
+ ` + } + + firstUpdated() { + // DOM refs + this.currencyBoxes = this.shadowRoot.querySelectorAll('.currency-box') + this.transactionsDOM = this.shadowRoot.getElementById('transactionsDOM') + + // Attach eventlisteners to the cuurency boxes + this.currencyBoxes.forEach((currencyBox) => { + currencyBox.addEventListener('click', this.selectWallet) + }) + + this.showWallet() + + window.addEventListener('contextmenu', (event) => { + event.preventDefault() + this.isTextMenuOpen = true + this._textMenu(event) + }) + window.addEventListener('click', () => { + if (this.isTextMenuOpen) { + parentEpml.request('closeCopyTextMenu', null) + } + }) + window.onkeyup = (e) => { + if (e.keyCode === 27) { + parentEpml.request('closeCopyTextMenu', null) + } + } + } + + selectWallet(event) { + event.preventDefault() + + const target = event.currentTarget + + // if (target.classList.contains('active')) return + // removed to allow one click wallet refresh + + this.currencyBoxes.forEach((currencyBox) => { + if (currencyBox.classList.contains('active')) { + currencyBox.classList.remove('active') + } + }) + target.classList.add('active') + this._selectedWallet=target.attributes.coin.value + this.showWallet() + } + +async showWallet(){ + this.transactionsDOM.hidden = true + this.loading = true + + if (this._selectedWallet=='qort') { + if (!window.parent.reduxStore.getState().app.blockInfo.height) { + // we make sure that `blockHeight` is set before rendering QORT transactions + await parentEpml.request('apiCall', { url: `/blocks/height`, type: 'api' }) + .then(height => parentEpml.request('updateBlockInfo', { height })) + } + } + const coin=this._selectedWallet + await this.fetchWalletDetails(this._selectedWallet) + if(this._selectedWallet == coin){//if the wallet didn't switch + await this.renderTransactions() + await this.getTransactionGrid(this._selectedWallet) + await this.updateItemsFromPage(1, true) + this.loading = false + this.transactionsDOM.hidden = false + } +} + async fetchWalletDetails(coin){//this function will fetch the balance and transactions of the given wallet + this.balanceString="Fetching balance ..." + switch (coin) { + case 'qort': + //fetching the qort balance + parentEpml + .request('apiCall', { + url: `/addresses/balance/${this.wallets.get('qort').wallet.address}`, + }) + .then((res) => { + if (isNaN(Number(res))) { + parentEpml.request('showSnackBar', `Failed to Fetch QORT Balance. Try again!`) + } else { + if(this._selectedWallet==coin){//check if we are still fetching wallet balance ... + this.wallets.get(coin).balance = res + this.balanceString=this.wallets.get(this._selectedWallet).balance+" "+this._selectedWallet.toLocaleUpperCase() + } + } + }) + //fetching the qort transactions + const txsQort = await parentEpml.request('apiCall', { + url: `/transactions/search?address=${this.wallets.get('qort').wallet.address}&confirmationStatus=BOTH&reverse=true`, + }) + if(this._selectedWallet==coin) + this.wallets.get(coin).transactions = txsQort + + break + case 'btc': + case 'ltc': + case 'doge': + //fetching the balance + const walletName = `${coin}Wallet` + parentEpml + .request('apiCall', { + url: `/crosschain/${coin}/walletbalance`, + method: 'POST', + body: `${window.parent.reduxStore.getState().app.selectedAddress[walletName].derivedMasterPublicKey}`, + }) + .then((res) => { + if (isNaN(Number(res))) { + parentEpml.request('showSnackBar', `Failed to Fetch ${coin.toLocaleUpperCase()} Balance. Try again!`) + } else { + if(this._selectedWallet==coin){//check if we are still fetching wallet balance ... + this.wallets.get(this._selectedWallet).balance = (Number(res) / 1e8).toFixed(8) + this.balanceString=this.wallets.get(this._selectedWallet).balance+" "+this._selectedWallet.toLocaleUpperCase() + } + } + }) + //fetching transactions + const txs = await parentEpml.request('apiCall', { + url: `/crosschain/${coin}/wallettransactions`, + method: 'POST', + body: `${window.parent.reduxStore.getState().app.selectedAddress[walletName].derivedMasterPublicKey}`, + }) + const compareFn = (a, b) => { + return b.timestamp - a.timestamp + } + const sortedTransactions = txs.sort(compareFn) + + if(this._selectedWallet==coin){ + this.wallets.get(this._selectedWallet).transactions = sortedTransactions + } + break + default: + break + } + } + + showTransactionDetails(myTransaction, allTransactions) { + allTransactions.forEach((transaction) => { + if (myTransaction.signature === transaction.signature) { + // Do something... + let txnFlow = myTransaction.creatorAddress === this.wallets.get('qort').wallet.address ? 'OUT' : 'IN' + this.selectedTransaction = { ...transaction, txnFlow } + if (this.selectedTransaction.signature.length != 0) { + this.shadowRoot.querySelector('#showTransactionDetailsDialog').show() + } + } + }) + } + + isEmptyArray(arr) { + if (!arr) { + return true + } + return arr.length === 0 + } + + floor(num) { + num = parseFloat(num) + return isNaN(num) ? 0 : this._format(Math.floor(num)) + } + + decimals(num) { + num = parseFloat(num) // So that conversion to string can get rid of insignificant zeros + // return isNaN(num) ? 0 : (num + "").split(".")[1] + return num % 1 > 0 ? (num + '').split('.')[1] : '0' + } + + subtract(num1, num2) { + return num1 - num2 + } + + getConfirmations(height, lastBlockHeight) { + return lastBlockHeight - height + 1 + } + + _format(num) { + return num.toLocaleString() + } + + textColor(color) { + return color === 'light' ? 'rgba(255,255,255,0.7)' : 'rgba(0,0,0,0.87)' + } + _unconfirmedClass(unconfirmed) { + return unconfirmed ? 'unconfirmed' : '' + } +} + +window.customElements.define('multi-wallet', MultiWallet) diff --git a/qortal-ui-plugins/plugins/utils/keyCodes.js b/qortal-ui-plugins/plugins/utils/keyCodes.js new file mode 100644 index 00000000..d4d6ca50 --- /dev/null +++ b/qortal-ui-plugins/plugins/utils/keyCodes.js @@ -0,0 +1 @@ +export const inputKeyCodes = [48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, 160, 161, 162, 163, 164, 165, 170, 171, 186, 187, 188, 189, 190, 191, 192, 193, 194, 219, 220, 221, 222, 223, 226]; diff --git a/qortal-ui-plugins/rollup.config.js b/qortal-ui-plugins/rollup.config.js new file mode 100644 index 00000000..fd333d2d --- /dev/null +++ b/qortal-ui-plugins/rollup.config.js @@ -0,0 +1,188 @@ +// From original frag-ui build + +import babel from '@rollup/plugin-babel' +import { nodeResolve } from '@rollup/plugin-node-resolve' +import builtins from 'rollup-plugin-node-builtins' +import globals from 'rollup-plugin-node-globals' +import commonjs from '@rollup/plugin-commonjs' + +import sass from 'rollup-plugin-sass' +import autoprefixer from 'autoprefixer' +import postcss from 'postcss' + +// import minifyHTML from 'rollup-plugin-minify-html-literals' +import { terser } from 'rollup-plugin-terser' + +const sassOptions = { + output: 'build/styles.bundle.css', + processor: css => postcss([autoprefixer]) + .process(css) + .then(result => result.css) +} + +const babelOptions = { + babelHelpers: 'bundled', + // exclude: 'node_modules/**', + exclude: ['node_modules/babel-runtime/**', /[\/\\]core-js/, 'node_modules/@babel/runtime-corejs3/**', 'node_modules/@webcomponentsjs/**'], + // exclude: 'node_modules/core-js/**', + ignore: [/[\/\\]core-js/, 'node_modules/@babel/runtime-corejs3/**', 'node_modules/@webcomponentsjs/**'], + runtimeHelpers: true, + presets: [ + [ + '@babel/preset-env', + { + // 'targets': 'Chrome 60, Firefox 66', + // debug: true, + // modules: 'false', + // targets: { + // browsers: 'Edge 16, Firefox 60, Chrome 61, Safari 11, Android 67, ChromeAndroid 73, FirefoxAndroid 66' + // }, + // useBuiltIns: 'usage', + useBuiltIns: 'entry', + corejs: '3' + } + ] + ], + plugins: [ + '@babel/plugin-syntax-dynamic-import', + [ + '@babel/transform-runtime', { + corejs: 3 + } + ] + ] +} + +const plugins = [ + nodeResolve({ + module: true + }), + commonjs({}), + globals(), + builtins(), + sass(sassOptions) +] + +if (process.env.NODE_ENV === 'production') { + plugins.push( + // minifyHTML(), + terser() + ) +} + +export default [ + { + context: 'window', + input: 'src/main.js', + output: [ + { + dir: 'build/es6', + format: 'es' + } + ], + plugins: plugins.concat([ + babel.babel(babelOptions) + ]) + }, + { + context: 'self', + input: 'src/worker.js', + output: [ + { + dir: 'build/es6', + format: 'iife' + } + ], + plugins: plugins.concat([ + babel.babel(babelOptions) + ]) + }, + { + context: 'window', + input: 'src/plugins/plugin-mainjs-loader.js', + output: [ + { + dir: 'build/es6', + format: 'iife' + } + ], + plugins: plugins.concat([ + babel.babel(babelOptions) + ]) + }, + { + context: 'window', + input: 'src/main.js', + output: [ + { + dir: 'build/es5', + format: 'system' + } + ], + plugins: plugins.concat([babel({ + ...babelOptions//, + // presets: [ + // [ + // '@babel/preset-env', + // { + // useBuiltIns: 'usage', + // targets: 'IE 10', + // corejs: '3' + // } + // ] + // ] + })]) + }, + { + context: 'window', + input: 'plugins/core/wallet/wallet-app.js', + output: [ + { + dir: 'plugins/core/wallet/build', + format: 'iife' + } + ], + plugins: plugins.concat([ + babel.babel(babelOptions) + ]) + }, + { + context: 'window', + input: 'plugins/core/main.src.js', + output: [ + { + file: 'plugins/core/main.js', + format: 'iife' + } + ], + plugins: plugins.concat([ + babel.babel(babelOptions) + ]) + }, + { + context: 'window', + input: 'plugins/core/send-coin/send-coin.src.js', + output: [ + { + file: 'plugins/core/send-coin/send-coin.js', + format: 'iife' + } + ], + plugins: plugins.concat([ + babel.babel(babelOptions) + ]) + }, + { + context: 'window', + input: 'plugins/chat/chat-app.src.js', + output: [ + { + file: 'plugins/chat/chat-app.js', + format: 'iife' + } + ], + plugins: plugins.concat([ + babel.babel(babelOptions) + ]) + } +] diff --git a/qortal-ui-plugins/watch.js b/qortal-ui-plugins/watch.js new file mode 100644 index 00000000..95687222 --- /dev/null +++ b/qortal-ui-plugins/watch.js @@ -0,0 +1,27 @@ +const rollup = require('rollup') + +const configs = require('./build-config.js')() + +const watch = () => { + configs.forEach(async file => { + const watchOptions = { + ...file.inputOptions, + output: [file.outputOptions], + watch: { + // chokidar, + // clearScreen, + // exclude, + // include + } + } + + const watcher = rollup.watch(watchOptions) + + watcher.on('event', event => { + // ... + }) + }) + console.log('WATCH PLUGINS ==> Write Bundle : Done 🎉'); +} + +module.exports = watch diff --git a/run_server.bat b/run_server.bat new file mode 100644 index 00000000..34f30698 --- /dev/null +++ b/run_server.bat @@ -0,0 +1,34 @@ +@echo off + +:: BatchGotAdmin +:------------------------------------- +REM --> Check for permissions + IF "%PROCESSOR_ARCHITECTURE%" EQU "amd64" ( +>nul 2>&1 "%SYSTEMROOT%\SysWOW64\cacls.exe" "%SYSTEMROOT%\SysWOW64\config\system" +) ELSE ( +>nul 2>&1 "%SYSTEMROOT%\system32\cacls.exe" "%SYSTEMROOT%\system32\config\system" +) + +REM --> If error flag set, we do not have admin. +if '%errorlevel%' NEQ '0' ( + echo Requesting administrative privileges... + goto UACPrompt +) else ( goto gotAdmin ) + +:UACPrompt + echo Set UAC = CreateObject^("Shell.Application"^) > "%temp%\getadmin.vbs" + set params= %* + echo UAC.ShellExecute "cmd.exe", "/c ""%~s0"" %params:"=""%", "", "runas", 1 >> "%temp%\getadmin.vbs" + + "%temp%\getadmin.vbs" + del "%temp%\getadmin.vbs" + exit /B + +:gotAdmin + pushd "%CD%" + CD /D "%~dp0" +:-------------------------------------- +npm run server +REM start /WAIT /B npm run install +REM sleep 1 +PAUSE \ No newline at end of file diff --git a/scripts/add-debian-apt-repo.sh b/scripts/add-debian-apt-repo.sh new file mode 100644 index 00000000..21eddfac --- /dev/null +++ b/scripts/add-debian-apt-repo.sh @@ -0,0 +1,27 @@ +#!/bin/bash + +# Make necessary config and add LOTW Softwares apt repo + +# SCript to run UI without sandbox +echo \'/opt/${productFilename}/qortal-ui\' --no-sandbox > '/opt/${productFilename}/run-ui' +chmod +x '/opt/${productFilename}/run-ui' + +# Link to run-ui +ln -sf '/opt/${productFilename}/run-ui' '/usr/bin/${executable}' + +# SUID chrome-sandbox for Electron 5+ +sudo chown root '/opt/${productFilename}/chrome-sandbox' || true +sudo chmod 4755 '/opt/${productFilename}/chrome-sandbox' || true + +update-mime-database /usr/share/mime || true +update-desktop-database /usr/share/applications || true + +# Install curl if not installed on the system +if ! which curl; then sudo apt-get --yes install curl; fi + +# Install apt repository source list if it does not exist +if ! grep ^ /etc/apt/sources.list /etc/apt/sources.list.d/* | grep qortal.list; then + curl -sS https://lotw.qortal.org/lotw_pub.gpg | sudo apt-key add - + echo "deb [arch=amd64] https://lotw.qortal.org/debian stable main" \ + | sudo tee /etc/apt/sources.list.d/qortal.list +fi diff --git a/scripts/afterPack.js b/scripts/afterPack.js new file mode 100644 index 00000000..747e06db --- /dev/null +++ b/scripts/afterPack.js @@ -0,0 +1,45 @@ +const path = require('path') +const shell = require("shelljs"); + +const runShellCommand = (appOutDir) => { + + shell.exec( + `chmod 4755 ${path.join(appOutDir, "chrome-sandbox")}`, + + function (code, stdout, stderr) { + console.log('runShellCommand ==> Exit code:', code); + if (stderr) { + console.log('runShellCommand ==> Program stderr:', stderr); + } + }); +} + +async function doLinux(context) { + + console.log("Running doLinux ==> "); + + const { targets, appOutDir } = context + + targets.forEach(async target => { + + if (!["appimage", "snap"].includes(target.name.toLowerCase())) { + + await runShellCommand(appOutDir) + } + }); +} + +async function afterPack(context) { + + console.log("Running AfterPack"); + + const electronPlatformName = context.electronPlatformName.toLowerCase(); + + if (electronPlatformName.includes("linux")) { + await doLinux(context); + return; + } + +} + +module.exports = afterPack diff --git a/scripts/uninstall-debian-conf.sh b/scripts/uninstall-debian-conf.sh new file mode 100644 index 00000000..cc02cedf --- /dev/null +++ b/scripts/uninstall-debian-conf.sh @@ -0,0 +1,35 @@ +#!/bin/bash + +# Remove all conf made by the the software + +# Remove apt repository source list when user uninstalls app +if grep ^ /etc/apt/sources.list /etc/apt/sources.list.d/* | grep qortal.list; then + sudo apt-key del 5025E50F; + sudo rm /etc/apt/sources.list.d/qortal.list; +fi + +# Get the root user +if [ $SUDO_USER ]; + then getSudoUser=$SUDO_USER; + else getSudoUser=`whoami`; +fi + +getDesktopEntry=/home/$getSudoUser/.config/autostart/qortal.desktop; + +# Remove desktop entry if exists +if [ -f $getDesktopEntry ]; then + sudo rm $getDesktopEntry; +fi + +# App directory which contains all the config, setting files +appDirectory=/home/$getSudoUser/.config/qortal-ui/; + +if [ -d $appDirectory ]; then + sudo rm -rf $appDirectory; +fi + +# Delete the link to the binary +rm -f '/usr/bin/${executable}' + +# Delete run-ui +rm -f '/opt/${productFilename}/run-ui' diff --git a/server.js b/server.js new file mode 100644 index 00000000..4bd13e1a --- /dev/null +++ b/server.js @@ -0,0 +1,30 @@ +const path = require("path") + +const uiCore = require('qortal-ui-core') +const createServer = uiCore('server') + +const config = require('./config/config.js') + +const pluginsController = require('qortal-ui-plugins') +const qortalPlugins = pluginsController('plugins') + +const plugins = [ + ...qortalPlugins +] + +const rootDir = process.env.NODE_ENV === 'production' ? __dirname : __dirname + + +const conf = { + ...config, + build: { + ...config.build, + options: { + ...config.build.options, + outputDir: path.join(rootDir, '/builtWWW') + } + } +} + +const server = createServer(conf, plugins) +server.start() diff --git a/set-up-snap.sh b/set-up-snap.sh new file mode 100644 index 00000000..2e161f8c --- /dev/null +++ b/set-up-snap.sh @@ -0,0 +1,28 @@ +#!/bin/sh + +# Qortal Blockchain Project - 2021 + +# Script to install and setup snapstore + +set -ev + +setup_snap() +{ + +# echo -e '---INSTALLING SNAPD---' + +# sudo apt update +# sudo apt install snapd + + echo -e '---INSTALLING SNAPCRAFT!---' + + sudo snap install snapcraft --classic + + echo -e 'LOGIN TO SNAP' + echo $SNAP_TOKEN | snapcraft login --with - + + + +} + +setup_snap diff --git a/snap/gui/256x256.png b/snap/gui/256x256.png new file mode 100644 index 00000000..5b1df7a8 Binary files /dev/null and b/snap/gui/256x256.png differ diff --git a/snap/snapcraft.yaml b/snap/snapcraft.yaml new file mode 100644 index 00000000..e38e8b33 --- /dev/null +++ b/snap/snapcraft.yaml @@ -0,0 +1,41 @@ +name: qortal-ui +version: 1.6.3 +summary: Qortal UI for Linux +description: Qortal Project - decentralize the world - Data storage, communications, web hosting, decentralized trading, complete infrastructure for the future blockchain-based Internet. +confinement: strict +grade: stable +icon: snap/gui/256x256.png +architectures: + - build-on: amd64 + run-on: [amd64, armhf, arm64, i386, ppc64el, s390x] +base: core18 +apps: + qortal-ui: + command: qortal-ui + plugs: + - desktop + - desktop-legacy + - home + - x11 + - unity7 + - browser-support + - network + - gsettings + - pulseaudio + - opengl +parts: + app: + plugin: dump + stage-packages: + - libasound2 + - libgconf2-4 + - libnotify4 + - libnspr4 + - libnss3 + - libpcre3 + - libpulse0 + - libxss1 + - libxtst6 + source: dist/linux-unpacked + after: + - desktop-gtk3 diff --git a/update-package-json.js b/update-package-json.js new file mode 100644 index 00000000..b6346ac6 --- /dev/null +++ b/update-package-json.js @@ -0,0 +1,29 @@ +const fs = require('fs') + +const uiPackageFilePath = 'package.json'; +const uiPackageFile = fs.readFileSync(uiPackageFilePath, 'utf8'); +const uiPackage = JSON.parse(uiPackageFile); + +const corePackageFilePath = './qortal-ui-core/package.json'; +const corePackageFile = fs.readFileSync(corePackageFilePath, 'utf8'); +const corePackage = JSON.parse(corePackageFile); + +const cryptoPackageFilePath = './qortal-ui-crypto/package.json'; +const cryptoPackageFile = fs.readFileSync(cryptoPackageFilePath, 'utf8'); +const cryptoPackage = JSON.parse(cryptoPackageFile); + +const pluginsPackageFilePath = './qortal-ui-plugins/package.json'; +const pluginsPackageFile = fs.readFileSync(pluginsPackageFilePath, 'utf8'); +const pluginsPackage = JSON.parse(pluginsPackageFile); + +uiPackage.dependencies = { + ...uiPackage.dependencies, + "qortal-ui-core": corePackage.version, + "qortal-ui-crypto": cryptoPackage.version, + "qortal-ui-plugins": pluginsPackage.version +} + +console.log(uiPackage.dependencies); + +fs.writeFileSync(uiPackageFilePath, JSON.stringify(uiPackage, null, 2)); +console.log('Package.Json updated'); diff --git a/watch-inline.js b/watch-inline.js new file mode 100644 index 00000000..90676631 --- /dev/null +++ b/watch-inline.js @@ -0,0 +1,25 @@ +const path = require('path') +const uiCore = require('qortal-ui-core') +const generateBuildConfig = uiCore('generate_build_config') +const watchInlines = uiCore('watch_inline') +const config = require('./config/config.js') + +const pluginsController = require('qortal-ui-plugins') +const watchDefaultPlugins = pluginsController('watch') + + +let srcConfig = { + ...config.build, + options: { + ...config.build.options, + outputDir: path.join(__dirname, '/builtWWW'), + sassOutputDir: path.join(__dirname, '/builtWWW/styles.bundle.css'), + } +} + +const { inlineConfigs } = generateBuildConfig(srcConfig) + +module.exports = () => { + watchInlines(inlineConfigs) + watchDefaultPlugins() +} diff --git a/watch.js b/watch.js new file mode 100644 index 00000000..4cb27dd0 --- /dev/null +++ b/watch.js @@ -0,0 +1,25 @@ +const path = require('path') +const uiCore = require('qortal-ui-core') +const generateBuildConfig = uiCore('generate_build_config') +const watch = uiCore('watch') +const config = require('./config/config.js') + +const pluginsController = require('qortal-ui-plugins') +const watchPlugins = pluginsController('watch') + +const watchInline = require('./watch-inline.js') + +let srcConfig = { + ...config.build, + options: { + ...config.build.options, + outputDir: path.join(__dirname, '/builtWWW'), + sassOutputDir: path.join(__dirname, '/builtWWW/styles.bundle.css'), + } +} + +const { buildConfig, inlineConfigs } = generateBuildConfig(srcConfig) + +watch(buildConfig.options, buildConfig.outputs, buildConfig.outputOptions, buildConfig.inputOptions) +watchInline() +watchPlugins()