Hexo Integration (#80)
* add new site with hexo static site generator * ignore DS_Store files from mac
|
@ -9,4 +9,5 @@ lib/
|
||||||
module/
|
module/
|
||||||
/examples/react-example1/src/contract.json
|
/examples/react-example1/src/contract.json
|
||||||
coverage/
|
coverage/
|
||||||
lerna-debug.log
|
lerna-debug.log
|
||||||
|
.DS_Store
|
|
@ -0,0 +1,8 @@
|
||||||
|
root = true
|
||||||
|
|
||||||
|
[*]
|
||||||
|
indent_style = space
|
||||||
|
indent_size = 2
|
||||||
|
charset = utf-8
|
||||||
|
trim_trailing_whitespace = false
|
||||||
|
insert_final_newline = false
|
|
@ -0,0 +1,4 @@
|
||||||
|
dist/
|
||||||
|
lib/
|
||||||
|
module/
|
||||||
|
node_modules/
|
|
@ -0,0 +1,45 @@
|
||||||
|
{
|
||||||
|
"env": {
|
||||||
|
"node": true,
|
||||||
|
"browser": true,
|
||||||
|
"jest": true
|
||||||
|
},
|
||||||
|
"parser": "babel-eslint",
|
||||||
|
"plugins": ["standard", "babel"],
|
||||||
|
"extends": [
|
||||||
|
"eslint:recommended",
|
||||||
|
"plugin:import/errors",
|
||||||
|
"plugin:import/warnings",
|
||||||
|
],
|
||||||
|
"parserOptions": {
|
||||||
|
"ecmaVersion": 2018,
|
||||||
|
"sourceType": "module",
|
||||||
|
"ecmaFeatures": {
|
||||||
|
"jsx": true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"rules": {
|
||||||
|
"arrow-parens": ["error", "as-needed"],
|
||||||
|
"standard/object-curly-even-spacing": [2, "never"],
|
||||||
|
"standard/array-bracket-even-spacing": [2, "either"],
|
||||||
|
"standard/computed-property-even-spacing": [2, "even"],
|
||||||
|
"standard/no-callback-literal": [2, ["cb", "callback"]],
|
||||||
|
"babel/new-cap": 1,
|
||||||
|
"babel/camelcase": 1,
|
||||||
|
"babel/no-invalid-this": 1,
|
||||||
|
"babel/object-curly-spacing": 0,
|
||||||
|
"babel/quotes": 1,
|
||||||
|
"babel/semi": 1,
|
||||||
|
"babel/no-unused-expressions": 1,
|
||||||
|
"babel/valid-typeof": 1,
|
||||||
|
"comma-dangle": "off",
|
||||||
|
"object-curly-newline": "off",
|
||||||
|
"quotes": "off",
|
||||||
|
"semi": "off",
|
||||||
|
"object-curly-spacing": "off",
|
||||||
|
"import/no-extraneous-dependencies": "off",
|
||||||
|
"max-len": ["error", { "code": 120} ],
|
||||||
|
"no-undef": "off"
|
||||||
|
},
|
||||||
|
"overrides": []
|
||||||
|
}
|
|
@ -0,0 +1,13 @@
|
||||||
|
node_modules/
|
||||||
|
.vscode/
|
||||||
|
phoenix.db
|
||||||
|
subspace.db
|
||||||
|
TODO
|
||||||
|
test.js
|
||||||
|
dist/
|
||||||
|
lib/
|
||||||
|
module/
|
||||||
|
/examples/react-example1/src/contract.json
|
||||||
|
coverage/
|
||||||
|
lerna-debug.log
|
||||||
|
.DS_Store
|
|
@ -0,0 +1,12 @@
|
||||||
|
{
|
||||||
|
"trailingComma": "none",
|
||||||
|
"tabWidth": 2,
|
||||||
|
"semi": true,
|
||||||
|
"singleQuote": false,
|
||||||
|
"useTabs": false,
|
||||||
|
"jsxSingleQuote": false,
|
||||||
|
"bracketSpacing": false,
|
||||||
|
"jsxBracketSameLine": false,
|
||||||
|
"arrowParens": "avoid",
|
||||||
|
"printWidth": 120
|
||||||
|
}
|
|
@ -0,0 +1 @@
|
||||||
|
subspace.status.im
|
|
@ -0,0 +1,21 @@
|
||||||
|
MIT License
|
||||||
|
|
||||||
|
Copyright (c) 2019 Status
|
||||||
|
|
||||||
|
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.
|
|
@ -0,0 +1,29 @@
|
||||||
|
![Subspace](https://raw.githubusercontent.com/status-im/subspace/master/logo.png?token=AABLEUFLVJ24SL7R6JIRXVS5T2MFI)
|
||||||
|
===
|
||||||
|
|
||||||
|
## Overview
|
||||||
|
Subspace is a framework agnostic JS library that embraces reactive programming with RxJS, by observing asynchronous changes in Smart Contracts, and providing methods to track and subscribe to events, changes to the state of contracts and address balances, and react to these changes and events via observables.
|
||||||
|
|
||||||
|
Subspace also takes care of syncing under the hood, saving & loading the state in a local database.
|
||||||
|
|
||||||
|
### Install
|
||||||
|
Subspace can be used in browser, node and native script environments. You can install it through `npm` or `yarn`:
|
||||||
|
```
|
||||||
|
npm install --save @embarklabs/subspace web3 rxjs # RxJS and Web3.js are needed peer-dependencies
|
||||||
|
```
|
||||||
|
|
||||||
|
### Documentation
|
||||||
|
https://subspace.embarklabs.io
|
||||||
|
|
||||||
|
## Contribution
|
||||||
|
Thank you for considering to help out with the source code! We welcome contributions from anyone on the internet, and are grateful for even the smallest of fixes!
|
||||||
|
|
||||||
|
If you'd like to contribute to Subspace, please fork, fix, commit and send a pull request for the maintainers to review and merge into the main code base. If you wish to submit more complex changes though, please check up with the core devs first on #embark-status channel to ensure those changes are in line with the general philosophy of the project and/or get some early feedback which can make both your efforts much lighter as well as our review and merge procedures quick and simple.
|
||||||
|
|
||||||
|
### To build:
|
||||||
|
|
||||||
|
* `yarn`
|
||||||
|
* `yarn bootstrap`
|
||||||
|
|
||||||
|
## License
|
||||||
|
MIT
|
|
@ -0,0 +1,49 @@
|
||||||
|
# Hexo Configuration
|
||||||
|
## Docs: https://hexo.io/docs/configuration.html
|
||||||
|
## Source: https://github.com/hexojs/hexo/
|
||||||
|
|
||||||
|
# Site
|
||||||
|
title: SUBSPACE
|
||||||
|
description: Reactive ÐApp Development
|
||||||
|
author: Status Research & Development GmbH
|
||||||
|
|
||||||
|
language: [en, de]
|
||||||
|
locale: en
|
||||||
|
i18n:
|
||||||
|
type: [page, post]
|
||||||
|
permalink_defaults:
|
||||||
|
lang: en
|
||||||
|
i18n_dir: :lang
|
||||||
|
|
||||||
|
source_dir: source/packages/docs
|
||||||
|
|
||||||
|
# URL
|
||||||
|
## If your site is put in a subdirectory, set url as 'http://yoursite.com/child' and root as '/child/'
|
||||||
|
url: http://localhost:4000
|
||||||
|
root: /
|
||||||
|
permalink: :year/:month/:day/:title/
|
||||||
|
post_asset_folder: true
|
||||||
|
|
||||||
|
# Pagination
|
||||||
|
## Set per_page to 0 to disable pagination
|
||||||
|
per_page: 0
|
||||||
|
|
||||||
|
# Extensions
|
||||||
|
## Plugins: https://hexo.io/plugins/
|
||||||
|
## Themes: https://hexo.io/themes/
|
||||||
|
theme: subspace
|
||||||
|
|
||||||
|
prism_plus:
|
||||||
|
enable: true
|
||||||
|
|
||||||
|
highlight:
|
||||||
|
enable: false
|
||||||
|
|
||||||
|
autoprefixer:
|
||||||
|
enable: true
|
||||||
|
browsers:
|
||||||
|
- 'last 2 versions'
|
||||||
|
node_sass:
|
||||||
|
outputStyle: nested
|
||||||
|
precision: 5
|
||||||
|
sourceComments: false
|
After Width: | Height: | Size: 184 KiB |
After Width: | Height: | Size: 216 KiB |
After Width: | Height: | Size: 226 KiB |
After Width: | Height: | Size: 212 KiB |
|
@ -0,0 +1,52 @@
|
||||||
|
{
|
||||||
|
"name": "subspace-docs",
|
||||||
|
"version": "0.0.1",
|
||||||
|
"description": "Subspace Website",
|
||||||
|
"main": "index.js",
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "git+https://github.com/embarklabs/subspace-docs.git"
|
||||||
|
},
|
||||||
|
"license": "MIT",
|
||||||
|
"bugs": {
|
||||||
|
"url": "https://github.com/embarklabs/subspace-docs/issues"
|
||||||
|
},
|
||||||
|
"author": "Status Research & Development GMBH",
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Iuri Matias",
|
||||||
|
"email": "iuri.matias@gmail.com",
|
||||||
|
"homepage": "https://github.com/iurimatias"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Richard Ramos",
|
||||||
|
"email": "info@richardramos.me",
|
||||||
|
"homepage": "https://github.com/richard-ramos"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"homepage": "https://github.com/embarklabs/subspace-docs#readme",
|
||||||
|
"scripts": {
|
||||||
|
"build": "hexo generate",
|
||||||
|
"clean": "hexo clean",
|
||||||
|
"deploy": "hexo deploy",
|
||||||
|
"server": "hexo server"
|
||||||
|
},
|
||||||
|
"hexo": {
|
||||||
|
"version": "4.2.0"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"hexo": "^4.0.0",
|
||||||
|
"hexo-autoprefixer": "^2.0.0",
|
||||||
|
"hexo-generator-archive": "^1.0.0",
|
||||||
|
"hexo-generator-category": "^1.0.0",
|
||||||
|
"hexo-generator-i18n": "^0.0.7",
|
||||||
|
"hexo-generator-index": "^1.0.0",
|
||||||
|
"hexo-generator-tag": "^1.0.0",
|
||||||
|
"hexo-prism-plus": "^1.1.0",
|
||||||
|
"hexo-renderer-ejs": "^1.0.0",
|
||||||
|
"hexo-renderer-marked": "^2.0.0",
|
||||||
|
"hexo-renderer-sass": "^0.4.0",
|
||||||
|
"hexo-renderer-stylus": "^1.1.0",
|
||||||
|
"hexo-server": "^1.0.0"
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1 @@
|
||||||
|
subspace.status.im
|
|
@ -0,0 +1,5 @@
|
||||||
|
.u-text-color-focus {
|
||||||
|
color: get-color(red, 900); }
|
||||||
|
|
||||||
|
.u-text-color-quiet {
|
||||||
|
color: get-color(gray, 500); }
|
|
@ -0,0 +1,8 @@
|
||||||
|
.u-text-l {
|
||||||
|
font-size: 24px; }
|
||||||
|
|
||||||
|
.u-text-uppercase {
|
||||||
|
text-transform: uppercase; }
|
||||||
|
|
||||||
|
.u-text-strong {
|
||||||
|
font-weight: 600; }
|
After Width: | Height: | Size: 184 KiB |
After Width: | Height: | Size: 216 KiB |
After Width: | Height: | Size: 226 KiB |
After Width: | Height: | Size: 212 KiB |
|
@ -0,0 +1,202 @@
|
||||||
|
|
||||||
|
Apache License
|
||||||
|
Version 2.0, January 2004
|
||||||
|
http://www.apache.org/licenses/
|
||||||
|
|
||||||
|
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||||
|
|
||||||
|
1. Definitions.
|
||||||
|
|
||||||
|
"License" shall mean the terms and conditions for use, reproduction,
|
||||||
|
and distribution as defined by Sections 1 through 9 of this document.
|
||||||
|
|
||||||
|
"Licensor" shall mean the copyright owner or entity authorized by
|
||||||
|
the copyright owner that is granting the License.
|
||||||
|
|
||||||
|
"Legal Entity" shall mean the union of the acting entity and all
|
||||||
|
other entities that control, are controlled by, or are under common
|
||||||
|
control with that entity. For the purposes of this definition,
|
||||||
|
"control" means (i) the power, direct or indirect, to cause the
|
||||||
|
direction or management of such entity, whether by contract or
|
||||||
|
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||||
|
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||||
|
|
||||||
|
"You" (or "Your") shall mean an individual or Legal Entity
|
||||||
|
exercising permissions granted by this License.
|
||||||
|
|
||||||
|
"Source" form shall mean the preferred form for making modifications,
|
||||||
|
including but not limited to software source code, documentation
|
||||||
|
source, and configuration files.
|
||||||
|
|
||||||
|
"Object" form shall mean any form resulting from mechanical
|
||||||
|
transformation or translation of a Source form, including but
|
||||||
|
not limited to compiled object code, generated documentation,
|
||||||
|
and conversions to other media types.
|
||||||
|
|
||||||
|
"Work" shall mean the work of authorship, whether in Source or
|
||||||
|
Object form, made available under the License, as indicated by a
|
||||||
|
copyright notice that is included in or attached to the work
|
||||||
|
(an example is provided in the Appendix below).
|
||||||
|
|
||||||
|
"Derivative Works" shall mean any work, whether in Source or Object
|
||||||
|
form, that is based on (or derived from) the Work and for which the
|
||||||
|
editorial revisions, annotations, elaborations, or other modifications
|
||||||
|
represent, as a whole, an original work of authorship. For the purposes
|
||||||
|
of this License, Derivative Works shall not include works that remain
|
||||||
|
separable from, or merely link (or bind by name) to the interfaces of,
|
||||||
|
the Work and Derivative Works thereof.
|
||||||
|
|
||||||
|
"Contribution" shall mean any work of authorship, including
|
||||||
|
the original version of the Work and any modifications or additions
|
||||||
|
to that Work or Derivative Works thereof, that is intentionally
|
||||||
|
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||||
|
or by an individual or Legal Entity authorized to submit on behalf of
|
||||||
|
the copyright owner. For the purposes of this definition, "submitted"
|
||||||
|
means any form of electronic, verbal, or written communication sent
|
||||||
|
to the Licensor or its representatives, including but not limited to
|
||||||
|
communication on electronic mailing lists, source code control systems,
|
||||||
|
and issue tracking systems that are managed by, or on behalf of, the
|
||||||
|
Licensor for the purpose of discussing and improving the Work, but
|
||||||
|
excluding communication that is conspicuously marked or otherwise
|
||||||
|
designated in writing by the copyright owner as "Not a Contribution."
|
||||||
|
|
||||||
|
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||||
|
on behalf of whom a Contribution has been received by Licensor and
|
||||||
|
subsequently incorporated within the Work.
|
||||||
|
|
||||||
|
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||||
|
this License, each Contributor hereby grants to You a perpetual,
|
||||||
|
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||||
|
copyright license to reproduce, prepare Derivative Works of,
|
||||||
|
publicly display, publicly perform, sublicense, and distribute the
|
||||||
|
Work and such Derivative Works in Source or Object form.
|
||||||
|
|
||||||
|
3. Grant of Patent License. Subject to the terms and conditions of
|
||||||
|
this License, each Contributor hereby grants to You a perpetual,
|
||||||
|
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||||
|
(except as stated in this section) patent license to make, have made,
|
||||||
|
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||||
|
where such license applies only to those patent claims licensable
|
||||||
|
by such Contributor that are necessarily infringed by their
|
||||||
|
Contribution(s) alone or by combination of their Contribution(s)
|
||||||
|
with the Work to which such Contribution(s) was submitted. If You
|
||||||
|
institute patent litigation against any entity (including a
|
||||||
|
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||||
|
or a Contribution incorporated within the Work constitutes direct
|
||||||
|
or contributory patent infringement, then any patent licenses
|
||||||
|
granted to You under this License for that Work shall terminate
|
||||||
|
as of the date such litigation is filed.
|
||||||
|
|
||||||
|
4. Redistribution. You may reproduce and distribute copies of the
|
||||||
|
Work or Derivative Works thereof in any medium, with or without
|
||||||
|
modifications, and in Source or Object form, provided that You
|
||||||
|
meet the following conditions:
|
||||||
|
|
||||||
|
(a) You must give any other recipients of the Work or
|
||||||
|
Derivative Works a copy of this License; and
|
||||||
|
|
||||||
|
(b) You must cause any modified files to carry prominent notices
|
||||||
|
stating that You changed the files; and
|
||||||
|
|
||||||
|
(c) You must retain, in the Source form of any Derivative Works
|
||||||
|
that You distribute, all copyright, patent, trademark, and
|
||||||
|
attribution notices from the Source form of the Work,
|
||||||
|
excluding those notices that do not pertain to any part of
|
||||||
|
the Derivative Works; and
|
||||||
|
|
||||||
|
(d) If the Work includes a "NOTICE" text file as part of its
|
||||||
|
distribution, then any Derivative Works that You distribute must
|
||||||
|
include a readable copy of the attribution notices contained
|
||||||
|
within such NOTICE file, excluding those notices that do not
|
||||||
|
pertain to any part of the Derivative Works, in at least one
|
||||||
|
of the following places: within a NOTICE text file distributed
|
||||||
|
as part of the Derivative Works; within the Source form or
|
||||||
|
documentation, if provided along with the Derivative Works; or,
|
||||||
|
within a display generated by the Derivative Works, if and
|
||||||
|
wherever such third-party notices normally appear. The contents
|
||||||
|
of the NOTICE file are for informational purposes only and
|
||||||
|
do not modify the License. You may add Your own attribution
|
||||||
|
notices within Derivative Works that You distribute, alongside
|
||||||
|
or as an addendum to the NOTICE text from the Work, provided
|
||||||
|
that such additional attribution notices cannot be construed
|
||||||
|
as modifying the License.
|
||||||
|
|
||||||
|
You may add Your own copyright statement to Your modifications and
|
||||||
|
may provide additional or different license terms and conditions
|
||||||
|
for use, reproduction, or distribution of Your modifications, or
|
||||||
|
for any such Derivative Works as a whole, provided Your use,
|
||||||
|
reproduction, and distribution of the Work otherwise complies with
|
||||||
|
the conditions stated in this License.
|
||||||
|
|
||||||
|
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||||
|
any Contribution intentionally submitted for inclusion in the Work
|
||||||
|
by You to the Licensor shall be under the terms and conditions of
|
||||||
|
this License, without any additional terms or conditions.
|
||||||
|
Notwithstanding the above, nothing herein shall supersede or modify
|
||||||
|
the terms of any separate license agreement you may have executed
|
||||||
|
with Licensor regarding such Contributions.
|
||||||
|
|
||||||
|
6. Trademarks. This License does not grant permission to use the trade
|
||||||
|
names, trademarks, service marks, or product names of the Licensor,
|
||||||
|
except as required for reasonable and customary use in describing the
|
||||||
|
origin of the Work and reproducing the content of the NOTICE file.
|
||||||
|
|
||||||
|
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||||
|
agreed to in writing, Licensor provides the Work (and each
|
||||||
|
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||||
|
implied, including, without limitation, any warranties or conditions
|
||||||
|
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||||
|
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||||
|
appropriateness of using or redistributing the Work and assume any
|
||||||
|
risks associated with Your exercise of permissions under this License.
|
||||||
|
|
||||||
|
8. Limitation of Liability. In no event and under no legal theory,
|
||||||
|
whether in tort (including negligence), contract, or otherwise,
|
||||||
|
unless required by applicable law (such as deliberate and grossly
|
||||||
|
negligent acts) or agreed to in writing, shall any Contributor be
|
||||||
|
liable to You for damages, including any direct, indirect, special,
|
||||||
|
incidental, or consequential damages of any character arising as a
|
||||||
|
result of this License or out of the use or inability to use the
|
||||||
|
Work (including but not limited to damages for loss of goodwill,
|
||||||
|
work stoppage, computer failure or malfunction, or any and all
|
||||||
|
other commercial damages or losses), even if such Contributor
|
||||||
|
has been advised of the possibility of such damages.
|
||||||
|
|
||||||
|
9. Accepting Warranty or Additional Liability. While redistributing
|
||||||
|
the Work or Derivative Works thereof, You may choose to offer,
|
||||||
|
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||||
|
or other liability obligations and/or rights consistent with this
|
||||||
|
License. However, in accepting such obligations, You may act only
|
||||||
|
on Your own behalf and on Your sole responsibility, not on behalf
|
||||||
|
of any other Contributor, and only if You agree to indemnify,
|
||||||
|
defend, and hold each Contributor harmless for any liability
|
||||||
|
incurred by, or claims asserted against, such Contributor by reason
|
||||||
|
of your accepting any such warranty or additional liability.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
APPENDIX: How to apply the Apache License to your work.
|
||||||
|
|
||||||
|
To apply the Apache License to your work, attach the following
|
||||||
|
boilerplate notice, with the fields enclosed by brackets "[]"
|
||||||
|
replaced with your own identifying information. (Don't include
|
||||||
|
the brackets!) The text should be enclosed in the appropriate
|
||||||
|
comment syntax for the file format. We also recommend that a
|
||||||
|
file or class name and description of purpose be included on the
|
||||||
|
same "printed page" as the copyright notice for easier
|
||||||
|
identification within third-party archives.
|
||||||
|
|
||||||
|
Copyright [yyyy] [name of copyright owner]
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
|
@ -0,0 +1,4 @@
|
||||||
|
<svg width="49" height="48" viewBox="0 0 49 48" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<path d="M32.1917 11.5C32.5901 11.5 32.9722 11.342 33.2539 11.0607C33.5356 10.7794 33.6939 10.3978 33.6939 10V7C33.6939 6.60218 33.5356 6.22064 33.2539 5.93934C32.9722 5.65804 32.5901 5.5 32.1917 5.5C31.7933 5.5 31.4112 5.65804 31.1295 5.93934C30.8478 6.22064 30.6896 6.60218 30.6896 7V10C30.6896 10.3978 30.8478 10.7794 31.1295 11.0607C31.4112 11.342 31.7933 11.5 32.1917 11.5Z" fill="#09D9B9"/>
|
||||||
|
<path d="M42.206 6C42.206 4.4087 41.573 2.88258 40.4461 1.75736C39.3193 0.632141 37.791 0 36.1974 0L12.1631 0C10.5695 0 9.04122 0.632141 7.91439 1.75736C6.78756 2.88258 6.15452 4.4087 6.15452 6V42C6.15452 43.5913 6.78756 45.1174 7.91439 46.2426C9.04122 47.3679 10.5695 48 12.1631 48H36.1974C37.791 48 39.3193 47.3679 40.4461 46.2426C41.573 45.1174 42.206 43.5913 42.206 42V6ZM24.1803 28C24.5764 28 24.9636 28.1173 25.293 28.3371C25.6224 28.5568 25.8791 28.8692 26.0307 29.2346C26.1823 29.6001 26.2219 30.0022 26.1446 30.3902C26.0674 30.7781 25.8766 31.1345 25.5965 31.4142C25.3164 31.6939 24.9595 31.8844 24.571 31.9616C24.1825 32.0387 23.7798 31.9991 23.4138 31.8478C23.0478 31.6964 22.735 31.44 22.515 31.1111C22.2949 30.7822 22.1774 30.3956 22.1774 30C22.1774 29.4696 22.3884 28.9609 22.764 28.5858C23.1396 28.2107 23.6491 28 24.1803 28ZM22.1774 21C22.1774 20.6044 22.2949 20.2178 22.515 19.8889C22.735 19.56 23.0478 19.3036 23.4138 19.1522C23.7798 19.0009 24.1825 18.9613 24.571 19.0384C24.9595 19.1156 25.3164 19.3061 25.5965 19.5858C25.8766 19.8655 26.0674 20.2219 26.1446 20.6098C26.2219 20.9978 26.1823 21.3999 26.0307 21.7654C25.8791 22.1308 25.6224 22.4432 25.293 22.6629C24.9636 22.8827 24.5764 23 24.1803 23C23.6491 23 23.1396 22.7893 22.764 22.4142C22.3884 22.0391 22.1774 21.5304 22.1774 21ZM33.1931 37.5C33.5915 37.5 33.9736 37.658 34.2553 37.9393C34.537 38.2206 34.6953 38.6022 34.6953 39C34.6953 39.3978 34.537 39.7794 34.2553 40.0607C33.9736 40.342 33.5915 40.5 33.1931 40.5H22.1774C21.779 40.5 21.3969 40.342 21.1152 40.0607C20.8335 39.7794 20.6753 39.3978 20.6753 39C20.6753 38.6022 20.8335 38.2206 21.1152 37.9393C21.3969 37.658 21.779 37.5 22.1774 37.5H33.1931ZM33.1931 32C32.797 32 32.4098 31.8827 32.0804 31.6629C31.751 31.4432 31.4943 31.1308 31.3427 30.7654C31.1912 30.3999 31.1515 29.9978 31.2288 29.6098C31.306 29.2219 31.4968 28.8655 31.7769 28.5858C32.057 28.3061 32.4139 28.1156 32.8024 28.0384C33.1909 27.9613 33.5936 28.0009 33.9596 28.1522C34.3256 28.3036 34.6384 28.56 34.8585 28.8889C35.0785 29.2178 35.196 29.6044 35.196 30C35.196 30.5304 34.985 31.0391 34.6094 31.4142C34.2338 31.7893 33.7243 32 33.1931 32ZM33.1931 23C32.797 23 32.4098 22.8827 32.0804 22.6629C31.751 22.4432 31.4943 22.1308 31.3427 21.7654C31.1912 21.3999 31.1515 20.9978 31.2288 20.6098C31.306 20.2219 31.4968 19.8655 31.7769 19.5858C32.057 19.3061 32.4139 19.1156 32.8024 19.0384C33.1909 18.9613 33.5936 19.0009 33.9596 19.1522C34.3256 19.3036 34.6384 19.56 34.8585 19.8889C35.0785 20.2178 35.196 20.6044 35.196 21C35.196 21.5304 34.985 22.0391 34.6094 22.4142C34.2338 22.7893 33.7243 23 33.1931 23ZM15.1674 32C14.7713 32 14.384 31.8827 14.0547 31.6629C13.7253 31.4432 13.4686 31.1308 13.317 30.7654C13.1654 30.3999 13.1257 29.9978 13.203 29.6098C13.2803 29.2219 13.4711 28.8655 13.7512 28.5858C14.0313 28.3061 14.3881 28.1156 14.7767 28.0384C15.1652 27.9613 15.5679 28.0009 15.9339 28.1522C16.2998 28.3036 16.6126 28.56 16.8327 28.8889C17.0528 29.2178 17.1703 29.6044 17.1703 30C17.1703 30.5304 16.9592 31.0391 16.5836 31.4142C16.208 31.7893 15.6986 32 15.1674 32ZM17.1703 39C17.1703 39.3956 17.0528 39.7822 16.8327 40.1111C16.6126 40.44 16.2998 40.6964 15.9339 40.8478C15.5679 40.9991 15.1652 41.0387 14.7767 40.9616C14.3881 40.8844 14.0313 40.6939 13.7512 40.4142C13.4711 40.1345 13.2803 39.7781 13.203 39.3902C13.1257 39.0022 13.1654 38.6001 13.317 38.2346C13.4686 37.8692 13.7253 37.5568 14.0547 37.3371C14.384 37.1173 14.7713 37 15.1674 37C15.6986 37 16.208 37.2107 16.5836 37.5858C16.9592 37.9609 17.1703 38.4696 17.1703 39ZM15.1674 23C14.7713 23 14.384 22.8827 14.0547 22.6629C13.7253 22.4432 13.4686 22.1308 13.317 21.7654C13.1654 21.3999 13.1257 20.9978 13.203 20.6098C13.2803 20.2219 13.4711 19.8655 13.7512 19.5858C14.0313 19.3061 14.3881 19.1156 14.7767 19.0384C15.1652 18.9613 15.5679 19.0009 15.9339 19.1522C16.2998 19.3036 16.6126 19.56 16.8327 19.8889C17.0528 20.2178 17.1703 20.6044 17.1703 21C17.1703 21.5304 16.9592 22.0391 16.5836 22.4142C16.208 22.7893 15.6986 23 15.1674 23ZM12.1631 4H36.1974C36.7286 4 37.2381 4.21071 37.6137 4.58579C37.9893 4.96086 38.2003 5.46957 38.2003 6V12.5C38.2003 12.6326 38.1475 12.7598 38.0536 12.8536C37.9597 12.9473 37.8324 13 37.6996 13H10.661C10.5282 13 10.4008 12.9473 10.3069 12.8536C10.213 12.7598 10.1602 12.6326 10.1602 12.5V6C10.1602 5.46957 10.3713 4.96086 10.7469 4.58579C11.1225 4.21071 11.6319 4 12.1631 4Z" fill="#09D9B9"/>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 4.8 KiB |
|
@ -0,0 +1,10 @@
|
||||||
|
<svg width="38" height="38" viewBox="0 0 38 38" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<g clip-path="url(#clip0)">
|
||||||
|
<path d="M31.9042 6.39667C31.7256 6.36022 31.5651 6.26329 31.4497 6.12224C31.3343 5.98119 31.2712 5.80465 31.2708 5.62242V3.16667C31.2708 2.32681 30.9372 1.52136 30.3433 0.927495C29.7495 0.33363 28.944 0 28.1042 0L8.3125 0C7.05272 0 5.84454 0.500445 4.95374 1.39124C4.06295 2.28204 3.5625 3.49022 3.5625 4.75V33.25C3.5625 34.5098 4.06295 35.718 4.95374 36.6088C5.84454 37.4996 7.05272 38 8.3125 38H31.2708C32.1107 38 32.9161 37.6664 33.51 37.0725C34.1039 36.4786 34.4375 35.6732 34.4375 34.8333V9.5C34.4377 8.76999 34.1856 8.06234 33.7239 7.49683C33.2623 6.93132 32.6194 6.54267 31.9042 6.39667ZM6.72917 4.75C6.72917 4.33007 6.89598 3.92735 7.19291 3.63041C7.48985 3.33348 7.89257 3.16667 8.3125 3.16667H27.7083C27.8133 3.16667 27.914 3.20837 27.9882 3.2826C28.0625 3.35684 28.1042 3.45752 28.1042 3.5625V5.9375C28.1042 6.04248 28.0625 6.14316 27.9882 6.2174C27.914 6.29163 27.8133 6.33333 27.7083 6.33333H8.3125C7.89257 6.33333 7.48985 6.16652 7.19291 5.86959C6.89598 5.57265 6.72917 5.16993 6.72917 4.75ZM28.2213 31.6413C28.1471 31.7305 28.0541 31.8022 27.949 31.8515C27.844 31.9007 27.7294 31.9263 27.6133 31.9263H10.3867C10.2708 31.9265 10.1563 31.9013 10.0513 31.8524C9.94621 31.8035 9.85319 31.7321 9.77874 31.6433C9.7043 31.5545 9.65025 31.4505 9.62042 31.3385C9.59058 31.2265 9.58569 31.1094 9.60608 30.9953C9.74825 30.1711 10.0074 29.3713 10.3756 28.6203C11.0833 27.2017 12.8646 26.3308 16.1199 25.1243C16.2567 24.7401 16.2523 24.3197 16.1073 23.9384C14.8331 22.338 14.2034 20.319 14.3418 18.278C14.3089 17.6458 14.4049 17.0136 14.6241 16.4198C14.8433 15.8259 15.1811 15.2829 15.6169 14.8238C16.0527 14.3647 16.5774 13.999 17.159 13.7492C17.7406 13.4994 18.367 13.3705 19 13.3705C19.633 13.3705 20.2594 13.4994 20.841 13.7492C21.4226 13.999 21.9473 14.3647 22.3831 14.8238C22.8189 15.2829 23.1567 15.8259 23.3759 16.4198C23.5951 17.0136 23.6911 17.6458 23.6582 18.278C23.7956 20.3354 23.156 22.3695 21.8658 23.978C21.7369 24.359 21.7515 24.774 21.907 25.1449C25.1354 26.334 26.9167 27.2032 27.6244 28.6283C27.9926 29.3793 28.2518 30.179 28.3939 31.0033C28.4128 31.1158 28.4072 31.231 28.3774 31.3412C28.3476 31.4513 28.2944 31.5537 28.2213 31.6413Z" fill="#09D9B9"/>
|
||||||
|
</g>
|
||||||
|
<defs>
|
||||||
|
<clipPath id="clip0">
|
||||||
|
<rect width="38" height="38" fill="white"/>
|
||||||
|
</clipPath>
|
||||||
|
</defs>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 2.3 KiB |
|
@ -0,0 +1 @@
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><title>close</title><path d="M14.3,12.179a.25.25,0,0,1,0-.354l9.263-9.262A1.5,1.5,0,0,0,21.439.442L12.177,9.7a.25.25,0,0,1-.354,0L2.561.442A1.5,1.5,0,0,0,.439,2.563L9.7,11.825a.25.25,0,0,1,0,.354L.439,21.442a1.5,1.5,0,0,0,2.122,2.121L11.823,14.3a.25.25,0,0,1,.354,0l9.262,9.263a1.5,1.5,0,0,0,2.122-2.121Z"/></svg>
|
After Width: | Height: | Size: 373 B |
|
@ -0,0 +1,11 @@
|
||||||
|
<svg width="52" height="52" viewBox="0 0 52 52" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<g clip-path="url(#clip0)">
|
||||||
|
<path d="M11.9167 35.1173V35.0415C11.9203 34.5082 11.7272 33.9923 11.3742 33.5925C11.0212 33.1928 10.5332 32.9372 10.0035 32.8748C8.4166 32.8894 6.88388 32.2982 5.71784 31.2217C5.23314 30.7067 4.85999 30.0972 4.62175 29.4313C4.38352 28.7655 4.28533 28.0576 4.33334 27.352C4.33392 25.866 4.92435 24.4409 5.97493 23.3899C7.02551 22.339 8.45031 21.748 9.93635 21.7468C10.3259 21.7476 10.7143 21.7883 11.0955 21.8682C11.4002 21.9299 11.7146 21.9259 12.0176 21.8564C12.3206 21.7869 12.6053 21.6535 12.8527 21.4652C13.1125 21.2662 13.3239 21.011 13.471 20.7187C13.6181 20.4264 13.6971 20.1045 13.702 19.7773C13.8775 7.31033 31.6853 3.82417 37.141 15.3465C37.3193 15.7321 37.6086 16.0557 37.9717 16.2761C38.3349 16.4964 38.7555 16.6035 39.1798 16.5837C40.3924 16.5229 41.6029 16.7396 42.7191 17.2171C43.8354 17.6947 44.828 18.4206 45.6213 19.3397C47.0197 20.9378 47.7517 23.0115 47.6667 25.1333C47.6219 26.8782 47.0072 28.5605 45.9164 29.9232C44.8256 31.2859 43.3188 32.2541 41.626 32.6798C41.1839 32.8078 40.7952 33.0757 40.5182 33.4433C40.2412 33.8109 40.0909 34.2584 40.0898 34.7187C40.0878 35.048 40.1626 35.3733 40.3082 35.6687C40.4538 35.9641 40.6663 36.2214 40.9288 36.4204C41.1912 36.6193 41.4964 36.7544 41.8202 36.8148C42.1439 36.8752 42.4773 36.8593 42.7938 36.7683C45.392 36.1382 47.7068 34.6616 49.3735 32.5713C51.0403 30.4809 51.9643 27.8954 52 25.2222C52.124 22.0321 51.022 18.9157 48.9203 16.5126C46.8187 14.1096 43.8768 12.6023 40.6987 12.3002C40.6142 12.292 40.5329 12.2642 40.461 12.2191C40.3892 12.1739 40.3289 12.1127 40.2848 12.0402C38.5715 9.17822 36.038 6.89685 33.0128 5.49171C29.9875 4.08657 26.61 3.62243 23.3179 4.15944C20.0258 4.69645 16.9708 6.20986 14.549 8.50354C12.1271 10.7972 10.4499 13.7654 9.73485 17.0235C9.71115 17.1394 9.65031 17.2444 9.56155 17.3226C9.4728 17.4008 9.36096 17.4479 9.24301 17.4568C7.6329 17.5735 6.07452 18.0759 4.69955 18.9218C3.32457 19.7677 2.17342 20.9321 1.34334 22.3167C0.397727 23.9167 -0.068528 25.7547 1.07624e-05 27.612C-0.0227125 28.85 0.202303 30.08 0.661829 31.2297C1.12135 32.3795 1.80611 33.4257 2.67584 34.307C4.56538 36.0481 6.99881 37.0822 9.56368 37.2342C9.86025 37.2644 10.1599 37.2322 10.4433 37.1397C10.7267 37.0472 10.9875 36.8964 11.2092 36.6971C11.4308 36.4977 11.6082 36.2541 11.7301 35.9821C11.8519 35.71 11.9155 35.4154 11.9167 35.1173Z" fill="#09D9B9"/>
|
||||||
|
<path d="M36.8334 32.8878C36.8247 32.1086 36.54 31.3576 36.0298 30.7685C35.5196 30.1794 34.8171 29.7903 34.047 29.6703C33.9184 29.6516 33.8008 29.5872 33.7156 29.489C33.6305 29.3907 33.5836 29.2652 33.5834 29.1352V26.9295C33.5834 24.9183 32.7844 22.9894 31.3622 21.5673C29.9401 20.1451 28.0112 19.3462 26 19.3462C23.9888 19.3462 22.0599 20.1451 20.6378 21.5673C19.2156 22.9894 18.4167 24.9183 18.4167 26.9295V29.1352C18.4166 29.2648 18.3699 29.3902 18.2852 29.4884C18.2005 29.5866 18.0834 29.6511 17.9552 29.6703C17.1846 29.7894 16.4813 30.1782 15.9706 30.7674C15.4599 31.3567 15.175 32.1081 15.1667 32.8878V44.8045C15.1667 45.6665 15.5091 46.4931 16.1186 47.1026C16.7281 47.7121 17.5547 48.0545 18.4167 48.0545H33.5834C34.4453 48.0545 35.272 47.7121 35.8814 47.1026C36.4909 46.4931 36.8334 45.6665 36.8334 44.8045V32.8878ZM26 42.0962C25.5715 42.0962 25.1526 41.9691 24.7963 41.731C24.44 41.4929 24.1623 41.1546 23.9983 40.7586C23.8343 40.3627 23.7914 39.9271 23.875 39.5068C23.9586 39.0865 24.1649 38.7004 24.468 38.3974C24.771 38.0944 25.157 37.8881 25.5773 37.8045C25.9976 37.7209 26.4333 37.7638 26.8292 37.9278C27.2251 38.0917 27.5635 38.3695 27.8015 38.7258C28.0396 39.0821 28.1667 39.501 28.1667 39.9295C28.1667 40.5041 27.9384 41.0552 27.5321 41.4616C27.1258 41.8679 26.5747 42.0962 26 42.0962ZM22.75 26.9295C22.75 26.0675 23.0924 25.2409 23.7019 24.6314C24.3114 24.0219 25.1381 23.6795 26 23.6795C26.862 23.6795 27.6886 24.0219 28.2981 24.6314C28.9076 25.2409 29.25 26.0675 29.25 26.9295V29.0962C29.25 29.2398 29.193 29.3776 29.0914 29.4792C28.9898 29.5808 28.852 29.6378 28.7084 29.6378H23.2917C23.148 29.6378 23.0103 29.5808 22.9087 29.4792C22.8071 29.3776 22.75 29.2398 22.75 29.0962V26.9295Z" fill="#09D9B9"/>
|
||||||
|
</g>
|
||||||
|
<defs>
|
||||||
|
<clipPath id="clip0">
|
||||||
|
<rect width="52" height="52" fill="white"/>
|
||||||
|
</clipPath>
|
||||||
|
</defs>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 4.2 KiB |
|
@ -0,0 +1,6 @@
|
||||||
|
<svg width="51" height="51" viewBox="0 0 51 51" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<path d="M43.0716 18.8465C41.8415 17.885 40.3256 17.3615 38.7642 17.359C38.3358 17.3613 37.9086 17.4069 37.4892 17.495C37.3952 17.5148 37.3082 17.5595 37.2375 17.6246C37.1669 17.6897 37.1151 17.7727 37.0876 17.8648C37.0599 17.9565 37.0578 18.054 37.0813 18.1469C37.1049 18.2397 37.1534 18.3244 37.2215 18.3918L45.509 26.6793C46.4891 27.6176 47.1612 28.8314 47.4364 30.16C47.6332 31.1822 47.5767 32.2371 47.2719 33.2324C46.967 34.2277 46.423 35.1333 45.6875 35.8699L44.8736 36.6859C44.8194 36.7393 44.7775 36.8038 44.7507 36.875C44.7239 36.9461 44.7129 37.0223 44.7185 37.0982C44.724 37.1744 44.7458 37.2486 44.7824 37.3157C44.8191 37.3828 44.8698 37.4412 44.931 37.487L45.3241 37.7824C45.4916 37.908 45.6326 38.0653 45.7393 38.2454C45.8459 38.4255 45.916 38.6248 45.9456 38.832C45.9752 39.0392 45.9637 39.2502 45.9118 39.4529C45.8598 39.6557 45.7684 39.8462 45.6429 40.0137C45.5173 40.1811 45.36 40.3222 45.1799 40.4288C44.9998 40.5354 44.8005 40.6055 44.5933 40.6351C44.3861 40.6647 44.1751 40.6532 43.9723 40.6013C43.7696 40.5493 43.5791 40.458 43.4116 40.3324L36.4501 35.1113L36.4267 35.0943L36.0017 34.8074C35.7295 34.6367 35.4338 34.5064 35.1241 34.4207C34.4236 34.2136 33.6742 34.245 32.9934 34.5099C32.3127 34.7748 31.7392 35.2581 31.3628 35.8842C30.9864 36.5102 30.8286 37.2435 30.914 37.969C30.9994 38.6944 31.3232 39.371 31.8346 39.8925L32.2469 40.3027C32.3463 40.4026 32.4021 40.5378 32.4021 40.6788C32.4021 40.8197 32.3463 40.955 32.2469 41.0549L30.7594 42.5424C30.7102 42.5918 30.6518 42.631 30.5874 42.6578C30.523 42.6845 30.454 42.6983 30.3843 42.6983C30.3146 42.6983 30.2456 42.6845 30.1812 42.6578C30.1169 42.631 30.0584 42.5918 30.0092 42.5424L11.7428 24.3014C11.6435 24.2018 11.5877 24.0669 11.5877 23.9263C11.5877 23.7857 11.6435 23.6509 11.7428 23.5513L22.5505 12.7499C22.5997 12.7002 22.6583 12.6607 22.7228 12.6338C22.7874 12.6068 22.8567 12.5929 22.9266 12.5929C22.9966 12.5929 23.0658 12.6068 23.1304 12.6338C23.195 12.6607 23.2535 12.7002 23.3027 12.7499L41.548 30.9952C41.6473 31.0947 41.703 31.2296 41.703 31.3702C41.703 31.5108 41.6473 31.6457 41.548 31.7453L40.273 33.0075C40.122 33.1577 40.0033 33.3372 39.9241 33.5349C39.845 33.7326 39.807 33.9443 39.8126 34.1572C39.8181 34.3701 39.8671 34.5796 39.9565 34.7729C40.0459 34.9662 40.1739 35.1392 40.3325 35.2813C40.6247 35.5453 41.0057 35.6895 41.3996 35.6852C41.7934 35.6808 42.1711 35.5283 42.4575 35.2579L43.7941 33.9999L43.8069 33.985C44.5028 33.2885 44.8937 32.3442 44.8937 31.3596C44.8937 30.375 44.5028 29.4307 43.8069 28.7342L25.5553 10.4889C24.8579 9.79207 23.9124 9.40063 22.9266 9.40063C21.9408 9.40063 20.9953 9.79207 20.298 10.4889L9.49025 21.2967C9.14464 21.6418 8.87046 22.0518 8.68339 22.503C8.49633 22.9542 8.40004 23.4379 8.40004 23.9263C8.40004 24.4148 8.49633 24.8985 8.68339 25.3497C8.87046 25.8009 9.14464 26.2108 9.49025 26.556L27.7355 44.8013C28.4336 45.4966 29.3788 45.8869 30.3641 45.8869C31.3494 45.8869 32.2946 45.4966 32.9927 44.8013L34.4802 43.3138C34.5807 43.2152 34.7156 43.1595 34.8564 43.1587C34.9263 43.1588 34.9956 43.1728 35.0601 43.1998C35.1247 43.2267 35.1832 43.2662 35.2325 43.3159L36.0188 44.1C36.2652 44.3465 36.5309 44.5697 36.7986 44.7928C37.9268 45.7437 39.2246 46.4726 40.6236 46.9412L50.0416 50.0798C50.1214 50.1059 50.2063 50.1128 50.2893 50.0999C50.3722 50.087 50.451 50.0547 50.5191 50.0056C50.5873 49.9565 50.6429 49.892 50.6814 49.8174C50.7199 49.7428 50.7402 49.6601 50.7407 49.5762V25.0749C50.7403 24.9925 50.7208 24.9113 50.684 24.8377C50.6472 24.764 50.5939 24.6997 50.5282 24.6499L43.0716 18.8465Z" fill="#09D9B9"/>
|
||||||
|
<path d="M16.7344 4.0863C17.1571 4.0863 17.5624 3.91839 17.8613 3.61951C18.1602 3.32062 18.3281 2.91524 18.3281 2.49255C18.3281 2.06986 18.1602 1.66449 17.8613 1.3656C17.5624 1.06672 17.1571 0.898804 16.7344 0.898804C12.3681 0.903865 8.18219 2.64059 5.0948 5.72798C2.00741 8.81537 0.270687 13.0013 0.265625 17.3676C0.265625 17.7902 0.433537 18.1956 0.732424 18.4945C1.03131 18.7934 1.43669 18.9613 1.85938 18.9613C2.28206 18.9613 2.68744 18.7934 2.98633 18.4945C3.28521 18.1956 3.45312 17.7902 3.45312 17.3676C3.45706 13.8464 4.8576 10.4705 7.34746 7.98064C9.83733 5.49078 13.2132 4.09024 16.7344 4.0863Z" fill="#09D9B9"/>
|
||||||
|
<path d="M10.2467 16.7876C10.2744 16.7185 10.2972 16.6475 10.3147 16.5751C10.4888 15.1441 11.1372 13.8127 12.1563 12.7932C13.1754 11.7737 14.5066 11.1248 15.9375 10.9502C16.0103 10.9315 16.0814 10.9066 16.15 10.8758C16.4181 10.8054 16.6628 10.665 16.8588 10.469C17.0548 10.273 17.1952 10.0284 17.2656 9.76022C17.318 9.56939 17.3331 9.37027 17.3102 9.17372C17.2853 8.9658 17.2194 8.76487 17.1165 8.58251C17.0135 8.40015 16.8755 8.23997 16.7104 8.11118C16.5453 7.9824 16.3563 7.88756 16.1543 7.83213C15.9524 7.7767 15.7415 7.76178 15.5337 7.78822C13.4019 8.05049 11.4189 9.01809 9.90023 10.5371C8.38158 12.0562 7.41448 14.0394 7.15275 16.1713C7.12689 16.3793 7.14228 16.5903 7.19804 16.7922C7.25381 16.9942 7.34885 17.1832 7.47774 17.3484C7.60662 17.5136 7.76682 17.6518 7.94916 17.755C8.1315 17.8582 8.3324 17.9245 8.54037 17.95C8.6052 17.9584 8.6705 17.9627 8.73587 17.9627C8.87255 17.9552 9.00762 17.9294 9.1375 17.8862C9.40243 17.8163 9.64434 17.678 9.83901 17.4852C10.0337 17.2924 10.1743 17.0518 10.2467 16.7876Z" fill="#09D9B9"/>
|
||||||
|
<path d="M18.4556 20.5935C18.3843 20.8571 18.383 21.1348 18.452 21.399C18.5209 21.6633 18.6577 21.9049 18.8488 22.1001L19.6223 22.8757C19.7066 22.9599 19.7603 23.07 19.7745 23.1883C19.7888 23.3066 19.7628 23.4263 19.7009 23.5281C19.324 24.1385 19.1445 24.8503 19.1869 25.5665C19.2294 26.2826 19.4917 26.9682 19.938 27.5299C20.3844 28.0915 20.9931 28.5018 21.6812 28.7048C22.3693 28.9078 23.1033 28.8936 23.783 28.6642L28.0968 27.2277C28.1641 27.2062 28.2366 27.2078 28.3029 27.2323C28.3692 27.2568 28.4254 27.3028 28.4625 27.3629C28.4997 27.423 28.5156 27.4938 28.5079 27.564C28.5001 27.6343 28.4691 27.6999 28.4197 27.7505L25.4001 30.768C25.1011 31.0669 24.9332 31.4725 24.9332 31.8953C24.9332 32.3181 25.1011 32.7236 25.4001 33.0226C25.6991 33.3216 26.1046 33.4895 26.5274 33.4895C26.9503 33.4895 27.3558 33.3216 27.6547 33.0226L28.3369 32.3405C28.386 32.2911 28.4445 32.2519 28.5089 32.2251C28.5732 32.1983 28.6422 32.1846 28.7119 32.1846C28.7816 32.1846 28.8507 32.1983 28.915 32.2251C28.9794 32.2519 29.0378 32.2911 29.087 32.3405L29.7691 33.0226C29.9162 33.1747 30.0921 33.2961 30.2866 33.3795C30.4811 33.4629 30.6903 33.5068 30.9019 33.5085C31.1135 33.5103 31.3233 33.4699 31.5192 33.3896C31.715 33.3094 31.8929 33.191 32.0424 33.0413C32.192 32.8916 32.3103 32.7136 32.3903 32.5177C32.4704 32.3217 32.5106 32.1119 32.5086 31.9002C32.5067 31.6886 32.4626 31.4795 32.379 31.2851C32.2954 31.0907 32.1739 30.9149 32.0216 30.768L31.2503 29.9945C31.1659 29.9103 31.1122 29.8002 31.098 29.6819C31.0837 29.5636 31.1097 29.4439 31.1716 29.3421C31.5483 28.7313 31.7276 28.0193 31.685 27.303C31.6423 26.5866 31.3798 25.9009 30.9333 25.3391C30.4868 24.7774 29.878 24.367 29.1897 24.1638C28.5015 23.9607 27.7674 23.9746 27.0874 24.2038L22.7758 25.6403C22.72 25.6594 22.66 25.6626 22.6026 25.6494C22.5452 25.6363 22.4925 25.6074 22.4506 25.566C22.3922 25.5064 22.3595 25.4263 22.3595 25.3428C22.3595 25.2594 22.3922 25.1793 22.4506 25.1197L25.4703 22.1001C25.7518 21.798 25.905 21.3984 25.8977 20.9855C25.8905 20.5726 25.7232 20.1786 25.4312 19.8866C25.1392 19.5946 24.7453 19.4274 24.3324 19.4201C23.9195 19.4128 23.5199 19.5661 23.2178 19.8476L22.5356 20.5297C22.4354 20.6286 22.3003 20.684 22.1595 20.684C22.0187 20.684 21.8836 20.6286 21.7834 20.5297L21.1034 19.8476C20.9079 19.6571 20.6662 19.5207 20.4021 19.4518C20.1379 19.3829 19.8604 19.3838 19.5968 19.4545C19.3137 19.5067 19.0531 19.6435 18.8494 19.8469C18.6457 20.0502 18.5084 20.3105 18.4556 20.5935Z" fill="#09D9B9"/>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 7.6 KiB |
|
@ -0,0 +1,4 @@
|
||||||
|
<svg width="51" height="51" viewBox="0 0 51 51" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<path d="M1.0625 38.25C1.0625 39.3772 1.51027 40.4582 2.3073 41.2552C3.10433 42.0522 4.18533 42.5 5.3125 42.5H45.6875C46.8147 42.5 47.8957 42.0522 48.6927 41.2552C49.4897 40.4582 49.9375 39.3772 49.9375 38.25V20.1875C49.9375 20.0466 49.8815 19.9115 49.7819 19.8118C49.6823 19.7122 49.5471 19.6562 49.4062 19.6562H1.59375C1.45285 19.6562 1.31773 19.7122 1.2181 19.8118C1.11847 19.9115 1.0625 20.0466 1.0625 20.1875V38.25ZM36.125 33.4688H42.5C42.9227 33.4688 43.3281 33.6367 43.627 33.9355C43.9258 34.2344 44.0938 34.6398 44.0938 35.0625C44.0938 35.4852 43.9258 35.8906 43.627 36.1895C43.3281 36.4883 42.9227 36.6562 42.5 36.6562H36.125C35.7023 36.6562 35.2969 36.4883 34.998 36.1895C34.6992 35.8906 34.5312 35.4852 34.5312 35.0625C34.5312 34.6398 34.6992 34.2344 34.998 33.9355C35.2969 33.6367 35.7023 33.4688 36.125 33.4688ZM9.5625 24.9688H26.5625C26.9852 24.9688 27.3906 25.1367 27.6895 25.4355C27.9883 25.7344 28.1562 26.1398 28.1562 26.5625C28.1562 26.9852 27.9883 27.3906 27.6895 27.6895C27.3906 27.9883 26.9852 28.1562 26.5625 28.1562H9.5625C9.13981 28.1562 8.73443 27.9883 8.43555 27.6895C8.13666 27.3906 7.96875 26.9852 7.96875 26.5625C7.96875 26.1398 8.13666 25.7344 8.43555 25.4355C8.73443 25.1367 9.13981 24.9688 9.5625 24.9688ZM9.5625 33.4688H15.9375C16.3602 33.4688 16.7656 33.6367 17.0645 33.9355C17.3633 34.2344 17.5312 34.6398 17.5312 35.0625C17.5312 35.4852 17.3633 35.8906 17.0645 36.1895C16.7656 36.4883 16.3602 36.6562 15.9375 36.6562H9.5625C9.13981 36.6562 8.73443 36.4883 8.43555 36.1895C8.13666 35.8906 7.96875 35.4852 7.96875 35.0625C7.96875 34.6398 8.13666 34.2344 8.43555 33.9355C8.73443 33.6367 9.13981 33.4688 9.5625 33.4688Z" fill="#09D9B9"/>
|
||||||
|
<path d="M49.9375 12.75C49.9375 11.6228 49.4897 10.5418 48.6927 9.7448C47.8957 8.94777 46.8147 8.5 45.6875 8.5H5.3125C4.18533 8.5 3.10433 8.94777 2.3073 9.7448C1.51027 10.5418 1.0625 11.6228 1.0625 12.75V15.9375C1.0625 16.0784 1.11847 16.2135 1.2181 16.3132C1.31773 16.4128 1.45285 16.4688 1.59375 16.4688H49.4062C49.5471 16.4688 49.6823 16.4128 49.7819 16.3132C49.8815 16.2135 49.9375 16.0784 49.9375 15.9375V12.75Z" fill="#09D9B9"/>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 2.2 KiB |
|
@ -0,0 +1,14 @@
|
||||||
|
<svg width="51" height="51" viewBox="0 0 51 51" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<g clip-path="url(#clip0)">
|
||||||
|
<path d="M31.3438 23.375C31.3438 23.5159 31.3997 23.651 31.4993 23.7507C31.599 23.8503 31.7341 23.9062 31.875 23.9062H35.0625C35.767 23.9062 36.4426 23.6264 36.9408 23.1283C37.4389 22.6301 37.7188 21.9545 37.7188 21.25C37.7188 20.5455 37.4389 19.8699 36.9408 19.3717C36.4426 18.8736 35.767 18.5938 35.0625 18.5938H31.875C31.7341 18.5938 31.599 18.6497 31.4993 18.7493C31.3997 18.849 31.3438 18.9841 31.3438 19.125V23.375Z" fill="#09D9B9"/>
|
||||||
|
<path d="M37.7188 12.75C37.7176 12.0459 37.4374 11.3709 36.9395 10.873C36.4416 10.3751 35.7666 10.0949 35.0625 10.0938H31.875C31.7341 10.0938 31.599 10.1497 31.4993 10.2493C31.3997 10.349 31.3438 10.4841 31.3438 10.625V14.875C31.3438 15.0159 31.3997 15.151 31.4993 15.2507C31.599 15.3503 31.7341 15.4063 31.875 15.4063H35.0625C35.7666 15.4051 36.4416 15.1249 36.9395 14.627C37.4374 14.1291 37.7176 13.4541 37.7188 12.75Z" fill="#09D9B9"/>
|
||||||
|
<path d="M34 0C30.6377 0 27.3509 0.997033 24.5553 2.86502C21.7597 4.733 19.5807 7.38804 18.2941 10.4944C17.0074 13.6007 16.6707 17.0189 17.3267 20.3165C17.9826 23.6142 19.6017 26.6433 21.9792 29.0208C24.3567 31.3983 27.3858 33.0174 30.6835 33.6733C33.9811 34.3293 37.3993 33.9926 40.5056 32.706C43.612 31.4193 46.267 29.2403 48.135 26.4447C50.003 23.6491 51 20.3623 51 17C51 12.4913 49.2089 8.1673 46.0208 4.97919C42.8327 1.79107 38.5087 0 34 0V0ZM28.1563 8.5C28.1563 8.07731 28.3242 7.67193 28.6231 7.37305C28.9219 7.07416 29.3273 6.90625 29.75 6.90625H30.8125C30.9534 6.90625 31.0885 6.85028 31.1882 6.75065C31.2878 6.65102 31.3438 6.5159 31.3438 6.375V5.84375C31.3438 5.42106 31.5117 5.01568 31.8106 4.7168C32.1094 4.41791 32.5148 4.25 32.9375 4.25C33.3602 4.25 33.7656 4.41791 34.0645 4.7168C34.3633 5.01568 34.5313 5.42106 34.5313 5.84375V6.375C34.5313 6.5159 34.5872 6.65102 34.6869 6.75065C34.7865 6.85028 34.9216 6.90625 35.0625 6.90625C36.1919 6.90298 37.2979 7.22801 38.246 7.8418C39.1941 8.45559 39.9433 9.33168 40.4026 10.3635C40.8619 11.3953 41.0114 12.5384 40.833 13.6536C40.6545 14.7688 40.1558 15.8081 39.3975 16.6451C39.3094 16.7427 39.2606 16.8696 39.2606 17.0011C39.2606 17.1326 39.3094 17.2594 39.3975 17.357C40.3674 18.4217 40.9053 19.8098 40.9063 21.25C40.9051 22.7995 40.2891 24.2852 39.1934 25.3809C38.0977 26.4766 36.612 27.0926 35.0625 27.0938C34.9216 27.0938 34.7865 27.1497 34.6869 27.2493C34.5872 27.349 34.5313 27.4841 34.5313 27.625V28.1562C34.5313 28.5789 34.3633 28.9843 34.0645 29.2832C33.7656 29.5821 33.3602 29.75 32.9375 29.75C32.5148 29.75 32.1094 29.5821 31.8106 29.2832C31.5117 28.9843 31.3438 28.5789 31.3438 28.1562V27.625C31.3438 27.4841 31.2878 27.349 31.1882 27.2493C31.0885 27.1497 30.9534 27.0938 30.8125 27.0938H29.75C29.3273 27.0938 28.9219 26.9258 28.6231 26.627C28.3242 26.3281 28.1563 25.9227 28.1563 25.5V8.5Z" fill="#09D9B9"/>
|
||||||
|
<path d="M2.125 31.3438C1.56141 31.3438 1.02091 31.5676 0.622398 31.9661C0.223883 32.3647 0 32.9052 0 33.4688L0 48.875C0 49.4386 0.223883 49.9791 0.622398 50.3776C1.02091 50.7761 1.56141 51 2.125 51C2.68859 51 3.22909 50.7761 3.6276 50.3776C4.02612 49.9791 4.25 49.4386 4.25 48.875V33.4688C4.25 32.9052 4.02612 32.3647 3.6276 31.9661C3.22909 31.5676 2.68859 31.3438 2.125 31.3438Z" fill="#09D9B9"/>
|
||||||
|
<path d="M32.9375 41.4375H13.5469C13.1946 41.4375 12.8568 41.2976 12.6077 41.0485C12.3587 40.7994 12.2188 40.4616 12.2188 40.1094C12.2188 39.7571 12.3587 39.4193 12.6077 39.1703C12.8568 38.9212 13.1946 38.7813 13.5469 38.7813H18.9125C19.2641 38.7814 19.6102 38.6944 19.9198 38.5279C20.2294 38.3614 20.4929 38.1207 20.6867 37.8273C20.8804 37.534 20.9983 37.1972 21.0299 36.847C21.0615 36.4969 21.0057 36.1444 20.8675 35.8211C20.5021 34.9651 19.8932 34.2354 19.1164 33.7227C18.3396 33.21 17.4292 32.9369 16.4985 32.9375H7.4375C7.15571 32.9375 6.88546 33.0494 6.6862 33.2487C6.48694 33.448 6.375 33.7182 6.375 34V47.8125C6.375 48.0943 6.48694 48.3645 6.6862 48.5638C6.88546 48.7631 7.15571 48.875 7.4375 48.875H30.311C31.5708 48.8739 32.7787 48.3729 33.6696 47.4821C34.5604 46.5912 35.0614 45.3833 35.0625 44.1235V43.5625C35.0625 42.9989 34.8386 42.4584 34.4401 42.0599C34.0416 41.6614 33.5011 41.4375 32.9375 41.4375Z" fill="#09D9B9"/>
|
||||||
|
</g>
|
||||||
|
<defs>
|
||||||
|
<clipPath id="clip0">
|
||||||
|
<rect width="51" height="51" fill="white"/>
|
||||||
|
</clipPath>
|
||||||
|
</defs>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 4.2 KiB |
|
@ -0,0 +1,5 @@
|
||||||
|
<svg width="49" height="48" viewBox="0 0 49 48" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<path d="M21.6738 39C21.6738 39.1326 21.7266 39.2598 21.8205 39.3536C21.9144 39.4473 22.0417 39.5 22.1745 39.5H25.1788C25.8428 39.5 26.4796 39.2366 26.9491 38.7678C27.4186 38.2989 27.6824 37.663 27.6824 37C27.6824 36.337 27.4186 35.7011 26.9491 35.2322C26.4796 34.7634 25.8428 34.5 25.1788 34.5H22.1745C22.0417 34.5 21.9144 34.5527 21.8205 34.6464C21.7266 34.7402 21.6738 34.8674 21.6738 35V39Z" fill="#09D9B9"/>
|
||||||
|
<path d="M22.1745 26.5C22.0417 26.5 21.9144 26.5527 21.8205 26.6464C21.7266 26.7402 21.6738 26.8674 21.6738 27V31C21.6738 31.1326 21.7266 31.2598 21.8205 31.3536C21.9144 31.4473 22.0417 31.5 22.1745 31.5H25.1788C25.8428 31.5 26.4796 31.2366 26.9491 30.7678C27.4186 30.2989 27.6824 29.663 27.6824 29C27.6824 28.337 27.4186 27.7011 26.9491 27.2322C26.4796 26.7634 25.8428 26.5 25.1788 26.5H22.1745Z" fill="#09D9B9"/>
|
||||||
|
<path d="M38.1053 18.11C37.992 18.0865 37.8903 18.0248 37.8174 17.9351C37.7444 17.8455 37.7046 17.7335 37.7047 17.618V13.5C37.7047 9.91958 36.2804 6.4858 33.745 3.95406C31.2096 1.42232 27.771 0 24.1854 0C20.5999 0 17.1612 1.42232 14.6258 3.95406C12.0905 6.4858 10.6661 9.91958 10.6661 13.5V17.618C10.6662 17.7335 10.6264 17.8455 10.5535 17.9351C10.4805 18.0248 10.3788 18.0865 10.2655 18.11C9.11478 18.3148 8.07256 18.9165 7.32071 19.8102C6.56886 20.7039 6.15511 21.8328 6.15165 23V43C6.15165 43.6566 6.28116 44.3068 6.5328 44.9134C6.78443 45.52 7.15325 46.0712 7.61821 46.5355C8.08317 46.9998 8.63515 47.3681 9.24265 47.6194C9.85014 47.8707 10.5013 48 11.1588 48H37.196C37.8535 48 38.5047 47.8707 39.1122 47.6194C39.7197 47.3681 40.2716 46.9998 40.7366 46.5355C41.2015 46.0712 41.5704 45.52 41.822 44.9134C42.0736 44.3068 42.2032 43.6566 42.2032 43V23C42.2004 21.8351 41.7889 20.708 41.0402 19.8146C40.2916 18.9213 39.2531 18.3181 38.1053 18.11ZM18.6695 25C18.6695 24.6022 18.8278 24.2206 19.1095 23.9393C19.3912 23.658 19.7733 23.5 20.1717 23.5H21.1731C21.3059 23.5 21.4333 23.4473 21.5272 23.3536C21.6211 23.2598 21.6738 23.1326 21.6738 23C21.6738 22.6022 21.8321 22.2206 22.1138 21.9393C22.3955 21.658 22.7776 21.5 23.176 21.5C23.5744 21.5 23.9564 21.658 24.2381 21.9393C24.5199 22.2206 24.6781 22.6022 24.6781 23C24.6781 23.1326 24.7309 23.2598 24.8248 23.3536C24.9187 23.4473 25.046 23.5 25.1788 23.5C26.6393 23.5011 28.0396 24.0809 29.0723 25.1121C30.105 26.1433 30.6856 27.5416 30.6867 29C30.6858 30.3555 30.1788 31.6619 29.2647 32.664C29.1816 32.7559 29.1357 32.8752 29.1357 32.999C29.1357 33.1228 29.1816 33.2421 29.2647 33.334C29.9794 34.1218 30.4494 35.0999 30.6176 36.1496C30.7858 37.1992 30.6449 38.275 30.212 39.2461C29.7791 40.2172 29.0729 41.0418 28.1793 41.6195C27.2858 42.1972 26.2433 42.5031 25.1788 42.5C25.046 42.5 24.9187 42.5527 24.8248 42.6464C24.7309 42.7402 24.6781 42.8674 24.6781 43C24.6781 43.3978 24.5199 43.7794 24.2381 44.0607C23.9564 44.342 23.5744 44.5 23.176 44.5C22.7776 44.5 22.3955 44.342 22.1138 44.0607C21.8321 43.7794 21.6738 43.3978 21.6738 43C21.6738 42.8674 21.6211 42.7402 21.5272 42.6464C21.4333 42.5527 21.3059 42.5 21.1731 42.5H20.1717C19.7733 42.5 19.3912 42.342 19.1095 42.0607C18.8278 41.7794 18.6695 41.3978 18.6695 41V25ZM15.6652 13.5C15.6652 11.2457 16.5621 9.08365 18.1584 7.48959C19.7547 5.89553 21.9198 5 24.1774 5C26.435 5 28.6001 5.89553 30.1964 7.48959C31.7927 9.08365 32.6896 11.2457 32.6896 13.5V17.5C32.6896 17.6326 32.6368 17.7598 32.5429 17.8536C32.449 17.9473 32.3216 18 32.1888 18H16.166C16.0332 18 15.9058 17.9473 15.8119 17.8536C15.718 17.7598 15.6652 17.6326 15.6652 17.5V13.5Z" fill="#09D9B9"/>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 3.5 KiB |
|
@ -0,0 +1,13 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg width="48px" height="48px" viewBox="0 0 48 48" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
||||||
|
<!-- Generator: Sketch 50.2 (55047) - http://www.bohemiancoding.com/sketch -->
|
||||||
|
<title>Facebook</title>
|
||||||
|
<desc>Created with Sketch.</desc>
|
||||||
|
<defs></defs>
|
||||||
|
<g id="Facebook" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
|
||||||
|
<g fill-rule="nonzero">
|
||||||
|
<path d="M0,24 C0,10.7451654 10.7451654,0 24,0 C37.2548346,0 48,10.7451654 48,24 C48,37.2548346 37.2548346,48 24,48 C10.7451654,48 0,37.2548346 0,24 Z" id="back" fill="#3B5998"></path>
|
||||||
|
<path d="M26.5015551,38.1114767 L26.5015551,25.0542096 L30.1059318,25.0542096 L30.5835896,20.554603 L26.5015551,20.554603 L26.5076789,18.3025066 C26.5076789,17.12894 26.6191834,16.5001162 28.3047641,16.5001162 L30.5580737,16.5001162 L30.5580737,12 L26.9531866,12 C22.6231375,12 21.0990725,14.1827933 21.0990725,17.8535652 L21.0990725,20.5551126 L18.4,20.5551126 L18.4,25.0547192 L21.0990725,25.0547192 L21.0990725,38.1114767 L26.5015551,38.1114767 Z" id="Shape" fill="#FFFFFF"></path>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 1.2 KiB |
|
@ -0,0 +1,15 @@
|
||||||
|
<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<g clip-path="url(#clip0)">
|
||||||
|
<path d="M20 0C16.0444 0 12.1776 1.17298 8.8886 3.37061C5.59962 5.56824 3.03617 8.69181 1.52242 12.3463C0.00866572 16.0009 -0.387401 20.0222 0.384303 23.9018C1.15601 27.7814 3.06082 31.3451 5.85787 34.1421C8.65492 36.9392 12.2186 38.844 16.0982 39.6157C19.9778 40.3874 23.9992 39.9913 27.6537 38.4776C31.3082 36.9638 34.4318 34.4004 36.6294 31.1114C38.827 27.8224 40 23.9556 40 20C39.9943 14.6974 37.8853 9.61368 34.1358 5.8642C30.3863 2.11471 25.3026 0.00573514 20 0V0ZM32.2117 31.3333C28.4415 29.3658 24.2518 28.3384 19.9992 28.3384C15.7465 28.3384 11.5568 29.3658 7.78667 31.3333C5.5792 28.9564 4.11336 25.9868 3.56892 22.7889C3.02448 19.591 3.4251 16.3038 4.72166 13.3302C6.01822 10.3567 8.15434 7.82614 10.8681 6.04892C13.5819 4.27169 16.7553 3.32503 19.9992 3.32503C23.2431 3.32503 26.4165 4.27169 29.1303 6.04892C31.844 7.82614 33.9801 10.3567 35.2767 13.3302C36.5732 16.3038 36.9739 19.591 36.4294 22.7889C35.885 25.9868 34.4192 28.9564 32.2117 31.3333Z" fill="#09D9B9"/>
|
||||||
|
<path d="M9.16666 18.75H6.66666C6.33514 18.75 6.01719 18.8817 5.78277 19.1161C5.54835 19.3505 5.41666 19.6685 5.41666 20C5.41666 20.3315 5.54835 20.6495 5.78277 20.8839C6.01719 21.1183 6.33514 21.25 6.66666 21.25H9.16666C9.49818 21.25 9.81612 21.1183 10.0505 20.8839C10.285 20.6495 10.4167 20.3315 10.4167 20C10.4167 19.6685 10.285 19.3505 10.0505 19.1161C9.81612 18.8817 9.49818 18.75 9.16666 18.75Z" fill="#09D9B9"/>
|
||||||
|
<path d="M11.6167 9.85C11.5022 9.72718 11.3642 9.62868 11.2109 9.56036C11.0576 9.49204 10.892 9.4553 10.7242 9.45234C10.5564 9.44938 10.3896 9.48026 10.234 9.54312C10.0784 9.60599 9.93696 9.69957 9.81826 9.81826C9.69957 9.93696 9.60599 10.0784 9.54312 10.234C9.48026 10.3896 9.44938 10.5564 9.45234 10.7242C9.4553 10.892 9.49204 11.0576 9.56036 11.2109C9.62868 11.3642 9.72718 11.5022 9.84999 11.6167L11.6167 13.3833C11.7311 13.5061 11.8691 13.6046 12.0224 13.673C12.1758 13.7413 12.3413 13.778 12.5091 13.781C12.677 13.7839 12.8437 13.7531 12.9993 13.6902C13.155 13.6273 13.2964 13.5338 13.4151 13.4151C13.5338 13.2964 13.6273 13.155 13.6902 12.9993C13.7531 12.8437 13.7839 12.677 13.781 12.5091C13.778 12.3413 13.7413 12.1758 13.673 12.0224C13.6046 11.8691 13.5061 11.7311 13.3833 11.6167L11.6167 9.85Z" fill="#09D9B9"/>
|
||||||
|
<path d="M20 10.4167C20.3315 10.4167 20.6495 10.285 20.8839 10.0506C21.1183 9.81615 21.25 9.49821 21.25 9.16669V6.66669C21.25 6.33517 21.1183 6.01722 20.8839 5.7828C20.6495 5.54838 20.3315 5.41669 20 5.41669C19.6685 5.41669 19.3505 5.54838 19.1161 5.7828C18.8817 6.01722 18.75 6.33517 18.75 6.66669V9.16669C18.75 9.49821 18.8817 9.81615 19.1161 10.0506C19.3505 10.285 19.6685 10.4167 20 10.4167Z" fill="#09D9B9"/>
|
||||||
|
<path d="M33.3333 18.75H30.8333C30.5018 18.75 30.1839 18.8817 29.9494 19.1161C29.715 19.3505 29.5833 19.6685 29.5833 20C29.5833 20.3315 29.715 20.6495 29.9494 20.8839C30.1839 21.1183 30.5018 21.25 30.8333 21.25H33.3333C33.6648 21.25 33.9828 21.1183 34.2172 20.8839C34.4516 20.6495 34.5833 20.3315 34.5833 20C34.5833 19.6685 34.4516 19.3505 34.2172 19.1161C33.9828 18.8817 33.6648 18.75 33.3333 18.75Z" fill="#09D9B9"/>
|
||||||
|
<path d="M30.59 11.0766C30.4585 10.9452 30.2869 10.8615 30.1024 10.8389C29.9178 10.8162 29.731 10.8559 29.5717 10.9516C28.4233 11.6416 18.3167 17.7283 17.0533 18.9916C16.3095 19.738 15.8918 20.7487 15.8918 21.8025C15.8918 22.8562 16.3095 23.867 17.0533 24.6133C17.8067 25.3437 18.8149 25.7521 19.8642 25.7521C20.9135 25.7521 21.9216 25.3437 22.675 24.6133C23.9383 23.35 30.025 13.2433 30.715 12.0966C30.8112 11.9371 30.8511 11.75 30.8284 11.5651C30.8058 11.3802 30.7218 11.2082 30.59 11.0766Z" fill="#09D9B9"/>
|
||||||
|
</g>
|
||||||
|
<defs>
|
||||||
|
<clipPath id="clip0">
|
||||||
|
<rect width="40" height="40" fill="white"/>
|
||||||
|
</clipPath>
|
||||||
|
</defs>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 3.7 KiB |
|
@ -0,0 +1,4 @@
|
||||||
|
<svg width="56" height="56" viewBox="0 0 56 56" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<path d="M28 6.09937C24.9801 6.09923 22.0153 6.90749 19.4132 8.44022C16.8112 9.97296 14.667 12.1743 13.2031 14.8156C11.7392 17.457 11.009 20.4421 11.0884 23.4609C11.1678 26.4797 12.0539 29.4223 13.6547 31.983C13.7724 32.1861 13.9298 32.3635 14.1175 32.5045C14.3052 32.6455 14.5194 32.7473 14.7472 32.8038C14.975 32.8603 15.2119 32.8705 15.4438 32.8336C15.6756 32.7967 15.8977 32.7135 16.0967 32.589C16.2957 32.4645 16.4677 32.3012 16.6023 32.1089C16.7369 31.9166 16.8315 31.6992 16.8803 31.4695C16.9292 31.2399 16.9314 31.0028 16.8867 30.7724C16.842 30.5419 16.7515 30.3228 16.6204 30.128C15.3494 28.0958 14.6459 25.7602 14.5832 23.364C14.5204 20.9679 15.1006 18.5986 16.2635 16.5026C17.4263 14.4066 19.1294 12.6604 21.1956 11.4453C23.2618 10.2303 25.6157 9.59096 28.0127 9.59366C30.4097 9.59637 32.7622 10.2411 34.8256 11.4607C36.8891 12.6804 38.5882 14.4305 39.7463 16.5291C40.9045 18.6278 41.4793 20.9983 41.4111 23.3943C41.343 25.7903 40.6343 28.1243 39.3587 30.1537C39.1112 30.5467 39.0299 31.0219 39.1327 31.4748C39.2355 31.9277 39.5141 32.3212 39.907 32.5687C40.3 32.8162 40.7752 32.8975 41.2281 32.7947C41.681 32.6919 42.0745 32.4133 42.322 32.0204C43.9314 29.4606 44.8254 26.5163 44.9108 23.4939C44.9962 20.4715 44.27 17.4814 42.8077 14.8349C41.3454 12.1884 39.2005 9.98211 36.5963 8.44579C33.9921 6.90947 31.0237 6.09921 28 6.09937Z" fill="#09D9B9"/>
|
||||||
|
<path d="M38.3063 35.672L29.575 33.0657C29.4549 33.0299 29.3496 32.9563 29.2747 32.8558C29.1999 32.7553 29.1595 32.6333 29.1597 32.508V21.8493C29.1597 21.2305 28.9138 20.637 28.4763 20.1994C28.0387 19.7618 27.4452 19.516 26.8263 19.516C26.2075 19.516 25.614 19.7618 25.1764 20.1994C24.7388 20.637 24.493 21.2305 24.493 21.8493V38.332C24.4932 38.4565 24.4535 38.5779 24.3797 38.6782C24.306 38.7786 24.202 38.8527 24.0831 38.8898C23.9642 38.9268 23.8365 38.9248 23.7188 38.884C23.6011 38.8433 23.4996 38.766 23.429 38.6633C19.9547 33.6747 14.434 35.2823 16.9867 39.186L23.7813 49.3757C23.8878 49.5356 24.0321 49.6668 24.2014 49.7576C24.3707 49.8483 24.5599 49.8959 24.752 49.896H37.436C37.7087 49.8962 37.9729 49.8008 38.1826 49.6265C38.3924 49.4521 38.5344 49.2098 38.584 48.9417C39.0927 46.1767 40.39 39.2187 40.39 39.2187C40.5627 38.4731 40.443 37.6897 40.0553 37.0299C39.6676 36.37 39.0417 35.884 38.3063 35.672Z" fill="#09D9B9"/>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 2.3 KiB |
|
@ -0,0 +1,19 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg width="48px" height="48px" viewBox="0 0 48 48" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
||||||
|
<!-- Generator: Sketch 50.2 (55047) - http://www.bohemiancoding.com/sketch -->
|
||||||
|
<title>Github</title>
|
||||||
|
<desc>Created with Sketch.</desc>
|
||||||
|
<defs></defs>
|
||||||
|
<g id="Github" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
|
||||||
|
<g fill="#161514" fill-rule="nonzero">
|
||||||
|
<path d="M24.0001987,0 C10.7469923,0 0,11.0169476 0,24.6076131 C0,35.4799011 6.87678742,44.7038849 16.4128006,47.9577067 C17.6122542,48.1854946 18.0526102,47.4238924 18.0526102,46.7739431 C18.0526102,46.187155 18.030354,44.2487166 18.0200207,42.1925131 C11.3431422,43.6810806 9.93424136,39.2891342 9.93424136,39.2891342 C8.84249224,36.4448416 7.26945146,35.6885369 7.26945146,35.6885369 C5.09191472,34.1612577 7.43359139,34.1926346 7.43359139,34.1926346 C9.84362656,34.3662261 11.112631,36.7284559 11.112631,36.7284559 C13.2532064,40.4904199 16.7271703,39.4028245 18.0967253,38.7740647 C18.3121342,37.1836243 18.9341172,36.0980661 19.6204844,35.4835686 C14.2897122,34.8613286 8.68590352,32.7513362 8.68590352,23.3223841 C8.68590352,20.6357909 9.62344856,18.4406327 11.1587332,16.7173499 C10.9095426,16.097555 10.088048,13.5947405 11.3912316,10.2052239 C11.3912316,10.2052239 13.4066156,9.54386481 17.9929952,12.727598 C19.9074312,12.182374 21.9605713,11.908947 24.0001987,11.8995747 C26.0398262,11.908947 28.094556,12.182374 30.0125688,12.727598 C34.5933844,9.54386481 36.6059863,10.2052239 36.6059863,10.2052239 C37.9123494,13.5947405 37.0904574,16.097555 36.8412668,16.7173499 C38.3801283,18.4406327 39.3113144,20.6357909 39.3113144,23.3223841 C39.3113144,32.7737483 33.696775,34.8548088 28.3524902,35.464009 C29.2133306,36.2276485 29.9803767,37.7251808 29.9803767,40.0209895 C29.9803767,43.3135229 29.9525564,45.9634419 29.9525564,46.7739431 C29.9525564,47.4287823 30.3845663,48.1960894 31.6011095,47.9544468 C41.1319561,44.6969575 48,35.4762337 48,24.6076131 C48,11.0169476 37.2545974,0 24.0001987,0" id="Fill-4"></path>
|
||||||
|
<path d="M9.16085952,35.1623051 C9.1080992,35.2833471 8.92085952,35.3196598 8.75028096,35.2365442 C8.57652896,35.15706 8.47894216,34.9920394 8.53527272,34.8705938 C8.58684296,34.7459205 8.77447936,34.7112218 8.94783472,34.7947408 C9.12198344,34.8742251 9.22115704,35.0408596 9.16085952,35.1623051" id="Fill-5"></path>
|
||||||
|
<path d="M10.1311735,36.2629806 C10.0169256,36.370708 9.7935868,36.3206773 9.6420496,36.1504115 C9.48535536,35.9805492 9.456,35.7533937 9.57183472,35.6440524 C9.68965288,35.536325 9.90624792,35.5867591 10.0633389,35.7566215 C10.220033,35.9285012 10.2505785,36.1540428 10.1311735,36.2629806" id="Fill-6"></path>
|
||||||
|
<path d="M11.0757025,37.6662612 C10.9289256,37.7699539 10.6889256,37.6727168 10.540562,37.4560515 C10.3937851,37.2393863 10.3937851,36.9795494 10.5437355,36.8754533 C10.6924958,36.7713572 10.9289256,36.8649629 11.0792727,37.0800143 C11.2256529,37.3003108 11.2256529,37.5601477 11.0757025,37.6662612" id="Fill-7"></path>
|
||||||
|
<path d="M12.369719,39.0219319 C12.2384132,39.1691997 11.9587438,39.1296592 11.7540496,38.9287295 C11.544595,38.7322379 11.486281,38.4534378 11.6179834,38.30617 C11.750876,38.1584987 12.0321322,38.2000565 12.2384132,38.3993723 C12.446281,38.5954605 12.5097521,38.876278 12.369719,39.0219319" id="Fill-8"></path>
|
||||||
|
<path d="M14.154843,39.8091085 C14.0969256,39.9999515 13.8275702,40.0866982 13.5562314,40.0056001 C13.2852893,39.9220811 13.107967,39.6985568 13.1627107,39.5056965 C13.2190414,39.3136431 13.4895868,39.2232651 13.7629091,39.3100119 C14.0334546,39.3931274 14.2111735,39.6150378 14.154843,39.8091085" id="Fill-9"></path>
|
||||||
|
<path d="M16.1153058,39.9551659 C16.1220496,40.1560956 15.891967,40.3227301 15.6071405,40.3263615 C15.3207273,40.332817 15.0890578,40.1702172 15.0858843,39.9725152 C15.0858843,39.7695681 15.3108099,39.6045475 15.5972231,39.5997058 C15.8820496,39.5940572 16.1153058,39.7554465 16.1153058,39.9551659" id="Fill-10"></path>
|
||||||
|
<path d="M17.9397025,39.6392462 C17.9738182,39.8353343 17.7758678,40.0366676 17.4930248,40.0903295 C17.2149422,40.1419741 16.9574876,40.020932 16.9221818,39.8264579 C16.8876694,39.6255281 17.0891901,39.4241949 17.366876,39.3721468 C17.6501157,39.3221161 17.9036033,39.4399303 17.9397025,39.6392462" id="Fill-11"></path>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 4.3 KiB |
|
@ -0,0 +1,15 @@
|
||||||
|
<svg width="345" height="330" viewBox="0 0 345 330" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<rect x="60" y="53" width="224" height="224" rx="112" fill="white" stroke="#EAFAEF" stroke-width="10"/>
|
||||||
|
<circle cx="114.169" cy="9.95074" r="7" transform="rotate(-20 114.169 9.95074)" fill="#09D9B9"/>
|
||||||
|
<circle cx="227.036" cy="320.049" r="7" transform="rotate(-20 227.036 320.049)" fill="#09D9B9"/>
|
||||||
|
<circle cx="64.5425" cy="38.6027" r="7" transform="rotate(-40 64.5425 38.6027)" fill="#09D9B9"/>
|
||||||
|
<circle cx="276.662" cy="291.397" r="7" transform="rotate(-40 276.662 291.397)" fill="#09D9B9"/>
|
||||||
|
<circle cx="27.7083" cy="82.5" r="7" transform="rotate(-60 27.7083 82.5)" fill="#09D9B9"/>
|
||||||
|
<circle cx="313.497" cy="247.5" r="7" transform="rotate(-60 313.497 247.5)" fill="#09D9B9"/>
|
||||||
|
<circle cx="8.10919" cy="136.348" r="7" transform="rotate(-80 8.10919 136.348)" fill="#09D9B9"/>
|
||||||
|
<circle cx="333.096" cy="193.652" r="7" transform="rotate(-80 333.096 193.652)" fill="#09D9B9"/>
|
||||||
|
<circle cx="8.10921" cy="193.652" r="7" transform="rotate(-100 8.10921 193.652)" fill="#09D9B9"/>
|
||||||
|
<circle cx="333.096" cy="136.348" r="8.5" transform="rotate(-100 333.096 136.348)" fill="#09D9B9" stroke="white" stroke-width="3"/>
|
||||||
|
<circle cx="27.7083" cy="247.5" r="7" transform="rotate(-120 27.7083 247.5)" fill="#09D9B9"/>
|
||||||
|
<circle cx="313.497" cy="82.5001" r="7" transform="rotate(-120 313.497 82.5001)" fill="#09D9B9"/>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 1.4 KiB |
|
@ -0,0 +1 @@
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><title>navigation-menu</title><rect x="0.5" y="2.5" width="23" height="3" rx="1" ry="1"/><rect x="0.5" y="10.5" width="23" height="3" rx="1" ry="1"/><rect x="0.5" y="18.5" width="23" height="3" rx="1" ry="1"/></svg>
|
After Width: | Height: | Size: 275 B |
|
@ -0,0 +1,13 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg width="48px" height="48px" viewBox="0 0 48 48" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
||||||
|
<!-- Generator: Sketch 50.2 (55047) - http://www.bohemiancoding.com/sketch -->
|
||||||
|
<title>Twitter</title>
|
||||||
|
<desc>Created with Sketch.</desc>
|
||||||
|
<defs></defs>
|
||||||
|
<g id="Twitter" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
|
||||||
|
<g fill-rule="nonzero">
|
||||||
|
<path d="M0,24 C0,10.7451654 10.7451654,0 24,0 C37.2548346,0 48,10.7451654 48,24 C48,37.2548346 37.2548346,48 24,48 C10.7451654,48 0,37.2548346 0,24 Z" id="back" fill="#55ACEE"></path>
|
||||||
|
<path d="M23.2812026,19.5075006 L23.3315651,20.3379548 L22.4921899,20.2362665 C19.4368642,19.8464615 16.7676511,18.5245141 14.5013381,16.3043203 L13.3933628,15.2026975 L13.1079753,16.0162036 C12.5036251,17.8296443 12.8897377,19.7447732 14.1488005,21.0328246 C14.8203006,21.7446424 14.6692131,21.8463306 13.5108754,21.4226296 C13.1079753,21.2870452 12.7554377,21.185357 12.7218626,21.2362011 C12.6043502,21.3548374 13.0072502,22.8971094 13.3262128,23.507239 C13.7626879,24.3546411 14.6524256,25.1850953 15.6261009,25.6765886 L16.4486886,26.0663936 L15.4750133,26.0833416 C14.5349131,26.0833416 14.5013381,26.1002897 14.6020631,26.4561986 C14.9378132,27.5578214 16.264026,28.7272364 17.7413263,29.2356778 L18.7821516,29.5915866 L17.8756264,30.1339241 C16.5326261,30.9135341 14.9546007,31.3541832 13.3765754,31.3880793 C12.6211377,31.4050274 12,31.4728195 12,31.5236637 C12,31.6931441 14.0480754,32.6422346 15.2399882,33.0150915 C18.8157266,34.1167144 23.062965,33.6421691 26.2525908,31.7609362 C28.5189038,30.4220408 30.7852169,27.7611979 31.8428296,25.1850953 C32.4136047,23.8123038 32.9843799,21.3039933 32.9843799,20.1006822 C32.9843799,19.3210722 33.0347424,19.2193839 33.9748426,18.2872414 C34.5288302,17.7449041 35.0492429,17.1517226 35.1499679,16.9822421 C35.317843,16.6602293 35.3010554,16.6602293 34.4448927,16.948346 C33.0179549,17.4567874 32.8165049,17.3889951 33.52158,16.6263332 C34.0419926,16.0839958 34.6631302,15.1010093 34.6631302,14.8128925 C34.6631302,14.7620484 34.4113177,14.8467886 34.1259302,14.999321 C33.823755,15.1688014 33.1522549,15.4230221 32.6486298,15.5755545 L31.7421046,15.8636712 L30.9195169,15.3043858 C30.4662543,14.999321 29.8283291,14.6603601 29.492579,14.5586718 C28.6364164,14.3213992 27.326991,14.3552953 26.5547659,14.626464 C24.4563279,15.389126 23.1301151,17.355099 23.2812026,19.5075006 Z" id="Shape" fill="#FFFFFF"></path>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 2.5 KiB |
After Width: | Height: | Size: 5.9 KiB |
|
@ -0,0 +1,24 @@
|
||||||
|
<svg width="62" height="22" viewBox="0 0 62 22" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<g clip-path="url(#clip0)">
|
||||||
|
<path d="M3.39852 6.00421L0.551111 10.9084C-0.183704 12.1917 -0.183704 13.7959 0.551111 15.0792L3.39852 19.9834C4.13333 21.2667 5.51111 22.0459 7.02667 22.0459H12.6756C14.1911 22.0459 15.5689 21.2667 16.3037 19.9375L19.1052 15.0334C19.84 13.75 19.84 12.1459 19.1052 10.8625L16.2578 5.95837C15.523 4.67504 14.1452 3.89587 12.6296 3.89587H6.98074C5.51111 3.89587 4.13333 4.72087 3.39852 6.00421Z" fill="#0B476D"/>
|
||||||
|
<path d="M6.42961 8.75421C6.42961 8.75421 5.14368 10.9084 5.23553 11.6875C5.41924 13.1542 6.42961 17.325 6.42961 17.325H6.75109L7.62368 13.5667C7.57775 13.5667 6.75109 11.9167 6.42961 8.75421Z" fill="#FAB266"/>
|
||||||
|
<path d="M13.5481 8.79999C13.5481 8.79999 14.834 10.9541 14.7422 11.7333C14.5584 13.1999 13.5481 17.3708 13.5481 17.3708H13.2266L12.354 13.6125C12.3999 13.6125 13.2725 11.9625 13.5481 8.79999Z" fill="#F1645D"/>
|
||||||
|
<path d="M10.0118 -0.0916138C17.2222 8.2042 11.2978 15.8125 11.2978 15.8125H10.0118V-0.0916138Z" fill="#398689"/>
|
||||||
|
<path d="M10.0118 -0.137512C2.80148 8.15834 8.72592 15.7667 8.72592 15.7667H10.0118V-0.137512Z" fill="#78BE97"/>
|
||||||
|
<path d="M23.3763 18.15V10.1292H28.3363V11.275H24.5704V13.475H27.0045V14.6209H24.5704V17.05H28.6119V18.1959H23.3763V18.15Z" fill="white"/>
|
||||||
|
<path d="M37.0622 18.15V14.6209C37.0622 13.7042 36.6948 13.2459 36.0059 13.2459C35.6844 13.2459 35.4088 13.3834 35.1792 13.6125C34.9496 13.8417 34.8577 14.2084 34.8577 14.6667V18.1042H33.6637V14.575C33.6637 13.6584 33.2962 13.2 32.6074 13.2C32.2859 13.2 32.0103 13.3375 31.7807 13.5667C31.5511 13.7959 31.4592 14.1625 31.4592 14.6209V18.0584H30.2651V12.2834H31.4592V12.8334C31.7807 12.375 32.2859 12.1459 32.9288 12.1459C33.6637 12.1459 34.1688 12.4209 34.4903 12.9709C34.8577 12.4209 35.4088 12.1459 36.2355 12.1459C36.8785 12.1459 37.3837 12.3292 37.7511 12.6959C38.1185 13.0625 38.3481 13.6125 38.3481 14.3459V18.1042H37.0622V18.15Z" fill="white"/>
|
||||||
|
<path d="M42.5733 18.2875C42.0222 18.2875 41.5629 18.1042 41.1955 17.6917V18.15H40.0015V10.4042L41.1955 9.85419V12.6959C41.5629 12.2834 42.0222 12.1 42.5733 12.1C43.3081 12.1 43.9052 12.375 44.3185 12.925C44.7778 13.475 45.0074 14.2084 45.0074 15.1709C45.0074 16.1334 44.7778 16.9125 44.3644 17.4625C43.9052 18.0125 43.3081 18.2875 42.5733 18.2875ZM42.4355 17.1417C42.8948 17.1417 43.2163 16.9584 43.4459 16.6375C43.6755 16.2709 43.8133 15.8125 43.8133 15.2167C43.8133 14.575 43.6755 14.1167 43.4459 13.7959C43.2163 13.475 42.8489 13.2917 42.4355 13.2917C42.16 13.2917 41.9304 13.3375 41.7007 13.475C41.4711 13.6125 41.3333 13.75 41.1955 13.9334V16.5C41.4711 16.9125 41.8844 17.1417 42.4355 17.1417Z" fill="white"/>
|
||||||
|
<path d="M49.8296 18.15V17.6459C49.4163 18.0584 48.8652 18.2875 48.2222 18.2875C47.6252 18.2875 47.12 18.1042 46.7067 17.7834C46.3392 17.4625 46.1096 16.9584 46.1096 16.3167C46.1096 15.675 46.3392 15.2167 46.7526 14.85C47.1659 14.4834 47.717 14.3459 48.36 14.3459C48.9111 14.3459 49.4163 14.4375 49.7837 14.7125V14.3917C49.7837 13.9792 49.6918 13.6584 49.5081 13.475C49.3244 13.2917 49.0029 13.2 48.5437 13.2C47.9007 13.2 47.3496 13.3834 46.8444 13.75L46.477 12.7875C47.0741 12.375 47.8089 12.1917 48.6815 12.1917C48.957 12.1917 49.2326 12.2375 49.4622 12.2834C49.6918 12.3292 49.9215 12.4209 50.1511 12.5584C50.3807 12.6959 50.5644 12.925 50.7022 13.2459C50.84 13.5667 50.8859 13.9334 50.8859 14.3917V18.1959H49.8296V18.15ZM48.4518 17.2334C49.003 17.2334 49.4622 17.0042 49.8296 16.5917V15.675C49.4622 15.4917 49.0489 15.4 48.5896 15.4C48.2222 15.4 47.9007 15.4917 47.6711 15.6292C47.4415 15.7667 47.3037 15.9959 47.3037 16.3167C47.3037 16.5917 47.3955 16.8209 47.6252 16.9584C47.8089 17.1417 48.0844 17.2334 48.4518 17.2334Z" fill="white"/>
|
||||||
|
<path d="M52.677 18.15V12.2834H53.8711V13.0167C54.1466 12.4667 54.56 12.1459 55.2029 12.1459C55.5703 12.1459 55.8918 12.2834 56.1674 12.5125L55.9837 13.6125C55.7081 13.4292 55.3866 13.3375 55.0652 13.3375C54.7437 13.3375 54.4681 13.475 54.2385 13.7042C54.0089 13.9334 53.8711 14.3459 53.8711 14.8959V18.1959H52.677V18.15Z" fill="white"/>
|
||||||
|
<path d="M62.2297 18.1501H60.9438L59.1986 14.8043L58.4178 15.5376V18.1501H57.2238V10.4501L58.4178 9.90009V14.1168L60.163 12.2834H61.6326L60.0252 13.9334L62.2297 18.1501Z" fill="white"/>
|
||||||
|
<path d="M15.7526 20.6249C15.7067 20.5791 15.6607 20.4874 15.6148 20.4416C15.4311 20.3041 15.2474 20.2583 15.0178 20.3499C14.9259 20.0749 14.6963 19.7999 14.3748 19.7999C14.1452 19.7999 13.9615 19.8916 13.8237 20.0291C13.5941 19.7083 13.1807 19.4333 12.7215 19.4333C12.6756 19.4333 12.6296 19.4333 12.6296 19.4333C12.5378 19.0208 12.2622 18.6999 11.9407 18.4708C11.2978 17.7833 11.2978 15.7666 11.2978 15.7666H9.96592H8.63407C8.63407 15.7666 8.58815 17.7833 7.94518 18.4708C7.66963 18.6541 7.48592 18.9291 7.39407 19.2041C7.21037 19.1124 7.02666 19.0666 6.79704 19.0208C6.15407 18.9749 5.55704 19.3874 5.32741 19.9833C5.23555 19.9374 5.1437 19.9374 5.05185 19.9374C4.77629 19.9374 4.50074 20.0749 4.36296 20.3041C4.31704 20.2583 4.22518 20.2583 4.13333 20.2583C3.94963 20.2583 3.76592 20.3499 3.67407 20.4874C3.94963 20.8083 4.22518 21.0374 4.54666 21.2666C4.73037 21.4041 4.91407 21.4958 5.09778 21.5874C5.28148 21.6791 5.46518 21.7249 5.60296 21.8166C5.64889 21.8166 5.64889 21.8166 5.69481 21.8624C5.83259 21.9083 6.01629 21.9541 6.2 21.9541C6.24592 21.9541 6.29185 21.9541 6.29185 21.9541C6.47555 21.9999 6.70518 21.9999 6.88889 21.9999H12.5378C12.7215 21.9999 12.9052 21.9999 13.1348 21.9541H13.1807C13.7319 21.8624 14.283 21.6791 14.7422 21.3583C15.2015 21.1749 15.477 20.9458 15.7526 20.6249Z" fill="#9BDCD9"/>
|
||||||
|
<path d="M7.02658 22.0458H12.6755C13.1347 22.0458 13.594 21.9541 14.0073 21.8166C13.8236 21.45 12.997 20.9 12.6755 20.7625C11.6651 20.3958 12.0784 19.25 11.0681 19.25C10.4251 19.25 10.1495 17.3708 10.1495 17.3708H9.82806C9.82806 17.3708 9.59843 19.2041 8.95547 19.1583C7.66954 19.1125 8.49621 20.4416 6.98066 20.8541C6.01621 21.1291 5.69473 21.4958 5.6488 21.7708C6.06214 21.9083 6.5214 22.0458 7.02658 22.0458Z" fill="#D7F1F0"/>
|
||||||
|
<path d="M10.0118 8.2041C10.0118 8.2041 8.40441 10.0374 8.58811 10.9083C8.86367 12.3749 9.87404 17.3249 9.87404 17.3249H10.0118V8.2041Z" fill="#FAB266"/>
|
||||||
|
<path d="M10.0118 8.25C10.0118 8.25 11.6192 10.0833 11.4355 10.9542C11.16 12.4208 10.1496 17.3708 10.1496 17.3708H10.0118V8.25Z" fill="#F1645D"/>
|
||||||
|
</g>
|
||||||
|
<defs>
|
||||||
|
<clipPath id="clip0">
|
||||||
|
<rect width="62" height="22" fill="white"/>
|
||||||
|
</clipPath>
|
||||||
|
</defs>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 6.3 KiB |
After Width: | Height: | Size: 602 B |
|
@ -0,0 +1,14 @@
|
||||||
|
<svg width="225" height="53" viewBox="0 0 225 53" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<path fill-rule="evenodd" clip-rule="evenodd" d="M42.6654 25.8287C44.5551 32.8096 42.7595 40.58 37.2789 46.0607C31.7982 51.5413 24.0278 53.3369 17.0469 51.4472C23.2532 50.4538 29.215 47.5651 33.9991 42.7809C38.7833 37.9968 41.672 32.035 42.6654 25.8287Z" fill="#78BE97"/>
|
||||||
|
<path fill-rule="evenodd" clip-rule="evenodd" d="M36.3667 16.0138C38.5157 23.9529 36.4738 32.7898 30.2409 39.0227C24.0079 45.2557 15.171 47.2976 7.23193 45.1486C14.2901 44.0189 21.0702 40.7336 26.511 35.2928C31.9518 29.852 35.237 23.072 36.3667 16.0138Z" fill="#FAB266"/>
|
||||||
|
<path fill-rule="evenodd" clip-rule="evenodd" d="M15.807 36.1601C13.6579 28.2211 15.6999 19.3842 21.9328 13.1512C28.1657 6.91827 37.0026 4.87632 44.9417 7.02537C37.8836 8.15505 31.1035 11.4403 25.6627 16.8811C20.2219 22.3219 16.9366 29.102 15.807 36.1601Z" fill="#F1645D"/>
|
||||||
|
<path fill-rule="evenodd" clip-rule="evenodd" d="M14.8949 6.11326C20.3756 0.632568 28.1459 -1.16294 35.1269 0.726737C28.9205 1.72008 22.9587 4.60883 18.1746 9.39298C13.3904 14.1771 10.5017 20.1389 9.50835 26.3452C7.61868 19.3643 9.41418 11.594 14.8949 6.11326Z" fill="#398689"/>
|
||||||
|
<path d="M70.6622 20.9627C70.5338 21.1681 70.3968 21.3222 70.2513 21.4249C70.1144 21.5276 69.9346 21.579 69.7121 21.579C69.5152 21.579 69.3012 21.5191 69.0701 21.3992C68.8475 21.2708 68.5907 21.1296 68.2997 20.9755C68.0172 20.8214 67.6919 20.6845 67.3239 20.5646C66.9558 20.4362 66.5364 20.372 66.0656 20.372C65.2524 20.372 64.6447 20.5475 64.2423 20.8985C63.8486 21.2409 63.6517 21.7074 63.6517 22.298C63.6517 22.6746 63.7716 22.9871 64.0112 23.2353C64.2509 23.4835 64.5633 23.6975 64.9485 23.8773C65.3423 24.057 65.7874 24.224 66.2839 24.378C66.7889 24.5235 67.3025 24.6905 67.8246 24.8788C68.3468 25.0585 68.8561 25.2725 69.3525 25.5208C69.8576 25.769 70.3027 26.0857 70.6879 26.4709C71.0816 26.8561 71.3983 27.3269 71.638 27.8833C71.8777 28.4311 71.9975 29.0945 71.9975 29.8734C71.9975 30.7379 71.8477 31.5468 71.5481 32.3001C71.2485 33.0534 70.812 33.7125 70.2385 34.2774C69.6735 34.8338 68.9716 35.2746 68.1328 35.5999C67.3025 35.9166 66.3566 36.075 65.2952 36.075C64.7131 36.075 64.1182 36.0151 63.5105 35.8952C62.9113 35.7754 62.3292 35.6085 61.7643 35.3945C61.1993 35.1719 60.6686 34.9108 60.1722 34.6112C59.6757 34.3117 59.2434 33.9778 58.8754 33.6098L60.1593 31.5811C60.2535 31.427 60.3862 31.3029 60.5574 31.2087C60.7286 31.1146 60.9126 31.0675 61.1095 31.0675C61.3663 31.0675 61.6231 31.1488 61.8798 31.3115C62.1452 31.4741 62.4405 31.6538 62.7658 31.8507C63.0996 32.0476 63.4805 32.2274 63.9085 32.39C64.3365 32.5526 64.8415 32.6339 65.4236 32.6339C66.2111 32.6339 66.8231 32.4627 67.2597 32.1204C67.6962 31.7694 67.9145 31.2173 67.9145 30.464C67.9145 30.0275 67.7947 29.6723 67.555 29.3983C67.3153 29.1244 66.9986 28.8976 66.6048 28.7178C66.2197 28.5381 65.7788 28.3797 65.2824 28.2428C64.7859 28.1058 64.2766 27.956 63.7544 27.7934C63.2323 27.6222 62.723 27.4168 62.2265 27.1771C61.7301 26.9288 61.2849 26.6079 60.8912 26.2141C60.506 25.8118 60.1936 25.3153 59.9539 24.7247C59.7142 24.1255 59.5944 23.3894 59.5944 22.5163C59.5944 21.8144 59.7356 21.1296 60.0181 20.4619C60.3006 19.7943 60.7157 19.1994 61.2635 18.6772C61.8114 18.1551 62.4833 17.7399 63.2794 17.4318C64.0754 17.1151 64.9871 16.9567 66.0142 16.9567C66.5877 16.9567 67.1441 17.0038 67.6834 17.0979C68.2312 17.1835 68.7491 17.3162 69.237 17.496C69.7249 17.6672 70.1786 17.8769 70.598 18.1251C71.026 18.3648 71.4069 18.6387 71.7407 18.9468L70.6622 20.9627Z" fill="white"/>
|
||||||
|
<path d="M87.2981 32.4413C87.8801 32.4413 88.398 32.3472 88.8517 32.1589C89.3139 31.962 89.7034 31.6838 90.0201 31.3243C90.3368 30.9648 90.5765 30.5282 90.7391 30.0146C90.9103 29.4925 90.9959 28.9019 90.9959 28.2428V17.1621H95.3357V28.2428C95.3357 29.3898 95.1474 30.4426 94.7708 31.4013C94.4027 32.36 93.872 33.186 93.1787 33.8794C92.4853 34.5727 91.6422 35.112 90.6492 35.4972C89.6563 35.8824 88.5393 36.075 87.2981 36.075C86.0484 36.075 84.927 35.8824 83.9341 35.4972C82.9412 35.112 82.098 34.5727 81.4047 33.8794C80.7113 33.186 80.1806 32.36 79.8126 31.4013C79.4445 30.4426 79.2604 29.3898 79.2604 28.2428V17.1621H83.6003V28.2299C83.6003 28.889 83.6816 29.4797 83.8442 30.0018C84.0154 30.5154 84.2594 30.9562 84.5761 31.3243C84.8928 31.6838 85.278 31.962 85.7316 32.1589C86.1939 32.3472 86.716 32.4413 87.2981 32.4413Z" fill="white"/>
|
||||||
|
<path d="M103.513 35.8695V17.1621H110.395C111.687 17.1621 112.787 17.282 113.695 17.5216C114.602 17.7613 115.342 18.0994 115.916 18.536C116.489 18.9725 116.904 19.5032 117.161 20.1281C117.427 20.753 117.559 21.4506 117.559 22.221C117.559 22.6404 117.499 23.047 117.38 23.4407C117.26 23.8259 117.071 24.1897 116.815 24.5321C116.558 24.8745 116.228 25.1869 115.826 25.4694C115.424 25.7433 114.94 25.983 114.375 26.1884C115.608 26.488 116.519 26.9759 117.11 27.6521C117.701 28.3198 117.996 29.1801 117.996 30.2329C117.996 31.029 117.842 31.7694 117.534 32.4542C117.225 33.139 116.772 33.7382 116.173 34.2517C115.582 34.7568 114.85 35.1548 113.977 35.4458C113.104 35.7283 112.107 35.8695 110.985 35.8695H103.513ZM107.852 27.9346V32.5954H110.908C111.482 32.5954 111.948 32.5227 112.308 32.3771C112.676 32.2316 112.963 32.0433 113.168 31.8122C113.374 31.5811 113.515 31.32 113.592 31.029C113.669 30.7379 113.707 30.4426 113.707 30.143C113.707 29.8007 113.66 29.4925 113.566 29.2186C113.481 28.9447 113.326 28.7136 113.104 28.5252C112.89 28.3369 112.603 28.1914 112.244 28.0887C111.884 27.986 111.43 27.9346 110.883 27.9346H107.852ZM107.852 25.0329H110.112C110.592 25.0329 111.024 24.9986 111.409 24.9301C111.794 24.8617 112.12 24.7418 112.385 24.5706C112.659 24.3994 112.864 24.164 113.001 23.8644C113.147 23.5648 113.219 23.1882 113.219 22.7345C113.219 22.2894 113.164 21.9214 113.053 21.6303C112.941 21.3307 112.77 21.0911 112.539 20.9113C112.308 20.7316 112.013 20.6032 111.653 20.5261C111.302 20.4491 110.883 20.4106 110.395 20.4106H107.852V25.0329Z" fill="white"/>
|
||||||
|
<path d="M136.153 20.9627C136.025 21.1681 135.888 21.3222 135.743 21.4249C135.606 21.5276 135.426 21.579 135.203 21.579C135.006 21.579 134.792 21.5191 134.561 21.3992C134.339 21.2708 134.082 21.1296 133.791 20.9755C133.508 20.8214 133.183 20.6845 132.815 20.5646C132.447 20.4362 132.028 20.372 131.557 20.372C130.744 20.372 130.136 20.5475 129.734 20.8985C129.34 21.2409 129.143 21.7074 129.143 22.298C129.143 22.6746 129.263 22.9871 129.502 23.2353C129.742 23.4835 130.055 23.6975 130.44 23.8773C130.834 24.057 131.279 24.224 131.775 24.378C132.28 24.5235 132.794 24.6905 133.316 24.8788C133.838 25.0585 134.347 25.2725 134.844 25.5208C135.349 25.769 135.794 26.0857 136.179 26.4709C136.573 26.8561 136.89 27.3269 137.129 27.8833C137.369 28.4311 137.489 29.0945 137.489 29.8734C137.489 30.7379 137.339 31.5468 137.039 32.3001C136.74 33.0534 136.303 33.7125 135.73 34.2774C135.165 34.8338 134.463 35.2746 133.624 35.5999C132.794 35.9166 131.848 36.075 130.786 36.075C130.204 36.075 129.609 36.0151 129.002 35.8952C128.403 35.7754 127.82 35.6085 127.256 35.3945C126.691 35.1719 126.16 34.9108 125.663 34.6112C125.167 34.3117 124.735 33.9778 124.367 33.6098L125.651 31.5811C125.745 31.427 125.877 31.3029 126.049 31.2087C126.22 31.1146 126.404 31.0675 126.601 31.0675C126.858 31.0675 127.114 31.1488 127.371 31.3115C127.636 31.4741 127.932 31.6538 128.257 31.8507C128.591 32.0476 128.972 32.2274 129.4 32.39C129.828 32.5526 130.333 32.6339 130.915 32.6339C131.702 32.6339 132.314 32.4627 132.751 32.1204C133.187 31.7694 133.406 31.2173 133.406 30.464C133.406 30.0275 133.286 29.6723 133.046 29.3983C132.807 29.1244 132.49 28.8976 132.096 28.7178C131.711 28.5381 131.27 28.3797 130.774 28.2428C130.277 28.1058 129.768 27.956 129.246 27.7934C128.724 27.6222 128.214 27.4168 127.718 27.1771C127.221 26.9288 126.776 26.6079 126.382 26.2141C125.997 25.8118 125.685 25.3153 125.445 24.7247C125.205 24.1255 125.086 23.3894 125.086 22.5163C125.086 21.8144 125.227 21.1296 125.509 20.4619C125.792 19.7943 126.207 19.1994 126.755 18.6772C127.303 18.1551 127.975 17.7399 128.771 17.4318C129.567 17.1151 130.478 16.9567 131.505 16.9567C132.079 16.9567 132.635 17.0038 133.175 17.0979C133.722 17.1835 134.24 17.3162 134.728 17.496C135.216 17.6672 135.67 17.8769 136.089 18.1251C136.517 18.3648 136.898 18.6387 137.232 18.9468L136.153 20.9627Z" fill="white"/>
|
||||||
|
<path d="M149.348 29.6166V35.8695H145.008V17.1621H151.608C152.926 17.1621 154.056 17.3205 154.998 17.6372C155.948 17.9454 156.727 18.3733 157.335 18.9212C157.951 19.469 158.405 20.1153 158.696 20.86C158.987 21.6047 159.132 22.4093 159.132 23.2738C159.132 24.2068 158.982 25.0628 158.683 25.8418C158.383 26.6207 157.925 27.2884 157.309 27.8447C156.693 28.4011 155.909 28.8377 154.959 29.1544C154.018 29.4625 152.901 29.6166 151.608 29.6166H149.348ZM149.348 26.3425H151.608C152.738 26.3425 153.551 26.0729 154.048 25.5336C154.544 24.9943 154.792 24.2411 154.792 23.2738C154.792 22.8458 154.728 22.4564 154.6 22.1054C154.471 21.7545 154.274 21.4549 154.009 21.2066C153.752 20.9498 153.423 20.753 153.02 20.616C152.627 20.479 152.156 20.4106 151.608 20.4106H149.348V26.3425Z" fill="white"/>
|
||||||
|
<path d="M181.976 35.8695H178.612C178.235 35.8695 177.923 35.7839 177.675 35.6127C177.435 35.433 177.268 35.2062 177.174 34.9322L176.07 31.671H168.956L167.852 34.9322C167.767 35.1719 167.6 35.3902 167.351 35.5871C167.103 35.7754 166.799 35.8695 166.44 35.8695H163.05L170.292 17.1621H174.734L181.976 35.8695ZM169.958 28.7178H175.068L173.348 23.5948C173.236 23.2695 173.104 22.8886 172.95 22.4521C172.804 22.007 172.658 21.5276 172.513 21.014C172.376 21.5362 172.235 22.0198 172.089 22.4649C171.944 22.91 171.807 23.2952 171.678 23.6205L169.958 28.7178Z" fill="white"/>
|
||||||
|
<path d="M200.654 31.029C200.757 31.029 200.86 31.0504 200.962 31.0932C201.065 31.1274 201.164 31.1916 201.258 31.2858L202.978 33.0962C202.225 34.0805 201.279 34.8252 200.141 35.3303C199.011 35.8267 197.671 36.075 196.122 36.075C194.701 36.075 193.425 35.8353 192.296 35.356C191.174 34.868 190.22 34.2004 189.432 33.353C188.653 32.497 188.054 31.4869 187.635 30.3228C187.215 29.1501 187.006 27.879 187.006 26.5094C187.006 25.1142 187.245 23.8345 187.725 22.6704C188.204 21.4977 188.872 20.4876 189.728 19.6402C190.592 18.7928 191.624 18.1337 192.822 17.6629C194.02 17.1921 195.343 16.9567 196.789 16.9567C197.491 16.9567 198.15 17.0209 198.767 17.1493C199.392 17.2691 199.974 17.4403 200.513 17.6629C201.052 17.8769 201.549 18.1379 202.002 18.4461C202.456 18.7457 202.858 19.0795 203.209 19.4476L201.746 21.4121C201.651 21.5319 201.54 21.6432 201.412 21.7459C201.283 21.8401 201.104 21.8871 200.872 21.8871C200.718 21.8871 200.573 21.8529 200.436 21.7844C200.299 21.7159 200.153 21.6346 199.999 21.5405C199.845 21.4377 199.674 21.3307 199.486 21.2195C199.306 21.0996 199.088 20.9926 198.831 20.8985C198.583 20.7958 198.287 20.7102 197.945 20.6417C197.611 20.5732 197.217 20.539 196.764 20.539C195.976 20.539 195.257 20.6802 194.607 20.9627C193.956 21.2366 193.396 21.6346 192.925 22.1568C192.462 22.6704 192.099 23.2952 191.833 24.0314C191.577 24.7675 191.448 25.5935 191.448 26.5094C191.448 27.4681 191.577 28.3198 191.833 29.0645C192.099 29.8092 192.454 30.4384 192.899 30.9519C193.353 31.457 193.879 31.8422 194.478 32.1075C195.078 32.3729 195.719 32.5055 196.404 32.5055C196.798 32.5055 197.158 32.4884 197.483 32.4542C197.808 32.4114 198.108 32.3429 198.382 32.2487C198.664 32.1546 198.929 32.0348 199.178 31.8892C199.434 31.7352 199.691 31.5468 199.948 31.3243C200.051 31.2387 200.162 31.1702 200.282 31.1189C200.402 31.0589 200.526 31.029 200.654 31.029Z" fill="white"/>
|
||||||
|
<path d="M222.368 17.1621V20.5004H214.69V24.8659H220.57V28.0759H214.69V32.5312H222.368V35.8695H210.324V17.1621H222.368Z" fill="white"/>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 11 KiB |
|
@ -0,0 +1,64 @@
|
||||||
|
$(document).ready(function() {
|
||||||
|
|
||||||
|
$(window).scroll(function() {
|
||||||
|
$('.js-inviewport-item').isInViewport({
|
||||||
|
tolerance: 0
|
||||||
|
})
|
||||||
|
.addClass('is-active');
|
||||||
|
});
|
||||||
|
|
||||||
|
var options = {
|
||||||
|
classes: {
|
||||||
|
clone: 'o-header__top--clone',
|
||||||
|
stick: 'is-sticky',
|
||||||
|
unstick: 'is-unsticky'
|
||||||
|
}
|
||||||
|
};
|
||||||
|
if($(window).width() >= 767) {
|
||||||
|
var header = new Headhesive('.js-header', options);
|
||||||
|
}
|
||||||
|
$('.js-navigation-open').on('click', function(event) {
|
||||||
|
event.preventDefault();
|
||||||
|
|
||||||
|
$('.js-navigation-list').addClass('is-active');
|
||||||
|
});
|
||||||
|
|
||||||
|
$('.js-navigation-close').on('click', function(event) {
|
||||||
|
event.preventDefault();
|
||||||
|
|
||||||
|
$('.js-navigation-list').removeClass('is-active');
|
||||||
|
});
|
||||||
|
|
||||||
|
$('.js-header-keyvisual').addClass('is-active');
|
||||||
|
|
||||||
|
// Popup
|
||||||
|
$('.js-popup').magnificPopup({
|
||||||
|
type: 'inline',
|
||||||
|
preloader: false,
|
||||||
|
focus: '#name',
|
||||||
|
|
||||||
|
// When elemened is focused, some mobile browsers in some cases zoom in
|
||||||
|
// It looks not nice, so we disable it:
|
||||||
|
callbacks: {
|
||||||
|
beforeOpen: function() {
|
||||||
|
if($(window).width() < 700) {
|
||||||
|
this.st.focus = false;
|
||||||
|
} else {
|
||||||
|
this.st.focus = '#name';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Scroll
|
||||||
|
$('.js-anchor-scroll').anchorScroll({
|
||||||
|
scrollSpeed: 800, // scroll speed
|
||||||
|
offsetTop: 100, // offset for fixed top bars (defaults to 0)
|
||||||
|
onScroll: function () {
|
||||||
|
// callback on scroll start
|
||||||
|
},
|
||||||
|
scrollEnd: function () {
|
||||||
|
// callback on scroll end
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
|
@ -0,0 +1,4 @@
|
||||||
|
---
|
||||||
|
title: {{ title }}
|
||||||
|
tags:
|
||||||
|
---
|
|
@ -0,0 +1,4 @@
|
||||||
|
---
|
||||||
|
title: {{ title }}
|
||||||
|
date: {{ date }}
|
||||||
|
---
|
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
title: {{ title }}
|
||||||
|
date: {{ date }}
|
||||||
|
tags:
|
||||||
|
---
|
|
@ -0,0 +1,62 @@
|
||||||
|
var join = require('path').join;
|
||||||
|
|
||||||
|
hexo.extend.helper.register('show_lang', function (lang) {
|
||||||
|
if (this.page.lang != 'en') {
|
||||||
|
return '/' + this.page.lang;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
hexo.extend.helper.register('lang_name', function(lang) {
|
||||||
|
var data = this.site.data.languages[lang];
|
||||||
|
return data.name || data;
|
||||||
|
});
|
||||||
|
|
||||||
|
hexo.extend.helper.register('sidebar', function (path) {
|
||||||
|
return `
|
||||||
|
<ul class="c-side-navigation js-docs-sidebar">
|
||||||
|
<li class="c-side-navigation__header">
|
||||||
|
<a href="#" class="c-side-navigation__header__offset js-docs-trigger-close">
|
||||||
|
<svg width="18" height="17" viewBox="0 0 18 17" fill="none" xmlns="http://www.w3.org/2000/svg"> <rect x="1.5752" y="0.368273" width="22" height="1" rx="0.5" transform="rotate(45 1.5752 0.368273)" fill="#090909"></rect> <rect x="0.868164" y="15.9246" width="22" height="1" rx="0.5" transform="rotate(-45 0.868164 15.9246)" fill="#090909"></rect> </svg>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
${genSidebarList.call(this, "", this.site.data.sidebar[path])}
|
||||||
|
</ul>
|
||||||
|
`
|
||||||
|
});
|
||||||
|
|
||||||
|
function genSidebarList(parent, entries) {
|
||||||
|
/* necessary due to changed context of map() */
|
||||||
|
let self = this
|
||||||
|
/* all languages except english needs a path prefix */
|
||||||
|
let lang = (self.page.lang != 'en' && parent == "") ? self.page.lang : ''
|
||||||
|
return entries.map(entry => {
|
||||||
|
/* normally path needs to be prefixed with lang and parent path */
|
||||||
|
|
||||||
|
let fullPath;
|
||||||
|
if (entry.path.startsWith('#')) {
|
||||||
|
fullPath = join('', lang, parent) + entry.path;
|
||||||
|
} else if (entry.path.startsWith('empty')) {
|
||||||
|
fullPath = 'empty';
|
||||||
|
} else {
|
||||||
|
fullPath = join('', lang, entry.path);
|
||||||
|
}
|
||||||
|
/* sometimes paths are full URLs instead of sub-paths */
|
||||||
|
if (entry.path.startsWith('http')) {
|
||||||
|
fullPath = entry.path
|
||||||
|
}
|
||||||
|
/* path is active when it's the one we are on currently */
|
||||||
|
let isActive = (self.path).startsWith(fullPath)
|
||||||
|
return `
|
||||||
|
<li class="c-side-navigation__item ${isActive ? "is-active" : ""}">
|
||||||
|
${(fullPath == 'empty') ? `
|
||||||
|
<span class="c-side-navigation__item__anchor">${entry.title}</span>
|
||||||
|
` : `<a href="${fullPath}" class="c-side-navigation__item__anchor">${entry.title}</a>`
|
||||||
|
}
|
||||||
|
${(entry.children != undefined) ? `
|
||||||
|
<ul class="c-side-navigation__item__tree">
|
||||||
|
${genSidebarList.call(self, fullPath, entry.children)}
|
||||||
|
</ul>
|
||||||
|
` : ''}
|
||||||
|
</li>`
|
||||||
|
}).join('\n')
|
||||||
|
}
|
|
@ -0,0 +1 @@
|
||||||
|
subspace.status.im
|
|
@ -0,0 +1,65 @@
|
||||||
|
docs:
|
||||||
|
- title: How it works
|
||||||
|
path: how-it-works.html
|
||||||
|
|
||||||
|
- title: Getting Started
|
||||||
|
path: getting-started.html
|
||||||
|
children:
|
||||||
|
- title: Installation
|
||||||
|
path: '#Installation'
|
||||||
|
- title: Importing the library
|
||||||
|
path: '#Importing-the-library'
|
||||||
|
- title: Connecting to a web3 provider
|
||||||
|
path: '#Connecting-to-a-web3-provider'
|
||||||
|
- title: Enhancing your contract objects
|
||||||
|
path: '#Enhancing-your-contract-objects'
|
||||||
|
- title: Reacting to data
|
||||||
|
path: '#Reacting-to-data'
|
||||||
|
- title: Tracking state
|
||||||
|
path: '#Tracking-state'
|
||||||
|
- title: Tracking events
|
||||||
|
path: '#Tracking-events'
|
||||||
|
- title: Tracking balances
|
||||||
|
path: '#Tracking-balances'
|
||||||
|
- title: Getting block data, gas prices and block time
|
||||||
|
path: '#Getting-block-data-gas-prices-and-block-time'
|
||||||
|
- title: Subscriptions
|
||||||
|
path: '#Subscriptions'
|
||||||
|
- title: Cleanup
|
||||||
|
path: '#Cleanup'
|
||||||
|
|
||||||
|
- title: Integrations
|
||||||
|
path: 'empty'
|
||||||
|
children:
|
||||||
|
- title: Overview
|
||||||
|
path: integrations-overview.html
|
||||||
|
- title: React
|
||||||
|
path: react.html
|
||||||
|
- title: Vue
|
||||||
|
path: vue.html
|
||||||
|
- title: Redux
|
||||||
|
path: 'empty'
|
||||||
|
children:
|
||||||
|
- title: redux
|
||||||
|
path: redux.html
|
||||||
|
- title: redux-observable
|
||||||
|
path: redux-observable.html
|
||||||
|
- title: reactive-graphql
|
||||||
|
path: reactive-graphql.html
|
||||||
|
- title: apollo-client
|
||||||
|
path: apollo-client.html
|
||||||
|
|
||||||
|
- title: Tutorial
|
||||||
|
path: tutorial.html
|
||||||
|
|
||||||
|
- title: API
|
||||||
|
path: api.html
|
||||||
|
children:
|
||||||
|
- title: General
|
||||||
|
path: '#general'
|
||||||
|
- title: Contract methods
|
||||||
|
path: '#Contract-methods'
|
||||||
|
- title: Blocks, gas price and block time
|
||||||
|
path: '#Blocks-gas-price-and-block-time'
|
||||||
|
- title: Low level API for data tracking
|
||||||
|
path: '#Low-level-API-for-data-tracking'
|
|
@ -0,0 +1,38 @@
|
||||||
|
---
|
||||||
|
title: Hello World
|
||||||
|
---
|
||||||
|
Welcome to [Hexo](https://hexo.io/)! This is your very first post. Check [documentation](https://hexo.io/docs/) for more info. If you get any problems when using Hexo, you can find the answer in [troubleshooting](https://hexo.io/docs/troubleshooting.html) or you can ask me on [GitHub](https://github.com/hexojs/hexo/issues).
|
||||||
|
|
||||||
|
## Quick Start
|
||||||
|
|
||||||
|
### Create a new post
|
||||||
|
|
||||||
|
``` bash
|
||||||
|
$ hexo new "My New Post"
|
||||||
|
```
|
||||||
|
|
||||||
|
More info: [Writing](https://hexo.io/docs/writing.html)
|
||||||
|
|
||||||
|
### Run server
|
||||||
|
|
||||||
|
``` bash
|
||||||
|
$ hexo server
|
||||||
|
```
|
||||||
|
|
||||||
|
More info: [Server](https://hexo.io/docs/server.html)
|
||||||
|
|
||||||
|
### Generate static files
|
||||||
|
|
||||||
|
``` bash
|
||||||
|
$ hexo generate
|
||||||
|
```
|
||||||
|
|
||||||
|
More info: [Generating](https://hexo.io/docs/generating.html)
|
||||||
|
|
||||||
|
### Deploy to remote sites
|
||||||
|
|
||||||
|
``` bash
|
||||||
|
$ hexo deploy
|
||||||
|
```
|
||||||
|
|
||||||
|
More info: [Deployment](https://hexo.io/docs/one-command-deployment.html)
|
|
@ -0,0 +1,154 @@
|
||||||
|
# API
|
||||||
|
|
||||||
|
## General
|
||||||
|
|
||||||
|
### `new Subspace(web3Provider [, options])`
|
||||||
|
Constructor.
|
||||||
|
|
||||||
|
**Parameters**
|
||||||
|
1. `web3Provider` - `Object`: a valid web3 provider.
|
||||||
|
2. `options` - `Object` (optional): Options used to initialize Subspace
|
||||||
|
- `dbFilename` - `String` (optional): Name of the database where the information will be stored (default `'subspace.db'`)
|
||||||
|
- `callInterval` - `Number` (optional): - Interval of time in milliseconds to poll a contract/address to determine changes in state or balance (default: `undefined`. Obtains data every block. If using a HttpProvider, the default is: `1000`)
|
||||||
|
- `refreshLastNBlocks` - Ignores last N blocks (from current block), stored in the local db and refresh them via a web3 subscription. Useful for possible reorgs (default: 12),
|
||||||
|
- `disableSubscriptions` - Subspace by default will attempt to use websocket subscriptions if the current provider supports them, otherwise it will use polling because it asumes the provider is an HttpProvider. This functionality can be disabled by passing true to this option. (default: undefined)
|
||||||
|
|
||||||
|
|
||||||
|
### `init()`
|
||||||
|
Initializes **Subspace**
|
||||||
|
|
||||||
|
**Returns**
|
||||||
|
`Promise` that once it's resolved, will mean that **Subspace** is available to use
|
||||||
|
|
||||||
|
### `close()`
|
||||||
|
Dispose and perform the cleanup necessary to remove the internal subscriptions and interval timers created by **Subspace** during its normal execution.
|
||||||
|
|
||||||
|
### `contract(instance|{abi,address})`
|
||||||
|
Adds a `track` method to the web3 contract objects. You can obtain this functionality by passing a `web3.eth.Contract` instance, or the `abi` and `address` of your contract
|
||||||
|
|
||||||
|
**Returns**
|
||||||
|
`web3.eth.Contract` object enhanced with `.track()` functions for methods and events.
|
||||||
|
|
||||||
|
## Contract methods
|
||||||
|
|
||||||
|
### `myContract.events.MyEvent.track([options])`
|
||||||
|
Track a contract event.
|
||||||
|
|
||||||
|
**Parameters**
|
||||||
|
1. `options` - `Object` (optional): web3 filter options object to limit the number of events based on a block number range, or indexed filters
|
||||||
|
- `filter` - `Object` (optional): Lets you filter events by indexed parameters, e.g. `{filter: {myNumber: [12,13]}}` means all events where `"myNumber"` is `12` or `13`.
|
||||||
|
- `fromBlock` - `Number` (optional): The block number from which to get events on.
|
||||||
|
- `toBlock` - `Number` (optional): The block number to get events up to (Defaults to `"latest"`)
|
||||||
|
- `topics` - `Array` (optional): This allows you to manually set the topics for the event filter. If given the filter property and event signature, (`topic[0]`) will not be set automatically.
|
||||||
|
|
||||||
|
**Returns**
|
||||||
|
`RxJS Observable` which will stream the event `returnValues`.
|
||||||
|
|
||||||
|
|
||||||
|
### `myContract.methods.myMethod([param1[, ...]]).track([callOptions])`
|
||||||
|
Track a constant function / contract state variable on each block mined, or depending on the `callInterval` option used during **Subspace** initialization.
|
||||||
|
|
||||||
|
**Parameters**
|
||||||
|
1. `callOptions` - `Object` (optional): The options used for calling.
|
||||||
|
- `from` - `String` (optional): The address the call “transaction” should be made from.
|
||||||
|
- `gasPrice` - `String` (optional): The gas price in wei to use for this call “transaction”.
|
||||||
|
- `gas` - `Number` (optional): The maximum gas provided for this call “transaction” (gas limit).
|
||||||
|
|
||||||
|
**Returns**
|
||||||
|
`RxJS Observable` which will stream the function / variable values. Data type will depend on the contract function invoked.
|
||||||
|
|
||||||
|
|
||||||
|
### `myContract.trackBalance(address [, tokenAddress])`
|
||||||
|
Track a contract's balance changes for an address on each block mined, or depending on the `callInterval` option used during **Subspace** initialization.
|
||||||
|
|
||||||
|
**Parameters**
|
||||||
|
1. `address` - `String`: The address to get the balance of.
|
||||||
|
2. `tokenAddress` - `String` (optional): If you want to track the balance for an ERC20 contract, here you can specify the token address. Otherwise, Only ETH balances will be returned.
|
||||||
|
|
||||||
|
**Returns**
|
||||||
|
`RxJS Observable` which will stream a string containing the address balance.
|
||||||
|
|
||||||
|
|
||||||
|
## Blocks, gas price and block time
|
||||||
|
|
||||||
|
### `trackBlock()`
|
||||||
|
Receive the block information for any new block. It's the reactive equivalent to `web3.eth.getBlock("latest")`.
|
||||||
|
|
||||||
|
**Returns**
|
||||||
|
`RxJS Observable` which will stream a block object for the latest block received
|
||||||
|
|
||||||
|
### `trackBlockNumber()`
|
||||||
|
Returns the latest block number. It's the reactive equivalent to `web3.eth.getBlockNumber`.
|
||||||
|
|
||||||
|
**Returns**
|
||||||
|
`RxJS Observable` with the latest block number
|
||||||
|
|
||||||
|
### `trackGasPrice()`
|
||||||
|
Returns the current gas price oracle. It's the reactive equivalent to `web3.eth.getGasPrice`.
|
||||||
|
|
||||||
|
**Returns**
|
||||||
|
`RxJS Observable` with the average gas price in wei.
|
||||||
|
|
||||||
|
### `trackAverageBlocktime()`
|
||||||
|
Average block time of the last 10 blocks.
|
||||||
|
|
||||||
|
**Returns**
|
||||||
|
`RxJS Observable` with the moving average block time of the last 10 blocks. The time is returned in milliseconds:
|
||||||
|
|
||||||
|
|
||||||
|
## Low level API for data tracking
|
||||||
|
|
||||||
|
These are used in case you don't want to decorate your web3 contract objects, or if you want to track the balance for an specific address.
|
||||||
|
|
||||||
|
### `trackEvent(contractObject, eventName [, options])`
|
||||||
|
Track a contract event.
|
||||||
|
|
||||||
|
**Parameters**
|
||||||
|
1. `contractObject` - `web3.eth.Contract`: An already initialized contract object pointing to an address and containing a valid ABI.
|
||||||
|
2. `eventName` - `String`: The name of the event to subscribe.
|
||||||
|
3. `options` - `Object` (optional): web3 filter options object to limit the number of events based on a block number range, or indexed filters
|
||||||
|
- `filter` - `Object` (optional): Lets you filter events by indexed parameters, e.g. `{filter: {myNumber: [12,13]}}` means all events where `"myNumber"` is `12` or `13`.
|
||||||
|
- `fromBlock` - `Number` (optional): The block number from which to get events on.
|
||||||
|
- `toBlock` - `Number` (optional): The block number to get events up to (Defaults to `"latest"`)
|
||||||
|
- `topics` - `Array` (optional): This allows you to manually set the topics for the event filter. If given the filter property and event signature, (`topic[0]`) will not be set automatically.
|
||||||
|
|
||||||
|
**Returns**
|
||||||
|
`RxJS Observable` which will stream the event `returnValues`.
|
||||||
|
|
||||||
|
### `trackProperty(contractObject, functionName [, functionArgs] [, callOptions])`
|
||||||
|
Track a constant function / contract state variable on each block mined, or depending on the `callInterval` option used during **Subspace** initialization.
|
||||||
|
|
||||||
|
**Parameters**
|
||||||
|
1. `contractObject` - `web3.eth.Contract`: An already initialized contract object pointing to an address and containing a valid ABI.
|
||||||
|
2. `functionName` - `String`: Name of the function or variable whose values will be tracked.
|
||||||
|
3. `functionArgs` - `Array` (optional): Array of arguments that the tracked function receives
|
||||||
|
4. `callOptions` - `Object` (optional): The options used for calling.
|
||||||
|
- `from` - `String` (optional): The address the call “transaction” should be made from.
|
||||||
|
- `gasPrice` - `String` (optional): The gas price in wei to use for this call “transaction”.
|
||||||
|
- `gas` - `Number` (optional): The maximum gas provided for this call “transaction” (gas limit).
|
||||||
|
|
||||||
|
**Returns**
|
||||||
|
`RxJS Observable` which will stream the function / variable values. Data type will depend on the contract function invoked.
|
||||||
|
|
||||||
|
### `trackBalance(address [, tokenAddress])`
|
||||||
|
Track balance changes for an address on each block mined, or depending on the `callInterval` option used during **Subspace** initialization.
|
||||||
|
|
||||||
|
**Parameters**
|
||||||
|
1. `address` - `String`: The address to get the balance of.
|
||||||
|
2. `tokenAddress` - `String` (optional): If you want to track the balance for an ERC20 contract, here you can specify the token address. Otherwise, Only ETH balances will be returned.
|
||||||
|
|
||||||
|
**Returns**
|
||||||
|
`RxJS Observable` which will stream a string containing the address balance.
|
||||||
|
|
||||||
|
### `trackLogs(options [, abi])`
|
||||||
|
Tracks incoming logs, filtered by the given options.
|
||||||
|
|
||||||
|
**Parameters**
|
||||||
|
1. `options` - `Object` (optional): web3 filter options object to limit the number of logs
|
||||||
|
- `address` - `String|Array` (optional): An address or a list of addresses to only get logs from particular account(s).
|
||||||
|
- `fromBlock` - `Number` (optional): The block number from which to get events on.
|
||||||
|
- `topics` - `Array` (optional): An array of values which must each appear in the log entries. The order is important, if you want to leave topics out use null, e.g. [null, '0x00...']. You can also pass another array for each topic with options for that topic e.g. [null, ['option1', 'option2']].
|
||||||
|
2. `abi` - `Array` (optional): Array containing the ABI for the inputs of the logs received. It will automatically decode the logs using this ABI instead of returning the hexadecimal data.
|
||||||
|
|
||||||
|
**Returns**
|
||||||
|
`RxJS Observable` which will stream the logs. If the inputs ABI is included in the call, the logs will be automatically decoded.
|
|
@ -0,0 +1,76 @@
|
||||||
|
# apollo-client
|
||||||
|
To use **Subspace** with `apollo-client`, a composed `ApolloLink` must be defined using the `apollo-link-rxjs` and `reactive-graphl` npm packages. Notice that the `addTypename` option of `InMemoryCache` must be set `false`.
|
||||||
|
|
||||||
|
```js
|
||||||
|
import { ApolloClient } from "apollo-client";
|
||||||
|
import { InMemoryCache } from "apollo-cache-inmemory";
|
||||||
|
import { ApolloLink } from "apollo-link";
|
||||||
|
import { rxjs as rxJsLink } from "apollo-link-rxjs";
|
||||||
|
import { graphql } from "reactive-graphql";
|
||||||
|
|
||||||
|
const client = new ApolloClient({
|
||||||
|
// If addTypename:true, the query will fail due to __typename
|
||||||
|
// being added to the schema. reactive-graphql does not
|
||||||
|
// support __typename at this moment.
|
||||||
|
cache: new InMemoryCache({ addTypename: false }),
|
||||||
|
link: ApolloLink.from([
|
||||||
|
rxJsLink({}),
|
||||||
|
new ApolloLink(operation => graphql(schema, operation.query))
|
||||||
|
])
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
### Example
|
||||||
|
|
||||||
|
```js{35-45}
|
||||||
|
import { ApolloClient } from "apollo-client";
|
||||||
|
import { InMemoryCache } from "apollo-cache-inmemory";
|
||||||
|
import { ApolloLink } from "apollo-link";
|
||||||
|
import { rxjs as rxJsLink } from "apollo-link-rxjs";
|
||||||
|
import { graphql } from "reactive-graphql";
|
||||||
|
|
||||||
|
// ...
|
||||||
|
|
||||||
|
// Initialize Subspace
|
||||||
|
const subspace = new Subspace(web3.currentProvider); // Use a valid provider (geth, parity, infura...)
|
||||||
|
await subspace.init();
|
||||||
|
|
||||||
|
const MyContractInstance = ...; // TODO: obtain a web3.eth.contract instance
|
||||||
|
|
||||||
|
const typeDefs = `
|
||||||
|
type MyEvent {
|
||||||
|
someValue: Int
|
||||||
|
anotherValue: String
|
||||||
|
}
|
||||||
|
type Query {
|
||||||
|
myEvents: MyEvent!
|
||||||
|
}
|
||||||
|
`;
|
||||||
|
|
||||||
|
const resolvers = {
|
||||||
|
Query: {
|
||||||
|
myEvents: () => {
|
||||||
|
return subspace.trackEvent(MyContractInstance, 'MyEvent', {filter: {}, fromBlock: 1})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const schema = makeExecutableSchema({ typeDefs, resolvers });
|
||||||
|
|
||||||
|
const client = new ApolloClient({
|
||||||
|
// If addTypename:true, the query will fail due to __typename
|
||||||
|
// being added to the schema. reactive-graphql does not
|
||||||
|
// support __typename at this moment.
|
||||||
|
cache: new InMemoryCache({ addTypename: false }),
|
||||||
|
link: ApolloLink.from([
|
||||||
|
rxJsLink({}),
|
||||||
|
new ApolloLink(operation => graphql(schema, operation.query))
|
||||||
|
])
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
<div class="c-notification">
|
||||||
|
Using react-apollo
|
||||||
|
A practical example can also be found in `examples/react-apollo`.
|
||||||
|
</div>
|
After Width: | Height: | Size: 184 KiB |
After Width: | Height: | Size: 216 KiB |
After Width: | Height: | Size: 226 KiB |
After Width: | Height: | Size: 212 KiB |
|
@ -0,0 +1,223 @@
|
||||||
|
|
||||||
|
---
|
||||||
|
title: Getting Started
|
||||||
|
---
|
||||||
|
# Getting Started
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
**Subspace** can be used in browser, node and native script environments. To get started install the package `@embarklabs/subspace` using `npm` or `yarn` by executing this command in your project directory:
|
||||||
|
```bash
|
||||||
|
# Using npm
|
||||||
|
npm install --save @embarklabs/subspace
|
||||||
|
|
||||||
|
# Using yarn
|
||||||
|
yarn add @embarklabs/subspace
|
||||||
|
```
|
||||||
|
|
||||||
|
## Importing the library
|
||||||
|
|
||||||
|
```js
|
||||||
|
// ESM (might require babel / browserify)
|
||||||
|
import Subspace from '@embarklabs/subspace';
|
||||||
|
|
||||||
|
// CommonJS
|
||||||
|
const Subspace = require('@embarklabs/subspace');
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
## Connecting to a web3 provider
|
||||||
|
To interact with the EVM, **Subspace** requires a valid Web3 provider.
|
||||||
|
|
||||||
|
```js
|
||||||
|
const subspace = new Subspace(web3.currentProvider);
|
||||||
|
await subspace.init();
|
||||||
|
```
|
||||||
|
|
||||||
|
In addition to the provider, `Subspace` also accepts an `options` object with settings that can change its behavior:
|
||||||
|
- `dbFilename` - Name of the database where the information will be stored (default `'subspace.db'`)
|
||||||
|
- `callInterval` - Interval of time in milliseconds to query a contract/address to determine changes in state or balance (default: `undefined`. Obtains data every block).
|
||||||
|
- `refreshLastNBlocks` - Ignores last N blocks (from current block), stored in the local db and refresh them via a web3 subscription. Useful for possible reorgs (default: 12),
|
||||||
|
- `disableSubscriptions` - Subspace by default will attempt to use websocket subscriptions if the current provider supports them, otherwise it will use polling because it asumes the provider is an HttpProvider. This functionality can be disabled by passing true to this option. (default: undefined)
|
||||||
|
|
||||||
|
|
||||||
|
## Enhancing your contract objects
|
||||||
|
Subspace provides a method to enhance your web3 Contract objects: `subspace.contract(instance|{abi,address})`. Calling this method will return a new contract object decorated with a `.track()` method for your contract view functions and events.
|
||||||
|
|
||||||
|
```js
|
||||||
|
const myRxContract = subspace.contract(myContractInstance);
|
||||||
|
```
|
||||||
|
|
||||||
|
You can also instantiate a contract directly by passing the contract ABI and its address:
|
||||||
|
|
||||||
|
```js
|
||||||
|
const myRXContract = subspace.contract({abi: ...., address: '0x1234...CDEF'})
|
||||||
|
```
|
||||||
|
|
||||||
|
## Reacting to data
|
||||||
|
Once it's initialized, you can use **Subspace**'s methods to track the contract state, events and balances. These functions return RxJS Observables which you can subscribe to, and obtain and transform the observed data via operators.
|
||||||
|
|
||||||
|
<div class="c-notification">
|
||||||
|
What is an Observable?
|
||||||
|
The `Observable` type can be used to model push-based data sources such as DOM events, timer intervals, and sockets. In addition, observables are:
|
||||||
|
- Compositional: Observables can be composed with higher-order combinators.
|
||||||
|
- Lazy: Observables do not start emitting data until an observer has subscribed.
|
||||||
|
</div>
|
||||||
|
|
||||||
|
#### Further read
|
||||||
|
- [RxJS Observables](https://rxjs-dev.firebaseapp.com/guide/observable)
|
||||||
|
|
||||||
|
## Tracking state
|
||||||
|
You can track changes to a contract state variable, by specifying the view function and arguments to call and query the contract.
|
||||||
|
```js
|
||||||
|
const stateObservable$ = Contract.methods.functionName(functionArgs).track();
|
||||||
|
```
|
||||||
|
|
||||||
|
<div class="c-notification">Tracking the public variables of a contract
|
||||||
|
State variables implicity create a `view` function when they're defined as `public`. The `functionName` would be the same as the variable name, and `functionArgs` will have a value when the type is a `mapping` or `array` (since these require an index value to query them).
|
||||||
|
</div>
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
```js
|
||||||
|
const productTitle$ = ProductList.methods.products(0).track().map("title");
|
||||||
|
productTitle$.subscribe((title) => console.log("product title is " + title));
|
||||||
|
|
||||||
|
|
||||||
|
// Alternative using Subspace low level API
|
||||||
|
const producTitle$ = subspace.trackProperty(ProductList, "products", [0], {from: web3.eth.defaultAccount});
|
||||||
|
...
|
||||||
|
```
|
||||||
|
|
||||||
|
The subscription will be triggered whenever the title changes
|
||||||
|
|
||||||
|
## Tracking events
|
||||||
|
You can track events and react to their returned values.
|
||||||
|
```js
|
||||||
|
const eventObservable$ = Contract.event.eventName().track();
|
||||||
|
```
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
```js
|
||||||
|
const rating$ = Product.events.Rating().track().map("rating")).pipe(map(x => parseInt(x)));
|
||||||
|
rating$.subscribe((rating) => console.log("rating received: " + rating));
|
||||||
|
|
||||||
|
|
||||||
|
// Alternative using Subspace low level API
|
||||||
|
const rating$ = subspace.trackEvent(Product, "Rating", {fromBlock: 0});
|
||||||
|
...
|
||||||
|
```
|
||||||
|
|
||||||
|
**Event Sourcing**
|
||||||
|
|
||||||
|
You can easily do event sourcing with subspace.
|
||||||
|
|
||||||
|
For e.g: if you needed to get the average rating of the last 5 events:
|
||||||
|
|
||||||
|
```js
|
||||||
|
import { $average, $latest } from "@embarklabs/subspace";
|
||||||
|
|
||||||
|
const rating$ = Product.events.Rating().track().map("rating")).pipe(map(x => parseInt(x)));
|
||||||
|
|
||||||
|
rating$.pipe($latest(5), $average()).subscribe((rating) => {
|
||||||
|
console.log("average rating of the last 5 events is " + rating)
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
## Tracking balances
|
||||||
|
You can also track changes in both ETH and ERC20 token balances for each mined block or time interval depending on the `callInterval` configured.
|
||||||
|
|
||||||
|
Tracking ETH balance in an address:
|
||||||
|
|
||||||
|
```js
|
||||||
|
const address = "0x0001020304050607080900010203040506070809";
|
||||||
|
|
||||||
|
subspace.trackBalance(address).subscribe((balance) => {
|
||||||
|
console.log("ETH balance is ", balance)
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
Tracking ETH balance in a Contract:
|
||||||
|
|
||||||
|
```js
|
||||||
|
Contract.trackBalance().subscribe((balance) => {
|
||||||
|
console.log("ETH balance is ", balance)
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
Tracking an ERC20 balance in a Contract:
|
||||||
|
|
||||||
|
```js
|
||||||
|
const tokenAddress = "0x744d70fdbe2ba4cf95131626614a1763df805b9e"; // SNT Address
|
||||||
|
|
||||||
|
const myBalanceObservable$ = Contract.trackBalance(tokenAddress);
|
||||||
|
```
|
||||||
|
|
||||||
|
<div class="c-notification c-notification--warning">
|
||||||
|
Balances are returned as a string containing the value in *wei*.
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Getting block data, gas prices and block time
|
||||||
|
Subspace also provides a way to always receive the latest block object:
|
||||||
|
```js
|
||||||
|
subspace.trackBlock().subscribe(block => {
|
||||||
|
console.log("The latest block data: ", block);
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
If you don't need all the block information, but just the block number, you can use instead:
|
||||||
|
```js
|
||||||
|
subspace.trackBlockNumber().subscribe(blockNumber => {
|
||||||
|
console.log("The latest block number: ", blockNumber);
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
You can also access the average block time. This takes in account only the last 10 blocks:
|
||||||
|
|
||||||
|
```js
|
||||||
|
subspace.trackAverageBlocktime().subscribe(blocktimeMS => {
|
||||||
|
console.log("The average block time in milliseconds is: ", blocktimeMS);
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
Finally, if you want to obtain the most up to date median gas price:
|
||||||
|
|
||||||
|
```js
|
||||||
|
subspace.trackGasPrice().subscribe(gasPrice => {
|
||||||
|
console.log("Gas price in wei", gasPrice);
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
## Subscriptions
|
||||||
|
Once you have an `Observable`, you may receive a stream of data by creating a subscription. Subscriptions are triggered each time an observable emits a new value. These subscription receive a callback that must have a parameter which represents the value received from the observable (a contract state variable, an event, or the balance of an address); and they return an object representing the subscription.
|
||||||
|
|
||||||
|
Subscriptions can be disposed by executing the method `unsubscribe()` liberating the resource held by it:
|
||||||
|
|
||||||
|
```js
|
||||||
|
const myBalanceObservable$ = subspace.trackBalance(address, tokenAddress);
|
||||||
|
const subscription = myBalanceObservable$.subscribe(value => {
|
||||||
|
console.log("The balance is: ", value);
|
||||||
|
});
|
||||||
|
|
||||||
|
// ...
|
||||||
|
|
||||||
|
subscription.unsubscribe();
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Further read
|
||||||
|
- [RxJS Subscriptions](https://rxjs-dev.firebaseapp.com/guide/subscription)
|
||||||
|
|
||||||
|
## Cleanup
|
||||||
|
If **Subspace** is not needed anymore, you need can invoke `close()` to dispose and perform the cleanup necessary to remove the internal subscriptions and interval timers created by **Subspace** during its normal execution, thus avoiding any potential memory leak.
|
||||||
|
|
||||||
|
```
|
||||||
|
subspace.close();
|
||||||
|
```
|
||||||
|
<div class="c-notification c-notification--warning">
|
||||||
|
What about subscriptions created with our observables?
|
||||||
|
Any subscription created via the tracking methods must be unsubscribed manually (in the current version).
|
||||||
|
</div>
|
||||||
|
|
|
@ -0,0 +1,20 @@
|
||||||
|
# How it works?
|
||||||
|
|
||||||
|
### Setup
|
||||||
|
![First Usage - Setup](./d1.png)
|
||||||
|
1. A ÐApp requests `Subspace` to track an event, property, or balance.
|
||||||
|
2. `Subspace` creates a observable for that event, and a web3 subscription to retrieve events from the chain
|
||||||
|
3. The ÐApp subscribes to the observable to receive events.
|
||||||
|
|
||||||
|
### Receiving events
|
||||||
|
![First Usage - Receiving events](./d2.png)
|
||||||
|
Depending on the filter parameters used to track the events, once an event is found, it is stored in `localStorage` and it is also pushed to the observable which delivers it to the ÐApp subscription.
|
||||||
|
|
||||||
|
### Tracking already known events
|
||||||
|
After restarting the ÐApp, either by executing it again in case of a console application or refreshing the browser the behavior of `Subspace` will change:
|
||||||
|
![Second Usage - Setup](./d3.png)
|
||||||
|
1. The Dapp will request `Subspace` to track an event it already knows, creating an observable and subscription for that event
|
||||||
|
2. It will retrieve events that were previously stored in localStorage and deliver them to the DApp subscription, avoiding having to query the chain for the old events again.
|
||||||
|
|
||||||
|
![Second Usage - Receiving events](./d4.png)
|
||||||
|
The web3 subscription created previously will start from the last known block instead of beginning from scratch. New events will be delivered normally from this step
|
|
@ -0,0 +1,2 @@
|
||||||
|
title: Homepage
|
||||||
|
---
|
|
@ -0,0 +1,3 @@
|
||||||
|
# Integrations with other frameworks
|
||||||
|
|
||||||
|
**Subspace** does not force you to change the architecture of your dApps, making it easy to use on existing projects. In this section you can find some examples and tips on how to integrate **Subspace** with various frontend frameworks and libraries
|
|
@ -0,0 +1,110 @@
|
||||||
|
# React
|
||||||
|
We provide a higher-order component to connect to enhance presentational components to react to any observable (not limited to those generated by **Subspace**).
|
||||||
|
|
||||||
|
### Usage
|
||||||
|
```js
|
||||||
|
import { observe } from '@embarklabs/subspace/react';
|
||||||
|
|
||||||
|
const ObserverComponent = observe(WrappedComponent);
|
||||||
|
```
|
||||||
|
|
||||||
|
This enhanced component will subscribe to any observable property it receives when the component is mounted and automatically unsubscribe when the component is unmounted.
|
||||||
|
|
||||||
|
### Example
|
||||||
|
|
||||||
|
<div class="c-notification">
|
||||||
|
This example is available in [Github](https://github.com/embark-framework/subspace/tree/master/examples/react-example1)
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
#### MyComponentObserver.js
|
||||||
|
```js
|
||||||
|
import React from "react";
|
||||||
|
import ReactDOM from 'react-dom';
|
||||||
|
import {observe} from "@embarklabs/subspace/react";
|
||||||
|
|
||||||
|
const MyComponent = ({eventData}) => {
|
||||||
|
// Handle initial state when no data is available
|
||||||
|
if (!eventData) {
|
||||||
|
return <p>No data</p>;
|
||||||
|
}
|
||||||
|
|
||||||
|
return <p>{eventData.someReturnedValue}</p>
|
||||||
|
};
|
||||||
|
|
||||||
|
// MyComponent will now observe any observable prop it receives
|
||||||
|
// and update its state whenever the observable emits an event
|
||||||
|
export default observe(MyComponent);
|
||||||
|
```
|
||||||
|
|
||||||
|
#### App.js
|
||||||
|
```js
|
||||||
|
import React, {Component} from 'react';
|
||||||
|
import ReactDOM from 'react-dom';
|
||||||
|
import Subspace from '@embarklabs/subspace';
|
||||||
|
|
||||||
|
import MyComponentObserver from './MyComponentObserver';
|
||||||
|
|
||||||
|
class App extends Component {
|
||||||
|
state = {
|
||||||
|
myEventObservable$: null
|
||||||
|
}
|
||||||
|
|
||||||
|
async componentDidMount() {
|
||||||
|
const MyContractInstance = ...; // TODO: obtain a web3.eth.contract instance
|
||||||
|
|
||||||
|
const subspace = new Subspace("wss://localhost:8545"); // Use a valid provider (geth, parity, infura...)
|
||||||
|
await subspace.init()
|
||||||
|
|
||||||
|
const myEventObservable$ = subspace.trackEvent(MyContractInstance, "MyEvent", {filter: {}, fromBlock: 1 });
|
||||||
|
this.setState({ myEventObservable$ });
|
||||||
|
}
|
||||||
|
|
||||||
|
render() {
|
||||||
|
return <MyComponentObserver eventData={this.state.myEventObservable$} />;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default App;
|
||||||
|
```
|
||||||
|
|
||||||
|
<div class="c-notification c-notification--warning">
|
||||||
|
Handling Contract Objects
|
||||||
|
The variable `MyContractInstance` is a `web3.eth.Contract` object pointing to a deployed contract address. You can use a DApp framework like [Embark](https://embark.status.im/docs/contracts_javascript.html) to easily import that contract instance: `import { MyContract } from './embarkArtifacts/contracts';`, or use web3.js directly (just like in the example [source code](https://github.com/embarklabs/subspace/blob/master/examples/react/src/MyContract.js#L36-L42))
|
||||||
|
</div>
|
||||||
|
|
||||||
|
#### index.js
|
||||||
|
```js
|
||||||
|
import React from 'react';
|
||||||
|
import ReactDOM from 'react-dom';
|
||||||
|
import App from './App';
|
||||||
|
|
||||||
|
ReactDOM.render(<App />, document.getElementById('root'));
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
```js
|
||||||
|
import { observe } from "@embarklabs/subspace/react";
|
||||||
|
|
||||||
|
const ProductComponent = ({ maxRating, minRating, averageRating }) => {
|
||||||
|
return <ul>
|
||||||
|
<li><b>minimum rating: </b> {minRating}</li>
|
||||||
|
<li><b>maximum rating: </b> {maxRating}</li>
|
||||||
|
<li><b>average rating: </b> {averageRating}</li>
|
||||||
|
</ul>;
|
||||||
|
};
|
||||||
|
|
||||||
|
const ReactiveProductComponent = observe(ProductComponent);
|
||||||
|
|
||||||
|
const Product = subspace.contract({abi, address});
|
||||||
|
const rating$ = Product.events.Rating.track().map("rating").pipe(map(x => parseInt(x)));
|
||||||
|
|
||||||
|
ReactDOM.render(
|
||||||
|
<ReactiveProductComponent
|
||||||
|
maxRating={rating$.pipe($max())}
|
||||||
|
minRating={rating$.pipe($min())}
|
||||||
|
averageRating={rating$.pipe($average())}
|
||||||
|
/>,
|
||||||
|
document.getElementById('hello-example')
|
||||||
|
);
|
||||||
|
```
|
|
@ -0,0 +1,63 @@
|
||||||
|
# reactive-graphql
|
||||||
|
|
||||||
|
Using `reactive-graphql` you can execute GraphQL queries against **Subspace** observables after you create your own type definitions and resolvers.
|
||||||
|
|
||||||
|
### Example
|
||||||
|
|
||||||
|
|
||||||
|
```js
|
||||||
|
const Subspace = require('@embarklabs/subspace');
|
||||||
|
const MyContract = require('./MyContract');
|
||||||
|
const { pluck } = require('rxjs/operators');
|
||||||
|
const { makeExecutableSchema } = require("graphql-tools");
|
||||||
|
const gql = require("graphql-tag");
|
||||||
|
const { graphql } = require("reactive-graphql");
|
||||||
|
|
||||||
|
const run = async () => {
|
||||||
|
const subspace = new Subspace(web3.currentProvider); // Use a valid provider (geth, parity, infura...)
|
||||||
|
await subspace.init();
|
||||||
|
|
||||||
|
const MyContractInstance = ...; // TODO: obtain a web3.eth.contract instance
|
||||||
|
|
||||||
|
const typeDefs = `
|
||||||
|
type MyEvent {
|
||||||
|
someValue: Int
|
||||||
|
anotherValue: String
|
||||||
|
}
|
||||||
|
type Query {
|
||||||
|
myEvents: MyEvent!
|
||||||
|
}
|
||||||
|
`;
|
||||||
|
|
||||||
|
const resolvers = {
|
||||||
|
Query: {
|
||||||
|
myEvents: () => {
|
||||||
|
return subspace.trackEvent(MyContractInstance, 'MyEvent', { filter: {}, fromBlock: 1 })
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const schema = makeExecutableSchema({ typeDefs, resolvers });
|
||||||
|
|
||||||
|
const query = gql`
|
||||||
|
query {
|
||||||
|
myEvents {
|
||||||
|
someValue
|
||||||
|
anotherValue
|
||||||
|
}
|
||||||
|
}
|
||||||
|
`;
|
||||||
|
|
||||||
|
const stream = graphql(schema, query).pipe(pluck('data', 'myEvents'));
|
||||||
|
stream.subscribe(data => {
|
||||||
|
console.log(data);
|
||||||
|
})
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
run();
|
||||||
|
```
|
||||||
|
|
||||||
|
<div class="c-notification">
|
||||||
|
This example is available in [Github](https://github.com/embarklabs/subspace/tree/master/examples/reactive-graphql)
|
||||||
|
</div>
|
|
@ -0,0 +1,20 @@
|
||||||
|
---
|
||||||
|
home: true
|
||||||
|
heroImage: /assets/img/logo.svg
|
||||||
|
heroText: " "
|
||||||
|
actionText: Get Started
|
||||||
|
actionLink: /getting-started/
|
||||||
|
footer: MIT Licensed | Subspace is part of the Status Network
|
||||||
|
features:
|
||||||
|
- title: Automatic Syncing
|
||||||
|
details: Subspace takes care of syncing under the hood, syncing exactly what you need when you need it. It saves the state to a local database ensuring the DApp always syncs from the last known point even after reloading the DApp.
|
||||||
|
- title: Reactive
|
||||||
|
details: Subspace embraces reactive programming with RxJS. It provides methods to track and subscribe to events, contract state & balances, and react to changes via observables.
|
||||||
|
- title: Framework Agnostic
|
||||||
|
details: Subspace is framework agnostic and integrates well with your favourite frameworks, from React to Angular. It works in the browser and in nodejs.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
<code1/>
|
|
@ -0,0 +1,33 @@
|
||||||
|
# redux-observable
|
||||||
|
|
||||||
|
[redux-observables](https://redux-observable.js.org/) can be used to manage side effects via `Epics` (their core primitive to receive and create stream of actions). **Subspace** can be configured inside these epics.
|
||||||
|
|
||||||
|
It's recommended to compose these epics by using [mergeMap](https://www.learnrxjs.io/operators/transformation/mergemap.html) or [switchMap](https://www.learnrxjs.io/operators/transformation/switchmap.html) operators.
|
||||||
|
|
||||||
|
Here's an example on how to use **Subspace** to subscribe to an Event when the action `SOME_ACTION` is dispatched, and then it will trigger `myAction` when the observable emits a value.
|
||||||
|
|
||||||
|
```js
|
||||||
|
// ...
|
||||||
|
|
||||||
|
const myEpic = action$ =>
|
||||||
|
action$.pipe(
|
||||||
|
ofType("SOME_ACTION"), // Execute when the action type is 'INIT'
|
||||||
|
switchMap(action =>
|
||||||
|
subspace
|
||||||
|
.trackEvent(MyContract, "MyEventName", { filter: {}, fromBlock: 1})
|
||||||
|
.pipe(
|
||||||
|
map(myAction) // Trigger redux action: MY_ACTION with the eventData
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
// ...
|
||||||
|
```
|
||||||
|
|
||||||
|
<div class="c-notification">
|
||||||
|
An example is available in [Github](https://github.com/embarklabs/subspace/tree/master/examples/redux-observable)
|
||||||
|
</div>
|
||||||
|
|
||||||
|
#### Further read
|
||||||
|
- [Epics](https://redux-observable.js.org/docs/basics/Epics.html)
|
||||||
|
|
|
@ -0,0 +1,78 @@
|
||||||
|
# redux
|
||||||
|
|
||||||
|
**Subspace** can be used with [redux](https://redux.js.org/). **Subspace** returns [`Observables`](https://rxjs-dev.firebaseapp.com/guide/observable), which you can subscribe to, and if this subscription has access to the redux store, it will be able to dispatch actions when the observable emits an event.
|
||||||
|
|
||||||
|
### Example
|
||||||
|
Here's a simple example on how to setup **Subspace** to work with `redux`:
|
||||||
|
|
||||||
|
<div class="c-notification">
|
||||||
|
This example is available in [Github](https://github.com/embarklabs/subspace/tree/master/examples/redux)
|
||||||
|
</div>
|
||||||
|
|
||||||
|
#### index.js
|
||||||
|
```js
|
||||||
|
import store from './store';
|
||||||
|
import web3 from './web3';
|
||||||
|
import Subspace from '@embarklabs/subspace';
|
||||||
|
import { myAction } from './actions';
|
||||||
|
|
||||||
|
const run = async () => {
|
||||||
|
const MyContractInstance = ...; // TODO: obtain a web3.eth.contract instance
|
||||||
|
|
||||||
|
const subspace = new Subspace("ws://localhost:8545"); // Use a valid provider (geth, parity, infura...)
|
||||||
|
await subspace.init();
|
||||||
|
|
||||||
|
subspace.trackEvent(MyContractInstance, "MyEvent", {filter: {}, fromBlock: 1 })
|
||||||
|
.subscribe(eventData => {
|
||||||
|
store.dispatch(myAction(eventData));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
run();
|
||||||
|
```
|
||||||
|
<div class="c-notification c-notification--warning">Handling Contract Objects
|
||||||
|
The variable `MyContractInstance` is a `web3.eth.Contract` object pointing to a deployed contract address. You can use a DApp framework like [Embark](https://embark.status.im/docs/contracts_javascript.html) to easily import that contract instance: `import { MyContract } from './embarkArtifacts/contracts';`, or use web3.js directly (just like in the example [source code](https://github.com/embarklabs/subspace/blob/master/examples/redux/src/MyContract.js#L36-L42))
|
||||||
|
</div>
|
||||||
|
|
||||||
|
#### store.js
|
||||||
|
```js
|
||||||
|
import { createStore } from 'redux';
|
||||||
|
import {myReducer} from './reducer';
|
||||||
|
|
||||||
|
export default store = createStore(myReducer);
|
||||||
|
```
|
||||||
|
|
||||||
|
#### reducer.js
|
||||||
|
```js
|
||||||
|
import { MY_ACTION } from "./constants";
|
||||||
|
|
||||||
|
const initialState = {
|
||||||
|
data: {}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const myReducer = (state = initialState, action) => {
|
||||||
|
switch (action.type) {
|
||||||
|
case MY_ACTION:
|
||||||
|
return { data: action.eventData };
|
||||||
|
default:
|
||||||
|
return state;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
```
|
||||||
|
|
||||||
|
#### constants.js
|
||||||
|
```js
|
||||||
|
export const MY_ACTION = 'MY_ACTION';
|
||||||
|
```
|
||||||
|
|
||||||
|
#### actions.js
|
||||||
|
```js
|
||||||
|
import {MY_ACTION} from './constants.js';
|
||||||
|
|
||||||
|
export const myAction = eventData => ({type: MY_ACTION, eventData});
|
||||||
|
```
|
||||||
|
|
||||||
|
<div class="c-notification">
|
||||||
|
Using React and Redux
|
||||||
|
A practical example can also be found in `examples/react-redux`.
|
||||||
|
</div>
|