feat: ✨ update working
This commit is contained in:
parent
65482536ff
commit
cc382601af
@ -5,24 +5,65 @@
|
|||||||
:message="error"
|
:message="error"
|
||||||
type="danger"
|
type="danger"
|
||||||
>
|
>
|
||||||
|
<form @submit.prevent="submit">
|
||||||
|
<div v-if="!container_name" class="field">
|
||||||
|
<label class="label">Name</label>
|
||||||
|
<div class="control has-icons-left">
|
||||||
|
<input
|
||||||
|
v-model="custom_name"
|
||||||
|
class="input"
|
||||||
|
placeholder="loop"
|
||||||
|
required
|
||||||
|
type="text"
|
||||||
|
/>
|
||||||
|
<span class="icon is-small is-left">
|
||||||
|
<i class="fa fa-tag"></i>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<div class="field">
|
<div class="field">
|
||||||
<label class="label">Image</label>
|
<label class="label">Image</label>
|
||||||
<div class="control has-icons-left">
|
<div class="control has-icons-left">
|
||||||
<input
|
<input
|
||||||
|
v-model="image"
|
||||||
class="input"
|
class="input"
|
||||||
placeholder="ghcr.io/crazy-max/loop:latest"
|
placeholder="ghcr.io/crazy-max/loop:latest"
|
||||||
|
required
|
||||||
type="text"
|
type="text"
|
||||||
value=""
|
|
||||||
/>
|
/>
|
||||||
<span class="icon is-small is-left">
|
<span class="icon is-small is-left">
|
||||||
<i class="fa fa-image"></i>
|
<i class="fa fa-image"></i>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="field">
|
||||||
|
<label class="label">Environment variables</label>
|
||||||
|
<div class="control">
|
||||||
|
<textarea
|
||||||
|
v-model="environment"
|
||||||
|
class="textarea"
|
||||||
|
placeholder="DURATION=60s"
|
||||||
|
required
|
||||||
|
></textarea>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="field is-grouped">
|
||||||
|
<div class="control">
|
||||||
|
<button class="button is-link" type="submit">Submit</button>
|
||||||
|
</div>
|
||||||
|
<div class="control">
|
||||||
|
<button class="button is-link is-light" @click="$router.back()">
|
||||||
|
Cancel
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
</Loading>
|
</Loading>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
|
import axios, { AxiosError } from 'axios'
|
||||||
|
import type { Container } from '../types'
|
||||||
import Loading from '../components/Loading.vue'
|
import Loading from '../components/Loading.vue'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
@ -32,6 +73,9 @@ export default {
|
|||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
custom_name: null as string | null,
|
||||||
|
image: null as string | null,
|
||||||
|
environment: null as string | null,
|
||||||
error: '',
|
error: '',
|
||||||
loading: false,
|
loading: false,
|
||||||
}
|
}
|
||||||
@ -41,5 +85,48 @@ export default {
|
|||||||
return this.$route.params.name as string
|
return this.$route.params.name as string
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
async mounted() {
|
||||||
|
if (!this.container_name) return
|
||||||
|
try {
|
||||||
|
this.loading = true
|
||||||
|
const { data } = await axios.get<Container>(
|
||||||
|
`/api/container/${this.container_name}`,
|
||||||
|
)
|
||||||
|
this.custom_name = data.name
|
||||||
|
this.image = data.image
|
||||||
|
this.environment = data.environment.join('\n')
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error)
|
||||||
|
this.error =
|
||||||
|
error instanceof AxiosError
|
||||||
|
? error.message
|
||||||
|
: 'Error performing operation'
|
||||||
|
} finally {
|
||||||
|
this.loading = false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
async submit() {
|
||||||
|
try {
|
||||||
|
this.loading = true
|
||||||
|
const { data } = await axios.post<Container>(
|
||||||
|
`/api/container/${this.custom_name ?? this.container_name}`,
|
||||||
|
{
|
||||||
|
image: this.image,
|
||||||
|
environment: this.environment?.split('\n'),
|
||||||
|
},
|
||||||
|
)
|
||||||
|
this.$router.push(`/show/${data.name}`)
|
||||||
|
} catch (error) {
|
||||||
|
console.error(error)
|
||||||
|
this.error =
|
||||||
|
error instanceof AxiosError
|
||||||
|
? error.message
|
||||||
|
: 'Error performing operation'
|
||||||
|
} finally {
|
||||||
|
this.loading = false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
},
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
Loading…
Reference in New Issue
Block a user