12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- <template>
- <SmartModal
- v-if="show"
- :title="`${$t('modal.edit_request')}`"
- @close="hideModal"
- >
- <template #body>
- <div class="flex flex-col px-2">
- <input
- id="selectLabelGqlEditReq"
- v-model="requestUpdateData.name"
- v-focus
- class="input floating-input"
- placeholder=" "
- type="text"
- autocomplete="off"
- @keyup.enter="saveRequest"
- />
- <label for="selectLabelGqlEditReq">
- {{ $t("action.label") }}
- </label>
- </div>
- </template>
- <template #footer>
- <span>
- <ButtonPrimary
- :label="`${$t('action.save')}`"
- @click.native="saveRequest"
- />
- <ButtonSecondary
- :label="`${$t('action.cancel')}`"
- @click.native="hideModal"
- />
- </span>
- </template>
- </SmartModal>
- </template>
- <script lang="ts">
- import { defineComponent, PropType } from "@nuxtjs/composition-api"
- import { HoppGQLRequest } from "~/helpers/types/HoppGQLRequest"
- import { editGraphqlRequest } from "~/newstore/collections"
- export default defineComponent({
- props: {
- show: Boolean,
- folderPath: { type: String, default: null },
- request: { type: Object as PropType<HoppGQLRequest>, default: () => {} },
- requestIndex: { type: Number, default: null },
- },
- data() {
- return {
- requestUpdateData: {
- name: null as any | null,
- },
- }
- },
- methods: {
- saveRequest() {
- if (!this.requestUpdateData.name) {
- this.$toast.error(`${this.$t("collection.invalid_name")}`)
- return
- }
- const requestUpdated = {
- ...this.$props.request,
- name: this.$data.requestUpdateData.name || this.$props.request.name,
- }
- editGraphqlRequest(this.folderPath, this.requestIndex, requestUpdated)
- this.hideModal()
- },
- hideModal() {
- this.requestUpdateData = { name: null }
- this.$emit("hide-modal")
- },
- },
- })
- </script>
|