feat: codemirror editor for pre-request and test scripts
This commit is contained in:
@@ -24,6 +24,13 @@
|
|||||||
:title="$t('app.wiki')"
|
:title="$t('app.wiki')"
|
||||||
svg="help-circle"
|
svg="help-circle"
|
||||||
/>
|
/>
|
||||||
|
<ButtonSecondary
|
||||||
|
v-tippy="{ theme: 'tooltip' }"
|
||||||
|
:title="$t('state.linewrap')"
|
||||||
|
:class="{ '!text-accent': linewrapEnabled }"
|
||||||
|
svg="corner-down-left"
|
||||||
|
@click.native.prevent="linewrapEnabled = !linewrapEnabled"
|
||||||
|
/>
|
||||||
<ButtonSecondary
|
<ButtonSecondary
|
||||||
v-tippy="{ theme: 'tooltip' }"
|
v-tippy="{ theme: 'tooltip' }"
|
||||||
:title="$t('action.clear')"
|
:title="$t('action.clear')"
|
||||||
@@ -34,17 +41,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="border-b border-dividerLight flex">
|
<div class="border-b border-dividerLight flex">
|
||||||
<div class="border-r border-dividerLight w-2/3">
|
<div class="border-r border-dividerLight w-2/3">
|
||||||
<SmartJsEditor
|
<div ref="preRrequestEditor" class="w-full block"></div>
|
||||||
v-model="preRequestScript"
|
|
||||||
:options="{
|
|
||||||
maxLines: Infinity,
|
|
||||||
minLines: 16,
|
|
||||||
autoScrollEditorIntoView: true,
|
|
||||||
showPrintMargin: false,
|
|
||||||
useWorker: false,
|
|
||||||
}"
|
|
||||||
complete-mode="pre"
|
|
||||||
/>
|
|
||||||
</div>
|
</div>
|
||||||
<div
|
<div
|
||||||
class="
|
class="
|
||||||
@@ -84,29 +81,38 @@
|
|||||||
</AppSection>
|
</AppSection>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts">
|
<script setup lang="ts">
|
||||||
import { defineComponent } from "@nuxtjs/composition-api"
|
import { reactive, ref } from "@nuxtjs/composition-api"
|
||||||
import { usePreRequestScript } from "~/newstore/RESTSession"
|
import { usePreRequestScript } from "~/newstore/RESTSession"
|
||||||
import preRequestScriptSnippets from "~/helpers/preRequestScriptSnippets"
|
import snippets from "~/helpers/preRequestScriptSnippets"
|
||||||
|
import "codemirror/mode/javascript/javascript"
|
||||||
|
import { useCodemirror } from "~/helpers/editor/codemirror"
|
||||||
|
import linter from "~/helpers/editor/linting/preRequest"
|
||||||
|
import completer from "~/helpers/editor/completion/preRequest"
|
||||||
|
|
||||||
export default defineComponent({
|
const preRequestScript = usePreRequestScript()
|
||||||
setup() {
|
|
||||||
const preRequestScript = usePreRequestScript()
|
|
||||||
|
|
||||||
const useSnippet = (script: string) => {
|
const preRrequestEditor = ref<any | null>(null)
|
||||||
preRequestScript.value += script
|
const linewrapEnabled = ref(true)
|
||||||
}
|
|
||||||
|
|
||||||
const clearContent = () => {
|
useCodemirror(
|
||||||
preRequestScript.value = ""
|
preRrequestEditor,
|
||||||
}
|
preRequestScript,
|
||||||
|
reactive({
|
||||||
|
extendedEditorConfig: {
|
||||||
|
mode: "application/javascript",
|
||||||
|
lineWrapping: linewrapEnabled,
|
||||||
|
},
|
||||||
|
linter,
|
||||||
|
completer,
|
||||||
|
})
|
||||||
|
)
|
||||||
|
|
||||||
return {
|
const useSnippet = (script: string) => {
|
||||||
preRequestScript,
|
preRequestScript.value += script
|
||||||
snippets: preRequestScriptSnippets,
|
}
|
||||||
useSnippet,
|
|
||||||
clearContent,
|
const clearContent = () => {
|
||||||
}
|
preRequestScript.value = ""
|
||||||
},
|
}
|
||||||
})
|
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
@@ -24,6 +24,13 @@
|
|||||||
:title="$t('app.wiki')"
|
:title="$t('app.wiki')"
|
||||||
svg="help-circle"
|
svg="help-circle"
|
||||||
/>
|
/>
|
||||||
|
<ButtonSecondary
|
||||||
|
v-tippy="{ theme: 'tooltip' }"
|
||||||
|
:title="$t('state.linewrap')"
|
||||||
|
:class="{ '!text-accent': linewrapEnabled }"
|
||||||
|
svg="corner-down-left"
|
||||||
|
@click.native.prevent="linewrapEnabled = !linewrapEnabled"
|
||||||
|
/>
|
||||||
<ButtonSecondary
|
<ButtonSecondary
|
||||||
v-tippy="{ theme: 'tooltip' }"
|
v-tippy="{ theme: 'tooltip' }"
|
||||||
:title="$t('action.clear')"
|
:title="$t('action.clear')"
|
||||||
@@ -34,17 +41,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="border-b border-dividerLight flex">
|
<div class="border-b border-dividerLight flex">
|
||||||
<div class="border-r border-dividerLight w-2/3">
|
<div class="border-r border-dividerLight w-2/3">
|
||||||
<SmartJsEditor
|
<div ref="testScriptEditor" class="w-full block"></div>
|
||||||
v-model="testScript"
|
|
||||||
:options="{
|
|
||||||
maxLines: Infinity,
|
|
||||||
minLines: 16,
|
|
||||||
autoScrollEditorIntoView: true,
|
|
||||||
showPrintMargin: false,
|
|
||||||
useWorker: false,
|
|
||||||
}"
|
|
||||||
complete-mode="test"
|
|
||||||
/>
|
|
||||||
</div>
|
</div>
|
||||||
<div
|
<div
|
||||||
class="
|
class="
|
||||||
@@ -85,11 +82,32 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
|
import { reactive, ref } from "@nuxtjs/composition-api"
|
||||||
import { useTestScript } from "~/newstore/RESTSession"
|
import { useTestScript } from "~/newstore/RESTSession"
|
||||||
import testSnippets from "~/helpers/testSnippets"
|
import testSnippets from "~/helpers/testSnippets"
|
||||||
|
import "codemirror/mode/javascript/javascript"
|
||||||
|
import { useCodemirror } from "~/helpers/editor/codemirror"
|
||||||
|
import linter from "~/helpers/editor/linting/testScript"
|
||||||
|
import completer from "~/helpers/editor/completion/testScript"
|
||||||
|
|
||||||
const testScript = useTestScript()
|
const testScript = useTestScript()
|
||||||
|
|
||||||
|
const testScriptEditor = ref<any | null>(null)
|
||||||
|
const linewrapEnabled = ref(true)
|
||||||
|
|
||||||
|
useCodemirror(
|
||||||
|
testScriptEditor,
|
||||||
|
testScript,
|
||||||
|
reactive({
|
||||||
|
extendedEditorConfig: {
|
||||||
|
mode: "application/javascript",
|
||||||
|
lineWrapping: linewrapEnabled,
|
||||||
|
},
|
||||||
|
linter,
|
||||||
|
completer,
|
||||||
|
})
|
||||||
|
)
|
||||||
|
|
||||||
const useSnippet = (script: string) => {
|
const useSnippet = (script: string) => {
|
||||||
testScript.value += script
|
testScript.value += script
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user