Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Angular 13 example for Relay #515

Closed
wants to merge 28 commits into from
Closed
Show file tree
Hide file tree
Changes from 13 commits
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
de2b687
initial commit of basic angular app
jemboh Feb 7, 2022
60725d8
adding angular cache folder to gitignore
jemboh Feb 7, 2022
57ccd2d
added messages component to display messages
jemboh Feb 7, 2022
37abcc8
Added libraries needed to run js-waku and js-waku itself
jemboh Feb 8, 2022
15ae29b
Configured CommonJS dependencies to stop warnings
jemboh Feb 8, 2022
4100785
Added paths to crypto and stream libraries so TS can find them
jemboh Feb 8, 2022
a277388
[wip] Adding types for 'time-cache' library
jemboh Feb 8, 2022
2c946f9
Adding polyfills for 'process' and 'global'
jemboh Feb 8, 2022
288a27e
pointing to local build on js-waku rather than packaged
jemboh Feb 10, 2022
fccae93
buffer polyfills
jemboh Feb 10, 2022
e54220c
added protons type module
jemboh Feb 10, 2022
a860ff3
[wip] removed message service for now
jemboh Feb 10, 2022
6de338c
Angular (12) example of send/receive with waku relay
jemboh Feb 10, 2022
86b1bf2
adding protons and removing npm
jemboh Feb 15, 2022
f1def36
message html formatting
jemboh Feb 15, 2022
7e0f29f
implemented message interface
jemboh Feb 15, 2022
9b62c9e
prepended waku namespace for npmjs
jemboh Feb 15, 2022
95804ff
updated ts target due to BigInt usage
jemboh Feb 15, 2022
8d79ad0
Told typescript that waku object really is a type of Waku!
jemboh Feb 15, 2022
4ed9724
updated readme
jemboh Feb 15, 2022
9d5e572
updated wakuconnect url
jemboh Feb 15, 2022
35306e8
delete relay observer on component destruction
jemboh Feb 15, 2022
ecadaeb
Add relay-angular-chat to example CI
D4nte Feb 16, 2022
842308b
added bl types to the root for angular example
jemboh Feb 16, 2022
fa93ffb
removed gitignore entry for yarn lock files
jemboh Feb 16, 2022
9a4549f
adding yarn lockfile
jemboh Feb 16, 2022
684fdd3
shortened yarn command
jemboh Feb 16, 2022
024fa1a
destroy component on page reload
jemboh Feb 16, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
.idea/*
.nyc_output
.angular
build
node_modules
src/**.js
Expand Down
27 changes: 27 additions & 0 deletions examples/relay-angular-chat/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
# RelayAngularChat

This project was generated with [Angular CLI](https://github.com/angular/angular-cli) version 13.2.2.

## Development server

Run `ng serve` for a dev server. Navigate to `http://localhost:4200/`. The app will automatically reload if you change any of the source files.
jemboh marked this conversation as resolved.
Show resolved Hide resolved

## Code scaffolding

Run `ng generate component component-name` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module`.

## Build

Run `ng build` to build the project. The build artifacts will be stored in the `dist/` directory.

## Running unit tests

Run `ng test` to execute the unit tests via [Karma](https://karma-runner.github.io).

## Running end-to-end tests

Run `ng e2e` to execute the end-to-end tests via a platform of your choice. To use this command, you need to first add a package that implements end-to-end testing capabilities.

## Further help

To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.io/cli) page.
129 changes: 129 additions & 0 deletions examples/relay-angular-chat/angular.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,129 @@
{
"$schema": "./node_modules/@angular/cli/lib/config/schema.json",
"version": 1,
"newProjectRoot": "projects",
"projects": {
"relay-angular-chat": {
"projectType": "application",
"schematics": {
"@schematics/angular:application": {
"strict": true
}
},
"root": "",
"sourceRoot": "src",
"prefix": "app",
"architect": {
"build": {
"builder": "@angular-devkit/build-angular:browser",
"options": {
"outputPath": "dist/relay-angular-chat",
"index": "src/index.html",
"main": "src/main.ts",
"polyfills": "src/polyfills.ts",
"tsConfig": "tsconfig.app.json",
"assets": [
"src/favicon.ico",
"src/assets"
],
"styles": [
"src/styles.css"
],
"scripts": [],
"allowedCommonJsDependencies": [
"libp2p-gossipsub/src/utils",
"rlp",
"multiaddr/src/convert",
"varint",
"multihashes",
"@chainsafe/libp2p-noise/dist/src/noise",
"debug",
"libp2p",
"libp2p-bootstrap",
"libp2p-crypto",
"libp2p-websockets",
"libp2p-websockets/src/filters",
"libp2p/src/ping",
"multiaddr",
"peer-id",
"buffer",
"crypto",
"ecies-geth",
"secp256k1",
"libp2p-gossipsub",
"it-concat"
]
},
"configurations": {
"production": {
"budgets": [
{
"type": "initial",
"maximumWarning": "500kb",
"maximumError": "1mb"
},
{
"type": "anyComponentStyle",
"maximumWarning": "2kb",
"maximumError": "4kb"
}
],
"fileReplacements": [
{
"replace": "src/environments/environment.ts",
"with": "src/environments/environment.prod.ts"
}
],
"outputHashing": "all"
},
"development": {
"buildOptimizer": false,
"optimization": false,
"vendorChunk": true,
"extractLicenses": false,
"sourceMap": true,
"namedChunks": true
}
},
"defaultConfiguration": "production"
},
"serve": {
"builder": "@angular-devkit/build-angular:dev-server",
"configurations": {
"production": {
"browserTarget": "relay-angular-chat:build:production"
},
"development": {
"browserTarget": "relay-angular-chat:build:development"
}
},
"defaultConfiguration": "development"
},
"extract-i18n": {
"builder": "@angular-devkit/build-angular:extract-i18n",
"options": {
"browserTarget": "relay-angular-chat:build"
}
},
"test": {
"builder": "@angular-devkit/build-angular:karma",
"options": {
"main": "src/test.ts",
"polyfills": "src/polyfills.ts",
"tsConfig": "tsconfig.spec.json",
"karmaConfig": "karma.conf.js",
"assets": [
"src/favicon.ico",
"src/assets"
],
"styles": [
"src/styles.css"
],
"scripts": []
}
}
}
}
},
"defaultProject": "relay-angular-chat"
}
44 changes: 44 additions & 0 deletions examples/relay-angular-chat/karma.conf.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
// Karma configuration file, see link for more information
// https://karma-runner.github.io/1.0/config/configuration-file.html

module.exports = function (config) {
config.set({
basePath: '',
frameworks: ['jasmine', '@angular-devkit/build-angular'],
plugins: [
require('karma-jasmine'),
require('karma-chrome-launcher'),
require('karma-jasmine-html-reporter'),
require('karma-coverage'),
require('@angular-devkit/build-angular/plugins/karma')
],
client: {
jasmine: {
// you can add configuration options for Jasmine here
// the possible options are listed at https://jasmine.github.io/api/edge/Configuration.html
// for example, you can disable the random execution with `random: false`
// or set a specific seed with `seed: 4321`
},
clearContext: false // leave Jasmine Spec Runner output visible in browser
},
jasmineHtmlReporter: {
suppressAll: true // removes the duplicated traces
},
coverageReporter: {
dir: require('path').join(__dirname, './coverage/relay-angular-chat'),
subdir: '.',
reporters: [
{ type: 'html' },
{ type: 'text-summary' }
]
},
reporters: ['progress', 'kjhtml'],
port: 9876,
colors: true,
logLevel: config.LOG_INFO,
autoWatch: true,
browsers: ['Chrome'],
singleRun: false,
restartOnFileChange: true
});
};
Loading