feat: codemirror editor for pre-request and test scripts

This commit is contained in:
liyasthomas
2021-09-10 11:12:08 +05:30
parent 2eb0a4c754
commit 3ef5a1e21a
2 changed files with 66 additions and 42 deletions

View File

@@ -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>

View File

@@ -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
} }