1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- <template>
- <div>
- <div class="field-title" :class="{ 'field-highlighted': isHighlighted }">
- {{ fieldName }}
- <span v-if="fieldArgs.length > 0">
- (
- <span v-for="(field, index) in fieldArgs" :key="`field-${index}`">
- {{ field.name }}:
- <GraphqlTypeLink
- :gql-type="field.type"
- :jump-type-callback="jumpTypeCallback"
- />
- <span v-if="index !== fieldArgs.length - 1">, </span>
- </span>
- ) </span
- >:
- <GraphqlTypeLink
- :gql-type="gqlField.type"
- :jump-type-callback="jumpTypeCallback"
- />
- </div>
- <div
- v-if="gqlField.description"
- class="text-secondaryLight field-desc py-2"
- >
- {{ gqlField.description }}
- </div>
- <div
- v-if="gqlField.isDeprecated"
- class="field-deprecated inline-block px-2 py-1 my-1 text-black bg-yellow-200 rounded"
- >
- {{ $t("state.deprecated") }}
- </div>
- <div v-if="fieldArgs.length > 0">
- <h5 class="my-2">Arguments:</h5>
- <div class="border-divider pl-4 border-l-2">
- <div v-for="(field, index) in fieldArgs" :key="`field-${index}`">
- <span>
- {{ field.name }}:
- <GraphqlTypeLink
- :gql-type="field.type"
- :jump-type-callback="jumpTypeCallback"
- />
- </span>
- <div
- v-if="field.description"
- class="text-secondaryLight field-desc py-2"
- >
- {{ field.description }}
- </div>
- </div>
- </div>
- </div>
- </div>
- </template>
- <script>
- import { defineComponent } from "@nuxtjs/composition-api"
- export default defineComponent({
- props: {
- gqlField: { type: Object, default: () => {} },
- jumpTypeCallback: { type: Function, default: () => {} },
- isHighlighted: { type: Boolean, default: false },
- },
- computed: {
- fieldName() {
- return this.gqlField.name
- },
- fieldArgs() {
- return this.gqlField.args || []
- },
- },
- })
- </script>
- <style scoped lang="scss">
- .field-highlighted {
- @apply border-b-2 border-accent;
- }
- .field-title {
- @apply select-text;
- }
- </style>
|