anki/ts/editor/BUILD.bazel
2021-09-15 13:33:22 +02:00

194 lines
4.1 KiB
Python

load("@npm//@bazel/typescript:index.bzl", "ts_library")
load("//ts/svelte:svelte.bzl", "compile_svelte", "svelte_check")
load("//ts:prettier.bzl", "prettier_test")
load("//ts:eslint.bzl", "eslint_test")
load("//ts:esbuild.bzl", "esbuild")
load("//ts:vendor.bzl", "copy_bootstrap_icons", "copy_mdi_icons")
load("//ts:compile_sass.bzl", "compile_sass")
svelte_files = glob(["*.svelte"])
svelte_names = [f.replace(".svelte", "") for f in svelte_files]
filegroup(
name = "svelte_components",
srcs = svelte_names,
visibility = ["//visibility:public"],
)
compile_svelte(
name = "svelte",
srcs = svelte_files,
visibility = ["//visibility:public"],
deps = [
"//ts/components",
],
)
compile_sass(
srcs = [
"fields.scss",
],
group = "base_css",
visibility = ["//visibility:public"],
deps = [
"//ts/sass:base_lib",
"//ts/sass:scrollbar_lib",
"//ts/sass:buttons_lib",
"//ts/sass:button_mixins_lib",
],
)
compile_sass(
srcs = [
"bootstrap.scss",
"legacy.scss",
],
group = "local_css",
visibility = ["//visibility:public"],
deps = [
"//ts/sass:button_mixins_lib",
"//ts/sass/bootstrap",
],
)
ts_library(
name = "editor_ts",
srcs = glob(["*.ts"]),
tsconfig = "//ts:tsconfig.json",
deps = [
"//ts/lib",
"//ts/sveltelib",
"//ts/components",
"//ts/editable",
"//ts/html-filter",
"//ts:image_module_support",
"@npm//svelte",
"@npm//@types/codemirror",
"@npm//codemirror",
] + svelte_names,
)
copy_bootstrap_icons(
name = "bootstrap-icons",
icons = [
"pin-angle.svg",
# inline formatting
"type-bold.svg",
"type-italic.svg",
"type-underline.svg",
"eraser.svg",
"square-fill.svg",
"paperclip.svg",
"mic.svg",
# block formatting
"list-ul.svg",
"list-ol.svg",
"text-paragraph.svg",
"justify.svg",
"text-left.svg",
"text-right.svg",
"text-center.svg",
"text-indent-left.svg",
"text-indent-right.svg",
# tag editor
"x.svg",
],
visibility = ["//visibility:public"],
)
copy_mdi_icons(
name = "mdi-icons",
icons = [
"format-superscript.svg",
"format-subscript.svg",
"function-variant.svg",
"contain.svg",
"xml.svg",
"format-color-text.svg",
"format-color-highlight.svg",
"color-helper.svg",
# image handle
"format-float-none.svg",
"format-float-left.svg",
"format-float-right.svg",
"image-size-select-large.svg",
"image-size-select-actual.svg",
# mathjax handle
"format-wrap-square.svg",
"format-wrap-top-bottom.svg",
# tag editor
"tag-outline.svg",
"tag.svg",
"tag-plus.svg",
"dots-vertical.svg",
],
visibility = ["//visibility:public"],
)
esbuild(
name = "editor",
args = [
"--loader:.svg=text",
"--resolve-extensions=.mjs,.js",
"--log-level=warning",
],
entry_point = "index_wrapper.ts",
output_css = "editor.css",
visibility = ["//visibility:public"],
deps = [
"editor_ts",
"base_css",
"local_css",
"bootstrap-icons",
"mdi-icons",
"svelte_components",
"//ts/editable",
"//ts/editable:mdi-icons",
"//ts/components",
"//ts/components:svelte_components",
"//ts/editable:svelte_components",
"@npm//protobufjs",
],
)
# Tests
################
prettier_test(
name = "format_check",
srcs = glob([
"*.ts",
"*.svelte",
]),
)
eslint_test(
name = "eslint",
srcs = glob(
[
"*.ts",
],
),
)
svelte_check(
name = "svelte_check",
srcs = glob([
"*.ts",
"*.svelte",
]) + [
"//ts/sass:button_mixins_lib",
"//ts/sass/bootstrap",
"@npm//@types/bootstrap",
"//ts/components",
],
)