mirror of
https://github.com/czhu12/canine.git
synced 2026-01-01 01:01:03 -06:00
66 lines
1.6 KiB
JavaScript
66 lines
1.6 KiB
JavaScript
import { Controller } from "@hotwired/stimulus"
|
|
|
|
export default class extends Controller {
|
|
static targets = [
|
|
"urlInput",
|
|
"verifyUrlSuccess",
|
|
"verifyUrlError",
|
|
"verifyUrlLoading",
|
|
]
|
|
|
|
async verifyUrl(event) {
|
|
const url = this.urlInputTarget.value.trim()
|
|
|
|
this.hideAllStatuses()
|
|
this.showLoading()
|
|
|
|
try {
|
|
const response = await fetch('/stack_manager/verify_url', {
|
|
method: 'POST',
|
|
headers: {
|
|
'Content-Type': 'application/json',
|
|
'X-CSRF-Token': document.querySelector('meta[name="csrf-token"]').content
|
|
},
|
|
body: JSON.stringify({ url: url })
|
|
})
|
|
|
|
if (response.status === 401) {
|
|
this.showError('Unauthorized')
|
|
return
|
|
}
|
|
|
|
if (response.ok) {
|
|
this.showSuccess()
|
|
} else {
|
|
this.showError('Unable to connect')
|
|
}
|
|
} catch (error) {
|
|
this.showError('Network error - please check the URL')
|
|
}
|
|
}
|
|
|
|
showLoading() {
|
|
this.hideAllStatuses()
|
|
this.verifyUrlLoadingTarget.classList.remove('hidden')
|
|
}
|
|
|
|
showSuccess() {
|
|
this.hideAllStatuses()
|
|
this.verifyUrlSuccessTarget.classList.remove('hidden')
|
|
}
|
|
|
|
showError(message) {
|
|
this.hideAllStatuses()
|
|
if (this.hasErrorMessageTarget && message) {
|
|
this.errorMessageTarget.textContent = message
|
|
}
|
|
this.verifyUrlErrorTarget.classList.remove('hidden')
|
|
}
|
|
|
|
hideAllStatuses() {
|
|
this.verifyUrlSuccessTarget.classList.add('hidden')
|
|
this.verifyUrlErrorTarget.classList.add('hidden')
|
|
this.verifyUrlLoadingTarget.classList.add('hidden')
|
|
}
|
|
}
|