Merge pull request #32 from the-superpirate/master

- feat(cognitron): Repair JS build …
This commit is contained in:
the-superpirate 2021-04-25 15:48:18 +03:00 committed by GitHub
commit f219c37b24
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
18 changed files with 65 additions and 212 deletions

View File

@ -26,8 +26,8 @@ http_archive(
http_archive(
name = "build_bazel_rules_nodejs",
sha256 = "1134ec9b7baee008f1d54f0483049a97e53a57cd3913ec9d6db625549c98395a",
urls = ["https://github.com/bazelbuild/rules_nodejs/releases/download/3.4.0/rules_nodejs-3.4.0.tar.gz"],
sha256 = "a160d9ac88f2aebda2aa995de3fa3171300c076f06ad1d7c2e1385728b8442fa",
urls = ["https://github.com/bazelbuild/rules_nodejs/releases/download/3.4.1/rules_nodejs-3.4.1.tar.gz"],
)
http_archive(

View File

@ -1,20 +1,22 @@
load("//rules/nodejs:common.bzl", "js_library")
load("@build_bazel_rules_nodejs//:index.bzl", "js_library")
js_library(
name = "base-client",
package_name = "base-client",
srcs = ["base-client.js"],
data = [
visibility = ["//visibility:public"],
deps = [
"//library/js:utils",
"@npm//axios",
],
visibility = ["//visibility:public"],
)
js_library(
name = "utils",
package_name = "utils",
srcs = ["utils.js"],
data = [
visibility = ["//visibility:public"],
deps = [
"@npm//lodash",
],
visibility = ["//visibility:public"],
)

View File

@ -1,4 +1,4 @@
import { removeUndefined, toCamel, toSnake } from '~/library/js/utils'
import { removeUndefined, toCamel, toSnake } from 'utils'
import Axios from 'axios'
export default class BaseClient {

View File

@ -1,7 +0,0 @@
load("//rules/nodejs:common.bzl", "js_library")
js_library(
name = "components",
srcs = glob(["**/*.vue"]),
visibility = ["//visibility:public"],
)

View File

@ -1,21 +0,0 @@
<template lang="pug">
b-container
b-modal(ref="newElementModal", :title="'New ' + typeName", @ok="handleAddElementOk", @cancel="handleAddElementCancel", @shown="$refs.newElement.focus()")
p.text-modal
b-form-input.form-control-sm(ref="newElement", v-model="newElement")
b-badge.ml-2(v-for="(element, elementIndex) of value", :key="elementIndex")
span {{ getDisplayName(element) }}
i.ml-1.fa.fa-sm.fa-remove(@click="deleteElement(elementIndex)", v-if="mutable")
b-badge.ml-2(@click="handleAddElementInit", variant="danger", v-if="mutable")
i.fa.fa-md.fa-plus
</template>
<script>
import BaseList from '~/library/js/components/BaseList'
export default {
name: 'BadgeList',
extends: BaseList
}
</script>

View File

@ -1,56 +0,0 @@
<script>
export default {
name: 'BaseList',
props: {
value: {
type: Array,
default: function () { return [] }
},
typeName: {
type: String,
default: 'element'
},
getDisplayName: {
type: Function,
default: function (x) {
return x
}
},
afterProcess: {
type: Function,
default: function (x) {
return x
}
},
mutable: {
type: Boolean,
default: true
}
},
data () {
return {
newElement: null
}
},
methods: {
handleAddElementInit () {
this.$refs.newElementModal.show()
},
handleAddElementOk () {
let processed = this.afterProcess(this.newElement)
this.value.push(processed)
this.$emit('added', processed)
this.newElement = null
},
handleAddElementCancel () {
this.newElement = null
},
deleteElement (elementIndex) {
let deleted = this.value[elementIndex]
this.value.splice(elementIndex, 1)
this.$emit('deleted', deleted)
}
}
}
</script>

View File

@ -1,21 +0,0 @@
<template lang="pug">
b-container
b-modal(ref="newElementModal", :title="'New ' + typeName", @ok="handleAddElementOk", @cancel="handleAddElementCancel", @shown="$refs.newElement.focus()")
p.text-modal
b-form-input.form-control-sm(ref="newElement", v-model="newElement")
div(v-for="(element, elementIndex) of value", :key="elementIndex")
span {{ getDisplayName(element) }}
i.ml-1.fa.fa-sm.fa-remove.float-right(@click="deleteElement(elementIndex)", v-if="mutable")
hr
b-button.btn-sm.float-right(@click="handleAddElementInit", variant="primary", v-if="mutable") Add
</template>
<script>
import BaseList from '~/library/js/components/BaseList'
export default {
name: 'CommonList',
extends: BaseList
}
</script>

View File

@ -1,45 +0,0 @@
<template lang="pug">
b-container(v-if="visible")
.loader
.message {{text}}
</template>
<script>
export default {
name: 'Loader',
props: {
text: {
type: String,
required: true
},
visible: {
type: Boolean,
required: true
}
}
}
</script>
<style lang="scss" scoped>
.loader {
width: 100%;
height: 100%;
position: fixed;
z-index: 100;
background-color: black;
opacity: 0.3;
top: 0;
left: 0;
}
.message {
padding: 50px 20px;
background: white;
width: 30%;
text-align: center;
position: fixed;
left: 35%;
top: 100px;
z-index: 1000;
font-size: 26px;
}
</style>

View File

@ -2,32 +2,29 @@
services:
nexus-cognitron-web:
depends_on:
- summa
- nexus-meta-api-envoy
environment:
ENV_TYPE: production
NEXUS_COGNITRON_WEB_ipfs.gateway.url: https://cloudflare-ipfs.com
NEXUS_COGNITRON_WEB_meta_api.url: http://nexus-meta-api:8080
NEXUS_COGNITRON_WEB_meta_api.url: http://localhost:8080
image: thesuperpirate/cognitron-web:latest
ports:
- '3000:80'
- '3000:3000'
nexus-meta-api:
depends_on:
- summa
environment:
ENV_TYPE: development
ENV_TYPE: production
NEXUS_META_API_grpc.address: '0.0.0.0'
NEXUS_META_API_grpc.port: 9090
NEXUS_META_API_summa.url: 'http://summa:8082'
image: thesuperpirate/meta-api:latest
ports:
- '9090:9090'
nexus-meta-api-envoy:
depends_on:
- nexus-meta-api
image: envoyproxy/envoy-dev:latest
ports:
- '8080:8080'
- '9901:9901'
volumes:
- './nexus-meta-api-envoy.yaml:/etc/envoy/envoy.yaml'
summa:
@ -37,8 +34,6 @@ services:
SUMMA_http.address: '0.0.0.0'
SUMMA_http.port: '8082'
image: izihawa/summa:latest
ports:
- '8082:8082'
volumes:
- '${DATA_PATH}:/summa/data'
version: "3"

View File

@ -1,7 +1,18 @@
load("@build_bazel_rules_nodejs//:index.bzl", "js_library")
load("@io_bazel_rules_docker//container:container.bzl", "container_push")
load("@io_bazel_rules_docker//nodejs:image.bzl", "nodejs_image")
load("@npm//nuxt:index.bzl", "nuxt")
load("//rules/nodejs:common.bzl", "js_library")
files = ["nuxt.config.js"] + glob([
"assets/**",
"components/**/*.vue",
"layouts/*.vue",
"middleware/*.js",
"pages/**/*.vue",
"plugins/*.js",
"static/*",
"store/*.js",
])
deps = [
"@npm//@nuxtjs/axios",
@ -18,27 +29,20 @@ deps = [
]
js_library(
name = "nuxt-srcs",
srcs = ["nuxt.config.js"] + glob([
"assets/**",
"components/**/*.vue",
"layouts/*.vue",
"middleware/*.js",
"pages/**/*.vue",
"plugins/*.js",
"static/*",
"store/*.js",
]),
name = "nexus-cognitron-web",
package_name = "nexus-cognitron-web",
srcs = files,
deps = deps,
)
nuxt(
name = "web_dev",
name = "web-dev",
args = [
"-c",
"nexus/cognitron/web/nuxt.config.js",
"--watch-poll",
],
data = [":nuxt-srcs"] + deps,
data = [":nexus-cognitron-web"],
)
nuxt(
@ -50,7 +54,8 @@ nuxt(
"nexus/cognitron/web/nuxt.config.js",
"--buildDir=$(@D)",
],
data = [":nuxt-srcs"] + deps,
data = files + deps,
link_workspace_root = True,
output_dir = True,
)

View File

@ -5,10 +5,10 @@ if (buildDir) {
buildDir = 'nexus/cognitron/web/.nuxt'
}
export default {
module.exports = {
server: {
host: '0.0.0.0',
port: 8082
port: 3000
},
buildDir: buildDir,
srcDir: 'nexus/cognitron/web',
@ -40,11 +40,11 @@ export default {
publicRuntimeConfig: {
meta_api: {
url: process.env.NEXUS_COGNITRON_WEB_meta_api.url || 'http://nexus-meta-api:8080'
url: process.env['NEXUS_COGNITRON_WEB_meta_api.url'] || 'http://localhost:8080'
},
ipfs: {
gateway: {
url: process.env.NEXUS_COGNITRON_WEB_ipfs.gateway.url || 'https://ipfs.io'
url: process.env['NEXUS_COGNITRON_WEB_ipfs.gateway.url'] || 'https://ipfs.io'
}
}
},
@ -80,6 +80,7 @@ export default {
build: {
extend (config) {
config.resolve.alias['~'] = process.cwd()
}
},
transpile: ['nexus-meta-api-js-client'],
}
}

View File

@ -1,6 +1,6 @@
import MetaApi from '~/nexus/meta_api/js/client'
import MetaApi from 'nexus-meta-api-js-client'
export default ({ $config }, inject) => {
const metaApi = new MetaApi($config.metaApi)
const metaApi = new MetaApi($config.meta_api)
inject('meta_api', metaApi)
}

View File

@ -38,7 +38,7 @@ py3_image(
"//library/aiopostgres",
"//library/configurator",
"//library/logging",
"//nexus/meta_api/proto:meta_api_grpc_py",
"//nexus/meta_api/proto:meta-api-grpc-py",
"//nexus/meta_api/query_extensionner",
"//nexus/models/proto:models_proto_py",
"//nexus/nlptools",

View File

@ -11,8 +11,8 @@ py_library(
requirement("tenacity"),
requirement("aiogrpcclient"),
requirement("aiokit"),
"//nexus/meta_api/proto:meta_api_grpc_py",
"//nexus/meta_api/proto:meta_api_proto_py",
"//nexus/meta_api/proto:meta-api-grpc-py",
"//nexus/meta_api/proto:meta-api-proto-py",
"//nexus/models/proto:models_proto_py",
],
)

View File

@ -1,12 +1,11 @@
load("//rules/nodejs:common.bzl", "js_library")
load("@build_bazel_rules_nodejs//:index.bzl", "js_library")
js_library(
name = "client",
package_name = "nexus-meta-api-js-client",
srcs = glob(["*.js"]),
data = [
"//library/js:base-client",
"//library/js:utils",
"//nexus/meta_api/proto:meta_api_grpc_web_js",
],
visibility = ["//visibility:public"],
deps = [
"//nexus/meta_api/proto:meta-api-grpc-web-js",
],
)

View File

@ -1,5 +1,5 @@
import documentsProto from '~/nexus/meta_api/proto/documents_service_grpc_web_pb'
import searchProto from '~/nexus/meta_api/proto/search_service_grpc_web_pb'
import documentsProto from 'meta-api-grpc-web-js/meta-api-grpc-web-js_pb/nexus/meta_api/proto/documents_service_grpc_web_pb'
import searchProto from 'meta-api-grpc-web-js/meta-api-grpc-web-js_pb/nexus/meta_api/proto/search_service_grpc_web_pb'
export default class MetaApi {
constructor (config) {

View File

@ -6,7 +6,7 @@ load("@rules_proto_grpc//js:defs.bzl", "js_grpc_web_library")
package(default_visibility = ["//visibility:public"])
proto_library(
name = "meta_api_proto",
name = "meta-api-proto",
srcs = glob([
"*.proto",
]),
@ -17,27 +17,29 @@ proto_library(
)
py_proto_library(
name = "meta_api_proto_py",
deps = [":meta_api_proto"],
name = "meta-api-proto-py",
deps = [":meta-api-proto"],
)
py_grpc_library(
name = "meta_api_grpc_py",
srcs = [":meta_api_proto"],
deps = [":meta_api_proto_py"],
name = "meta-api-grpc-py",
srcs = [":meta-api-proto"],
deps = [":meta-api-proto-py"],
)
rust_proto_library(
name = "meta_api_proto_rust",
name = "meta-api-proto-rust",
rust_deps = ["//rules/rust/cargo:protobuf"],
visibility = ["//visibility:public"],
deps = [":meta_api_proto"],
deps = [":meta-api-proto"],
)
js_grpc_web_library(
name = "meta_api_grpc_web_js",
prefix_path = "../../../../",
protos = [":meta_api_proto"],
name = "meta-api-grpc-web-js",
protos = [
":meta-api-proto",
"//nexus/models/proto:models_proto",
],
visibility = ["//visibility:public"],
deps = ["//nexus/models/proto:models_proto_js"],
)

View File

@ -26,7 +26,6 @@ rust_proto_library(
js_proto_library(
name = "models_proto_js",
prefix_path = "../../../../",
protos = [":models_proto"],
visibility = ["//visibility:public"],
)