diff --git a/.htmlhintrc b/.htmlhintrc new file mode 100644 index 0000000000000000000000000000000000000000..19115c1c25ab059dee0544148e5b8d088533ce9b --- /dev/null +++ b/.htmlhintrc @@ -0,0 +1,12 @@ +{ + "doctype-first": false, + "tagname-lowercase": true, + "attr-lowercase": false, + "attr-value-double-quotes": true, + "inline-style-disabled": true, + "inline-script-disabled": true, + "space-tab-mixed-disabled": true, + "style-disabled": true, + "attr-no-duplication": true, + "tagname-lowercase": true +} diff --git a/package-lock.json b/package-lock.json index 84760f2dce6660614a256752110dc959a0f931bd..01035eb0c17eee0b373b49a5e84b0fee8bd358fc 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1248,6 +1248,32 @@ "to-fast-properties": "^2.0.0" } }, + "@fortawesome/angular-fontawesome": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/@fortawesome/angular-fontawesome/-/angular-fontawesome-0.6.1.tgz", + "integrity": "sha512-ARQjtRuT+ZskzJDJKPwuiGO3+7nS0iyNLU/uHVJHfG4LwGJxwVIGldwg1SU957sra0Z0OtWEajHMhiS4vB9LwQ==" + }, + "@fortawesome/fontawesome-common-types": { + "version": "0.2.28", + "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-common-types/-/fontawesome-common-types-0.2.28.tgz", + "integrity": "sha512-gtis2/5yLdfI6n0ia0jH7NJs5i/Z/8M/ZbQL6jXQhCthEOe5Cr5NcQPhgTvFxNOtURE03/ZqUcEskdn2M+QaBg==" + }, + "@fortawesome/fontawesome-svg-core": { + "version": "1.2.28", + "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-svg-core/-/fontawesome-svg-core-1.2.28.tgz", + "integrity": "sha512-4LeaNHWvrneoU0i8b5RTOJHKx7E+y7jYejplR7uSVB34+mp3Veg7cbKk7NBCLiI4TyoWS1wh9ZdoyLJR8wSAdg==", + "requires": { + "@fortawesome/fontawesome-common-types": "^0.2.28" + } + }, + "@fortawesome/free-solid-svg-icons": { + "version": "5.13.0", + "resolved": "https://registry.npmjs.org/@fortawesome/free-solid-svg-icons/-/free-solid-svg-icons-5.13.0.tgz", + "integrity": "sha512-IHUgDJdomv6YtG4p3zl1B5wWf9ffinHIvebqQOmV3U+3SLw4fC+LUCCgwfETkbTtjy5/Qws2VoVf6z/ETQpFpg==", + "requires": { + "@fortawesome/fontawesome-common-types": "^0.2.28" + } + }, "@istanbuljs/schema": { "version": "0.1.2", "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.2.tgz", @@ -2671,6 +2697,17 @@ "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", "dev": true }, + "cli": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/cli/-/cli-1.0.1.tgz", + "integrity": "sha1-IoF1NPJL+klQw01TLUjsvGIbjBQ=", + "dev": true, + "optional": true, + "requires": { + "exit": "0.1.2", + "glob": "^7.1.1" + } + }, "cli-cursor": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", @@ -3403,6 +3440,17 @@ "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==", "dev": true }, + "csslint": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/csslint/-/csslint-1.0.5.tgz", + "integrity": "sha1-Gcw+2jIhYP0/cjKvHLKjYOiYouk=", + "dev": true, + "optional": true, + "requires": { + "clone": "~2.1.0", + "parserlib": "~1.1.1" + } + }, "cssnano": { "version": "4.1.10", "resolved": "https://registry.npmjs.org/cssnano/-/cssnano-4.1.10.tgz", @@ -3546,6 +3594,13 @@ "integrity": "sha512-bYQuGLeFxhkxNOF3rcMtiZxvCBAquGzZm6oWA1oZ0g2THUzivaRhv8uOhdr19LmoobSOLoIAxeUK2RdbM8IFTA==", "dev": true }, + "date-now": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/date-now/-/date-now-0.1.4.tgz", + "integrity": "sha1-6vQ5/U1ISK105cx9vvIAZyueNFs=", + "dev": true, + "optional": true + }, "debug": { "version": "4.1.1", "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", @@ -3875,6 +3930,16 @@ "integrity": "sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==", "dev": true }, + "domhandler": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-2.3.0.tgz", + "integrity": "sha1-LeWaCCLVAn+r/28DLCsloqir5zg=", + "dev": true, + "optional": true, + "requires": { + "domelementtype": "1" + } + }, "domutils": { "version": "1.7.0", "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.7.0.tgz", @@ -4915,6 +4980,42 @@ "path-is-absolute": "^1.0.0" } }, + "glob-base": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", + "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", + "dev": true, + "requires": { + "glob-parent": "^2.0.0", + "is-glob": "^2.0.0" + }, + "dependencies": { + "glob-parent": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", + "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", + "dev": true, + "requires": { + "is-glob": "^2.0.0" + } + }, + "is-extglob": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", + "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", + "dev": true + }, + "is-glob": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", + "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", + "dev": true, + "requires": { + "is-extglob": "^1.0.0" + } + } + } + }, "glob-parent": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", @@ -5190,6 +5291,167 @@ "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", "dev": true }, + "htmlhint": { + "version": "0.11.0", + "resolved": "https://registry.npmjs.org/htmlhint/-/htmlhint-0.11.0.tgz", + "integrity": "sha512-uXuRyVhQa0HlNmZg5LJ1BRJvRq5f7IJL/34tItHhZr9re15pwaqAuLUAIcqtwd1bLUCE++7HVPtR+NSReFW0iA==", + "dev": true, + "requires": { + "async": "2.6.1", + "colors": "1.3.2", + "commander": "2.17.1", + "csslint": "^1.0.5", + "glob": "7.1.3", + "jshint": "^2.9.6", + "parse-glob": "3.0.4", + "path-parse": "1.0.6", + "request": "2.88.0", + "strip-json-comments": "2.0.1", + "xml": "1.0.1" + }, + "dependencies": { + "async": { + "version": "2.6.1", + "resolved": "https://registry.npmjs.org/async/-/async-2.6.1.tgz", + "integrity": "sha512-fNEiL2+AZt6AlAw/29Cr0UDe4sRAHCpEHh54WMz+Bb7QfNcFw4h3loofyJpLeQs4Yx7yuqu/2dLgM5hKOs6HlQ==", + "dev": true, + "requires": { + "lodash": "^4.17.10" + } + }, + "colors": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/colors/-/colors-1.3.2.tgz", + "integrity": "sha512-rhP0JSBGYvpcNQj4s5AdShMeE5ahMop96cTeDl/v9qQQm2fYClE2QXZRi8wLzc+GmXSxdIqqbOIAhyObEXDbfQ==", + "dev": true + }, + "commander": { + "version": "2.17.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.17.1.tgz", + "integrity": "sha512-wPMUt6FnH2yzG95SA6mzjQOEKUU3aLaDEmzs1ti+1E9h+CsrZghRlqEM/EJ4KscsQVG8uNN4uVreUeT8+drlgg==", + "dev": true + }, + "glob": { + "version": "7.1.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", + "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", + "dev": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "punycode": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", + "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", + "dev": true + }, + "request": { + "version": "2.88.0", + "resolved": "https://registry.npmjs.org/request/-/request-2.88.0.tgz", + "integrity": "sha512-NAqBSrijGLZdM0WZNsInLJpkJokL72XYjUpnB0iwsRgxh7dB6COrHnTBNwN0E+lHDAJzu7kLAkDeY08z2/A0hg==", + "dev": true, + "requires": { + "aws-sign2": "~0.7.0", + "aws4": "^1.8.0", + "caseless": "~0.12.0", + "combined-stream": "~1.0.6", + "extend": "~3.0.2", + "forever-agent": "~0.6.1", + "form-data": "~2.3.2", + "har-validator": "~5.1.0", + "http-signature": "~1.2.0", + "is-typedarray": "~1.0.0", + "isstream": "~0.1.2", + "json-stringify-safe": "~5.0.1", + "mime-types": "~2.1.19", + "oauth-sign": "~0.9.0", + "performance-now": "^2.1.0", + "qs": "~6.5.2", + "safe-buffer": "^5.1.2", + "tough-cookie": "~2.4.3", + "tunnel-agent": "^0.6.0", + "uuid": "^3.3.2" + } + }, + "tough-cookie": { + "version": "2.4.3", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz", + "integrity": "sha512-Q5srk/4vDM54WJsJio3XNn6K2sCG+CQ8G5Wz6bZhRZoAe/+TxjWB/GlFAnYEbkYVlON9FMk/fE3h2RLpPXo4lQ==", + "dev": true, + "requires": { + "psl": "^1.1.24", + "punycode": "^1.4.1" + } + } + } + }, + "htmlparser2": { + "version": "3.8.3", + "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-3.8.3.tgz", + "integrity": "sha1-mWwosZFRaovoZQGn15dX5ccMEGg=", + "dev": true, + "optional": true, + "requires": { + "domelementtype": "1", + "domhandler": "2.3", + "domutils": "1.5", + "entities": "1.0", + "readable-stream": "1.1" + }, + "dependencies": { + "domutils": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.5.1.tgz", + "integrity": "sha1-3NhIiib1Y9YQeeSMn3t+Mjc2gs8=", + "dev": true, + "optional": true, + "requires": { + "dom-serializer": "0", + "domelementtype": "1" + } + }, + "entities": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-1.0.0.tgz", + "integrity": "sha1-sph6o4ITR/zeZCsk/fyeT7cSvyY=", + "dev": true, + "optional": true + }, + "isarray": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", + "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", + "dev": true, + "optional": true + }, + "readable-stream": { + "version": "1.1.14", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", + "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", + "dev": true, + "optional": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.1", + "isarray": "0.0.1", + "string_decoder": "~0.10.x" + } + }, + "string_decoder": { + "version": "0.10.31", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", + "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", + "dev": true, + "optional": true + } + } + }, "http-cache-semantics": { "version": "3.8.1", "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-3.8.1.tgz", @@ -5706,6 +5968,12 @@ "integrity": "sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE=", "dev": true }, + "is-dotfile": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz", + "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=", + "dev": true + }, "is-extendable": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", @@ -6128,6 +6396,42 @@ "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", "dev": true }, + "jshint": { + "version": "2.11.0", + "resolved": "https://registry.npmjs.org/jshint/-/jshint-2.11.0.tgz", + "integrity": "sha512-ooaD/hrBPhu35xXW4gn+o3SOuzht73gdBuffgJzrZBJZPGgGiiTvJEgTyxFvBO2nz0+X1G6etF8SzUODTlLY6Q==", + "dev": true, + "optional": true, + "requires": { + "cli": "~1.0.0", + "console-browserify": "1.1.x", + "exit": "0.1.x", + "htmlparser2": "3.8.x", + "lodash": "~4.17.11", + "minimatch": "~3.0.2", + "shelljs": "0.3.x", + "strip-json-comments": "1.0.x" + }, + "dependencies": { + "console-browserify": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/console-browserify/-/console-browserify-1.1.0.tgz", + "integrity": "sha1-8CQcRXMKn8YyOyBtvzjtx0HQuxA=", + "dev": true, + "optional": true, + "requires": { + "date-now": "^0.1.4" + } + }, + "strip-json-comments": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-1.0.4.tgz", + "integrity": "sha1-HhX7ysl9Pumb8tc7TGVrCCu6+5E=", + "dev": true, + "optional": true + } + } + }, "json-parse-better-errors": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", @@ -7807,6 +8111,35 @@ "safe-buffer": "^5.1.1" } }, + "parse-glob": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz", + "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=", + "dev": true, + "requires": { + "glob-base": "^0.3.0", + "is-dotfile": "^1.0.0", + "is-extglob": "^1.0.0", + "is-glob": "^2.0.0" + }, + "dependencies": { + "is-extglob": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", + "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", + "dev": true + }, + "is-glob": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", + "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", + "dev": true, + "requires": { + "is-extglob": "^1.0.0" + } + } + } + }, "parse-json": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", @@ -7832,6 +8165,13 @@ "better-assert": "~1.0.0" } }, + "parserlib": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/parserlib/-/parserlib-1.1.1.tgz", + "integrity": "sha1-pkz6ckBiQ0/fw1HJpOwtkrlMBvQ=", + "dev": true, + "optional": true + }, "parseuri": { "version": "0.0.5", "resolved": "https://registry.npmjs.org/parseuri/-/parseuri-0.0.5.tgz", @@ -9803,6 +10143,13 @@ "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", "dev": true }, + "shelljs": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/shelljs/-/shelljs-0.3.0.tgz", + "integrity": "sha1-NZbmMHp4FUT1kfN9phg2DzHbV7E=", + "dev": true, + "optional": true + }, "signal-exit": { "version": "3.0.3", "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz", @@ -10550,6 +10897,12 @@ "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=", "dev": true }, + "strip-json-comments": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", + "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", + "dev": true + }, "style-loader": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/style-loader/-/style-loader-1.0.0.tgz", @@ -13282,6 +13635,12 @@ "async-limiter": "~1.0.0" } }, + "xml": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/xml/-/xml-1.0.1.tgz", + "integrity": "sha1-eLpyAgApxbyHuKgaPPzXS0ovweU=", + "dev": true + }, "xml2js": { "version": "0.4.23", "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.4.23.tgz", diff --git a/package.json b/package.json index 82a91bc4cea86b9d15b31d704ddd0e84a7b68fa9..036558308792a258ebc54a8cd05cfd0c83f77005 100644 --- a/package.json +++ b/package.json @@ -6,7 +6,7 @@ "start": "ng serve", "build": "ng build", "test": "ng test", - "lint": "ng lint", + "lint": "ng lint && htmlhint", "e2e": "ng e2e" }, "private": true, @@ -19,6 +19,9 @@ "@angular/platform-browser": "~9.0.2", "@angular/platform-browser-dynamic": "~9.0.2", "@angular/router": "~9.0.2", + "@fortawesome/angular-fontawesome": "^0.6.1", + "@fortawesome/fontawesome-svg-core": "^1.2.28", + "@fortawesome/free-solid-svg-icons": "^5.13.0", "bulma": "^0.8.1", "python": "0.0.4", "python-shell": "^1.0.8", @@ -36,6 +39,7 @@ "@types/jasminewd2": "~2.0.3", "@types/node": "^12.12.32", "codelyzer": "^5.1.2", + "htmlhint": "^0.11.0", "jasmine-core": "~3.5.0", "jasmine-spec-reporter": "~4.2.1", "karma": "~4.3.0", diff --git a/src/app/app-routing.module.ts b/src/app/app-routing.module.ts index 06c734263e1716e120bbb2771845eca1ae74c055..a407a1a14f74ac657d9f4f02f089037999778af7 100644 --- a/src/app/app-routing.module.ts +++ b/src/app/app-routing.module.ts @@ -1,8 +1,16 @@ import { NgModule } from '@angular/core'; import { Routes, RouterModule } from '@angular/router'; +import {ExplorerPageComponent} from './pages/explorer-page/explorer-page.component'; +import {AboutPageComponent} from './pages/about-page/about-page.component'; +import {HomePageComponent} from './pages/home-page/home-page.component'; -const routes: Routes = []; +export const routes: Routes = [ + { path: '', component: HomePageComponent }, + { path: 'explorer', component: ExplorerPageComponent}, + { path: 'explorer/:proteinGroup', component: ExplorerPageComponent}, + { path: 'about', component: AboutPageComponent } +]; @NgModule({ imports: [RouterModule.forRoot(routes)], diff --git a/src/app/app.component.css b/src/app/app.component.css deleted file mode 100644 index b7ef084c563fcdce196a2076486d16c87ef19cbf..0000000000000000000000000000000000000000 --- a/src/app/app.component.css +++ /dev/null @@ -1,3 +0,0 @@ -p { - font-family: Lato; -} \ No newline at end of file diff --git a/src/app/app.component.html b/src/app/app.component.html index d6bbe573ea62de61c74d361bd4f32080bb51baf3..77a029646b99af4c2db67dd808eecdc979d5f760 100644 --- a/src/app/app.component.html +++ b/src/app/app.component.html @@ -1,29 +1,33 @@ -<nav class="navbar" role="navigation" aria-label="main navigation"> - <div class="navbar-brand"> - <a class="navbar-item" href="https://bulma.io"> - <img src="" height="28"> - </a> - - <a role="button" class="navbar-burger burger" aria-label="menu" aria-expanded="false"> - <span aria-hidden="true"></span> - <span aria-hidden="true"></span> - <span aria-hidden="true"></span> - </a> - </div> - - <div class="navbar-menu"> - <div class="navbar-start"> - <a class="navbar-item"> - Network +<div class="container is-fluid"> + <nav class="navbar" role="navigation" aria-label="main navigation"> + <div class="navbar-brand"> + <img src="assets/logo.png" class="menu-icon" alt="logo" width="50px"/> + <a role="button" class="navbar-burger burger" aria-label="menu" aria-expanded="false"> + <span aria-hidden="true"></span> + <span aria-hidden="true"></span> + <span aria-hidden="true"></span> </a> </div> - <div class="navbar-end"> - <a class="navbar-item"> - About - </a> + <div class="navbar-menu is-active"> + <div class="navbar-start"> + <a routerLink="/" routerLinkActive="is-active" class="navbar-item"> + <span class="icon"><i class="fa fa-home"></i></span> + <span>Home</span> + </a> + <a routerLink="/explorer" routerLinkActive="is-active" class="navbar-item"> + <span class="icon"><i class="fa fa-project-diagram"></i></span> + <span>Explorer</span> + </a> + <a routerLink="/about" routerLinkActive="is-active" class="navbar-item"> + <span class="icon"><i class="fa fa-question"></i></span> + <span>About</span> + </a> + </div> </div> - </div> -</nav> + </nav> +</div> -<router-outlet></router-outlet> +<main> + <router-outlet></router-outlet> +</main> diff --git a/src/app/app.component.scss b/src/app/app.component.scss index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..8b137891791fe96927ad78e64b0aad7bded08bdc 100644 --- a/src/app/app.component.scss +++ b/src/app/app.component.scss @@ -0,0 +1 @@ + diff --git a/src/app/app.module.ts b/src/app/app.module.ts index bf189ee6a5abcf6411e9988afea859b9357fab4e..3929e22a3cc505c855f89dd9636d02ea317b939a 100644 --- a/src/app/app.module.ts +++ b/src/app/app.module.ts @@ -1,30 +1,31 @@ import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; +import { CommonModule } from '@angular/common'; import { FormsModule } from '@angular/forms'; import { AppRoutingModule } from './app-routing.module'; import { AppComponent } from './app.component'; +import {ExplorerPageComponent} from './pages/explorer-page/explorer-page.component'; +import {AboutPageComponent} from './pages/about-page/about-page.component'; +import {HomePageComponent} from './pages/home-page/home-page.component'; - - -// @NgModule({ -// declarations: [ -// AppComponent -// ], -// imports: [ -// BrowserModule, -// AppRoutingModule -// ], -// providers: [], -// bootstrap: [AppComponent] -// }) -// export class AppModule { } - @NgModule({ - imports: [ BrowserModule, FormsModule, AppRoutingModule], - declarations: [ AppComponent ], - bootstrap: [ AppComponent ] + declarations: [ + AppComponent, + ExplorerPageComponent, + AboutPageComponent, + HomePageComponent + ], + imports: [ + BrowserModule, + AppRoutingModule, + FormsModule, + CommonModule + ], + providers: [], + bootstrap: [AppComponent] + }) export class AppModule { } diff --git a/src/app/pages/about-page/about-page.component.html b/src/app/pages/about-page/about-page.component.html new file mode 100644 index 0000000000000000000000000000000000000000..45094ab126acc03f58f9fb5790d98ac26065126d --- /dev/null +++ b/src/app/pages/about-page/about-page.component.html @@ -0,0 +1,4 @@ +<div class="content"> +Write information about the project and website here +</div> + diff --git a/src/app/pages/about-page/about-page.component.scss b/src/app/pages/about-page/about-page.component.scss new file mode 100644 index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 diff --git a/src/app/pages/about-page/about-page.component.ts b/src/app/pages/about-page/about-page.component.ts new file mode 100644 index 0000000000000000000000000000000000000000..c93a5e594bbffb94c24ebb2e9ad1fd8474b73fd9 --- /dev/null +++ b/src/app/pages/about-page/about-page.component.ts @@ -0,0 +1,15 @@ +import { Component, OnInit } from '@angular/core'; + +@Component({ + selector: 'app-about-page', + templateUrl: './about-page.component.html', + styleUrls: ['./about-page.component.scss'] +}) +export class AboutPageComponent implements OnInit { + + constructor() { } + + ngOnInit() { + } + +} diff --git a/src/app/pages/explorer-page/explorer-page.component.html b/src/app/pages/explorer-page/explorer-page.component.html new file mode 100644 index 0000000000000000000000000000000000000000..79847ed623d8ab3f30e5dbb914648628812a3e1f --- /dev/null +++ b/src/app/pages/explorer-page/explorer-page.component.html @@ -0,0 +1,136 @@ +<div class="content fullscreen"> + <div class="modal" [class.is-active]="showModal"> + <div class="modal-background"></div> + <div class="modal-card"> + <header class="modal-card-head"> + <p class="modal-card-title">{{groupId}}</p> + <button class="delete" aria-label="close" (click)="closeSummary()"></button> + </header> + <section class="modal-card-body"> + <h2>General Information</h2> + <ul> + <li><b>Protein Group:</b> {{proteinGroup}}</li> + <li><b>Gene Name(s):</b> <span *ngFor="let geneName of geneNames"> {{ geneName }}</span> + <li><b>Protein Name(s):</b> <span *ngFor="let proteinName of proteinNames"> {{ proteinName }}</span> + </li> + <li><b>Protein AC(s):</b> + <a href="https://www.uniprot.org/uniprot/{{proteinAC}}" target="_blank" + *ngFor="let proteinAC of proteinACs"> + {{ proteinAC }}<span><img class="inline" align="center" src="../assets/uniprot.png"></span> + </a> + </li> + <li><b>Number of Interactions:</b> {{numberOfInteractions}}</li> + </ul> + + <h2>Summary</h2> + <figure class="image" (click)="openSummary('A4435')"> + <img src="../assets/boxplot.png" alt="Boxplots"> + </figure> + </section> + + <footer class="modal-card-foot"> + <button class="button is-danger" (click)="closeSummary()">Close</button> + </footer> + </div> + </div> + + + <div class="content left-bar"> + + <div class="card left-bar-item"> + <header class="card-header"> + <p class="card-header-title"> + <span class="icon"> + <i class="fas fa-info" aria-hidden="true"></i> + </span> Info + </p> + </header> + <div class="card-content"> + <div class="content"> + Information about how to use the explorer + </div> + </div> + </div> + + <div class="card left-bar-item"> + <header class="card-header"> + <p class="card-header-title"> + <span class="icon"> + <i class="fas fa-search" aria-hidden="true"></i> + </span> Query Protein/Gene + </p> + </header> + <div class="card-content"> + <div class="content"> + <div class="field"> + <div class="control is-loading"> + <input class="input" type="text" placeholder="Search for Protein/Gene..."> + </div> + </div> + </div> + </div> + </div> + + <div class="card left-bar-item"> + <header class="card-header"> + <p class="card-header-title"> + <span class="icon"> + <i class="fas fa-filter" aria-hidden="true"></i> + </span> Filtering + </p> + </header> + <div class="card-content"> + <div class="content"> + <p><b>Baits</b></p> + <label class="checkbox" *ngFor="let baitName of baitNames"> + <input type="checkbox" class="checkbox"> + {{ baitName }} + </label> + </div> + </div> + <footer class="card-footer"> + <button class="card-footer-item button is-danger">Reset + </button> + </footer> + </div> + </div> + + <div class="card right-big" > + <header class="card-header"> + <p class="card-header-title"> + SARS-CoV-2 Protein-Protein Interaction Network + </p> + <a href="#" class="card-header-icon" aria-label="more options"> + <span class="icon"> + <i class="fas fa-sliders-h" aria-hidden="true"></i> + </span> + </a> + </header> + <div class="card-content"> + <div class="card-image"> + <figure class="image" (click)="openSummary('A4435')"> + <img src="assets/graph_example.png" alt="PPI Network" class="network"> + </figure> + </div> + <footer class="card-footer"> + <button class="card-footer-item button is-primary"> + <span class="icon"> + <i class="fas fa-cloud-download-alt" aria-hidden="true"></i> + </span> + </button> + <a class="card-footer-item"> + <span class="icon"> + <i class="fas fa-search-plus" aria-hidden="true"></i> + </span> + </a> + <a href="#" class="card-footer-item"> + <span class="icon"> + <i class="fas fa-search-minus" aria-hidden="true"></i> + </span> + </a> + </footer> + </div> + </div> +</div> + + diff --git a/src/app/pages/explorer-page/explorer-page.component.scss b/src/app/pages/explorer-page/explorer-page.component.scss new file mode 100644 index 0000000000000000000000000000000000000000..230c9db23bc69c20eda1da9a21c0b05c93ebbbdb --- /dev/null +++ b/src/app/pages/explorer-page/explorer-page.component.scss @@ -0,0 +1,9 @@ +.card { + height: 100%; + display:flex; + flex-direction: column; +} + +.card-block{ + height: 100%; +} diff --git a/src/app/pages/explorer-page/explorer-page.component.ts b/src/app/pages/explorer-page/explorer-page.component.ts new file mode 100644 index 0000000000000000000000000000000000000000..a16def7f2caa1fd8f8d35d039178fad0d69e1dc3 --- /dev/null +++ b/src/app/pages/explorer-page/explorer-page.component.ts @@ -0,0 +1,71 @@ +import {Component, OnInit} from '@angular/core'; +import {ActivatedRoute, Router} from '@angular/router'; + +@Component({ + selector: 'app-explorer-page', + templateUrl: './explorer-page.component.html', + styleUrls: ['./explorer-page.component.scss'], +}) +export class ExplorerPageComponent implements OnInit { + + public showModal = false; + public groupId = ''; + public geneNames: Array<string> = []; + public proteinGroup = ''; + public proteinNames: Array<string> = []; + public proteinACs: Array<string> = []; + public numberOfInteractions = 0; + public baitNames: Array<string> = []; + + constructor(private route: ActivatedRoute, private router: Router) { + + this.groupId = 'IFI16'; + this.geneNames.push('IFI16'); + this.proteinNames.push('Gamma-interface-inducible protein 16'); + this.proteinACs.push('Q16666'); + this.numberOfInteractions = 25; + this.baitNames.push('Bait Protein 1'); + this.baitNames.push('Bait Protein 2'); + this.baitNames.push('Bait Protein 3'); + this.baitNames.push('Bait Protein 4'); + this.baitNames.push('Bait Protein 5'); + + this.route.params.subscribe(async (params) => { + const proteinGroup = params.proteinGroup; + if (!proteinGroup) { + // In this case, the URL is just `/explorer` + // Therefore, we do not show a modal + this.showModal = false; + return; + } + + // In this case, the URL is `/explorer/<proteinGroup>` + + if (this.proteinGroup === proteinGroup) { + // The protein group is the same as before, so we do not need to do anything + return; + } + + // We have a new proteinGroup id, so we need to load it and show the modal... + + this.proteinGroup = proteinGroup; + + // TODO: Perform call here for 'proteinGroup'... + + this.showModal = true; + }); + } + + ngOnInit() { + + } + + public async openSummary(groupId: string) { + await this.router.navigate(['explorer', groupId]); + } + + public async closeSummary() { + await this.router.navigate(['explorer']); + } + +} diff --git a/src/app/pages/home-page/home-page.component.html b/src/app/pages/home-page/home-page.component.html new file mode 100644 index 0000000000000000000000000000000000000000..d0d4cd44afe8063d7785b8b4bbb2eddaee71b5aa --- /dev/null +++ b/src/app/pages/home-page/home-page.component.html @@ -0,0 +1,17 @@ +<section class="hero is-primary is-large"> + <div class="hero-body"> + <div class="container"> + <h1 class="title"> + SARS-CoV-2 Explorer + </h1> + <h2 class="subtitle"> + Explore the Protein interactions of SARS-CoV-2 + </h2> + </div> + </div> +</section> + +<div class="content"> +General Information about the Website +</div> + diff --git a/src/app/pages/home-page/home-page.component.scss b/src/app/pages/home-page/home-page.component.scss new file mode 100644 index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 diff --git a/src/app/pages/home-page/home-page.component.ts b/src/app/pages/home-page/home-page.component.ts new file mode 100644 index 0000000000000000000000000000000000000000..4f49595151dfc8f84a5391366a3ea01dc1b07e65 --- /dev/null +++ b/src/app/pages/home-page/home-page.component.ts @@ -0,0 +1,15 @@ +import { Component, OnInit } from '@angular/core'; + +@Component({ + selector: 'app-home-page', + templateUrl: './home-page.component.html', + styleUrls: ['./home-page.component.scss'] +}) +export class HomePageComponent implements OnInit { + + constructor() { } + + ngOnInit() { + } + +} diff --git a/src/assets/boxplot.png b/src/assets/boxplot.png new file mode 100644 index 0000000000000000000000000000000000000000..4e8eb829cd5c8581bca92b8ced95653e47b93a46 Binary files /dev/null and b/src/assets/boxplot.png differ diff --git a/src/assets/graph_example.png b/src/assets/graph_example.png new file mode 100644 index 0000000000000000000000000000000000000000..a7ed6b8a5ff329c8812c46fabaaf3d8e0a95970d Binary files /dev/null and b/src/assets/graph_example.png differ diff --git a/src/assets/logo.png b/src/assets/logo.png new file mode 100644 index 0000000000000000000000000000000000000000..066eb713ee455cebe340dc8504fe6fcf1bfad8d0 Binary files /dev/null and b/src/assets/logo.png differ diff --git a/src/assets/uniprot.png b/src/assets/uniprot.png new file mode 100644 index 0000000000000000000000000000000000000000..c2f607535a9d0f1e6cbe3a7e7d6388c14ac86282 Binary files /dev/null and b/src/assets/uniprot.png differ diff --git a/src/index.html b/src/index.html index 1eb0ed1f005def2751a3ac0fb4a4069d919443d0..82b85d025b288c79124f834415b62d664a6bc593 100644 --- a/src/index.html +++ b/src/index.html @@ -2,10 +2,10 @@ <html lang="en"> <head> <meta charset="utf-8"> - <title>Covid19</title> + <title>CovPPI</title> <base href="/"> <meta name="viewport" content="width=device-width, initial-scale=1"> - <link rel="icon" type="image/x-icon" href="favicon.ico"> + <link rel="icon" type="image/ico" href="../../assets/logo.png"> <script src="https://kit.fontawesome.com/3ad4fe992f.js" crossorigin="anonymous"></script> </head> <body> diff --git a/src/styles.scss b/src/styles.scss index 7d85f64db268396b259b1bf8cf1a6f1e1422b9d8..cb26458e9f9ffa624ee3e9d1b066af42fe8d5e7a 100644 --- a/src/styles.scss +++ b/src/styles.scss @@ -1,3 +1,92 @@ /* You can add global styles to this file, and also import other style files */ -@import '~bulma'; +@charset "utf-8"; + +@import url('https://fonts.googleapis.com/css?family=Varela+Round'); +$family-sans-serif: "Varela Round", sans-serif; +@import "~bulma/bulma.sass"; + +.hero.is-primary { + background-color: #118AB2; + background-image: url("assets/logo.png"), linear-gradient(to left, #f2fcfe, #118AB2); + background-repeat: no-repeat; + background-position: 80%; + padding: 50px; +} + +.button.is-primary, .button.is-primary:hover, .button.is-primary:disabled { + background-color: #118AB2; +} + +.button.is-danger, .button.is-danger:hover, .button.is-danger:disabled { + background-color: #EF476F; +} + +.button.is-success, .button.is-success:hover, .button.is-success:disabled { + background-color: #06D6A0; +} + +div.content { + margin: 30px; +} + +div.content.fullscreen { + margin: 20px; + height: calc(100vh - 120px); + width: 100%; +} + +div.navbar-menu { + margin-left: 5px; +} + +div.content.left-bar { + float: left; + width: 400px; +} + +div.card.left-bar-item { + margin-bottom: 30px; +} + +div.card.right-big { + float: right; + width: calc(100% - 460px); + height: calc(100vh - 105px); +} + +button.i { + margin-left: 5px; +} + +body { + height: 100%; +} + +img { + margin: 10px; +} + +span.icon { + margin-right: 5px; +} + +img.inline { + height: 30px; + margin-left: 0px; +} + +img.network { + height: calc(100vh - 270px); +} + +main { + height: calc(100vh - 500px); +} + +input.checkbox { + margin-left: 15px; +} + + +