Sha256: 59c264b7e0b5093a17b90e9ecc10ee97ffcec9539547188c72dac6750db95190

Contents?: true

Size: 2 KB

Versions: 10

Compression:

Stored size: 2 KB

Contents

<template>
  <div>
    <a v-if="rawMode" @click="rawMode = false">view pretty</a>
    <a v-if="!rawMode" @click="rawMode = true">view raw</a>
    <div v-show="!rawMode" ref="schemaTarget" class="schema-pretty"/>
    <pre v-show="rawMode"><code v-html="schemaFormatted" class="json"/></pre>
  </div>
</template>
<script>
import "json-schema-view-js/dist/style.css";
import "highlight.js/styles/railscasts.css";
import highlightJson from "../highlight";
import { emptyPromise } from '../utils';

const JSONSchemaViewP = emptyPromise();
const $RefParserP = emptyPromise();

export default {
  name: "InnerJsonSchema",
  props: ["schema"],
  data() {
    return {
      rawMode: false,
    };
  },
  created() {
    import("json-schema-view-js").then(JSONSchemaViewP.resolve);
    import("json-schema-ref-parser/dist/ref-parser.js").then($RefParserP.resolve);
  },
  computed: {
    view() {
      return Promise.all([$RefParserP, JSONSchemaViewP])
        .then(([$RefParser]) => $RefParser.default.dereference(this.schema))
        .then(
          s =>
            new window.JSONSchemaView(s, 2, {
              theme: "dark"
            })
        );
    },
    schemaFormatted() {
      return highlightJson(JSON.stringify(this.schema, null, 2));
    }
  },
  methods: {
    async replaceRenderedSchema() {
      const v = await this.view;
      this.$refs.schemaTarget.innerHtml = "";
      this.$refs.schemaTarget.appendChild(v.render());
    }
  },
  watch: {
    schema: {
      handler: "replaceRenderedSchema",
      immediate: true
    }
  }
};
</script>
<style>
.schema-pretty {
  margin-top: 0.85rem;
  background-color: #282c34;
  padding: 1.25rem 1.5rem;
  border-radius: 6px;
  width: fit-content
}
.json-formatter-row a {
  color: white;
}
.json-formatter-row .json-formatter-bracket,
.json-formatter-row .json-formatter-number {
  color: #9090fb;
}
.json-formatter-row .json-formatter-key {
  color: #8665d0;
}
.json-schema-view .object .inner.oneOf b {
  color: aqua;
}
.json-schema-view .default {
  color:  #5f96df
}
</style>

Version data entries

10 entries across 10 versions & 1 rubygems

Version Path
urbanopt-scenario-0.4.2 docs/.vuepress/components/InnerJsonSchema.vue
urbanopt-scenario-0.4.1 docs/.vuepress/components/InnerJsonSchema.vue
urbanopt-scenario-0.4.0 docs/.vuepress/components/InnerJsonSchema.vue
urbanopt-scenario-0.3.0 docs/.vuepress/components/InnerJsonSchema.vue
urbanopt-scenario-0.3.0.pre1 docs/.vuepress/components/InnerJsonSchema.vue
urbanopt-scenario-0.2.0 docs/.vuepress/components/InnerJsonSchema.vue
urbanopt-scenario-0.2.0.pre2 docs/.vuepress/components/InnerJsonSchema.vue
urbanopt-scenario-0.2.0.pre1 docs/.vuepress/components/InnerJsonSchema.vue
urbanopt-scenario-0.1.1 docs/.vuepress/components/InnerJsonSchema.vue
urbanopt-scenario-0.1.0 docs/.vuepress/components/InnerJsonSchema.vue