-
Notifications
You must be signed in to change notification settings - Fork 31
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
8b8280d
commit 0161b5a
Showing
7 changed files
with
20,136 additions
and
72 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,166 @@ | ||
<template> | ||
<v-data-table | ||
:headers="headers" | ||
:items="providers" | ||
:hide-default-footer="true" | ||
class="elevation-1" | ||
> | ||
<template #top> | ||
<v-toolbar flat> | ||
<v-dialog v-model="dialog" max-width="500px"> | ||
<template #activator="{ on, attrs }"> | ||
<v-btn color="primary" dark class="mb-2" v-bind="attrs" v-on="on"> | ||
New Provider | ||
</v-btn> | ||
</template> | ||
<v-card> | ||
<v-card-text> | ||
<v-container> | ||
<v-row> | ||
<v-col cols="12" sm="6" md="4"> | ||
<v-text-field | ||
v-model="editedItem.provider_name" | ||
label="Provider name" | ||
></v-text-field> | ||
</v-col> | ||
<v-col cols="12" sm="6" md="4"> | ||
<v-text-field | ||
v-model="editedItem.client_id" | ||
label="Client id" | ||
></v-text-field> | ||
</v-col> | ||
<v-col cols="12" sm="6" md="4"> | ||
<v-text-field | ||
v-model="editedItem.client_secret" | ||
label="Client secret" | ||
></v-text-field> | ||
</v-col> | ||
</v-row> | ||
</v-container> | ||
</v-card-text> | ||
|
||
<v-card-actions> | ||
<v-spacer></v-spacer> | ||
<v-btn color="blue darken-1" text @click="close"> Cancel </v-btn> | ||
<v-btn color="blue darken-1" text @click="save"> Save </v-btn> | ||
</v-card-actions> | ||
</v-card> | ||
</v-dialog> | ||
<v-dialog v-model="dialogDelete" max-width="500px"> | ||
<v-card> | ||
<v-card-title class="text-h5" | ||
>Are you sure you want to delete this item?</v-card-title | ||
> | ||
<v-card-actions> | ||
<v-spacer></v-spacer> | ||
<v-btn color="blue darken-1" text @click="closeDelete" | ||
>Cancel</v-btn | ||
> | ||
<v-btn color="blue darken-1" text @click="deleteItemConfirm" | ||
>OK</v-btn | ||
> | ||
<v-spacer></v-spacer> | ||
</v-card-actions> | ||
</v-card> | ||
</v-dialog> | ||
</v-toolbar> | ||
</template> | ||
<template #item.actions="{ item }"> | ||
<v-icon small class="mr-2" @click="editItem(item)"> mdi-pencil </v-icon> | ||
<v-icon small @click="deleteItem(item)"> mdi-delete </v-icon> | ||
</template> | ||
</v-data-table> | ||
</template> | ||
<script> | ||
export default { | ||
data: () => ({ | ||
dialog: false, | ||
dialogDelete: false, | ||
headers: [ | ||
{ | ||
text: "Provider name", | ||
align: "start", | ||
sortable: false, | ||
value: "provider_name", | ||
}, | ||
{ text: "Client id", value: "client_id" }, | ||
{ text: "Client secret", value: "client_secret" }, | ||
{ text: "Actions", value: "actions", sortable: false }, | ||
], | ||
providers: [], | ||
editedIndex: -1, | ||
editedItem: { | ||
provider_name: "", | ||
client_id: 0, | ||
client_secret: 0, | ||
}, | ||
defaultItem: { | ||
provider_name: "", | ||
client_id: 0, | ||
client_secret: 0, | ||
}, | ||
}), | ||
computed: { | ||
formTitle() { | ||
return this.editedIndex === -1 ? "New Item" : "Edit Item" | ||
}, | ||
}, | ||
watch: { | ||
dialog(val) { | ||
val || this.close() | ||
}, | ||
dialogDelete(val) { | ||
val || this.closeDelete() | ||
}, | ||
}, | ||
beforeMount() { | ||
this.providers = this.$store.state.policies.enabled_providers | ||
}, | ||
methods: { | ||
editItem(item) { | ||
this.editedIndex = this.providers.indexOf(item) | ||
this.editedItem = Object.assign({}, item) | ||
this.dialog = true | ||
this.$emit("input", this.providers) | ||
}, | ||
deleteItem(item) { | ||
this.editedIndex = this.providers.indexOf(item) | ||
this.editedItem = Object.assign({}, item) | ||
this.dialogDelete = true | ||
this.$emit("input", this.providers) | ||
}, | ||
deleteItemConfirm() { | ||
this.providers.splice(this.editedIndex, 1) | ||
this.closeDelete() | ||
this.$emit("input", this.providers) | ||
}, | ||
close() { | ||
this.dialog = false | ||
this.$nextTick(() => { | ||
this.editedItem = Object.assign({}, this.defaultItem) | ||
this.editedIndex = -1 | ||
}) | ||
}, | ||
closeDelete() { | ||
this.dialogDelete = false | ||
this.$nextTick(() => { | ||
this.editedItem = Object.assign({}, this.defaultItem) | ||
this.editedIndex = -1 | ||
}) | ||
}, | ||
save() { | ||
if (this.editedIndex > -1) { | ||
Object.assign(this.providers[this.editedIndex], this.editedItem) | ||
} else { | ||
this.providers.push(this.editedItem) | ||
} | ||
this.$emit("input", this.providers) | ||
this.close() | ||
}, | ||
}, | ||
} | ||
</script> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
<template> | ||
<v-layout column align-center justify-center class="auth-buttons" mb-6> | ||
<v-btn | ||
v-if="providers.includes('google')" | ||
class="sso-auth-button" | ||
color="white" | ||
outlined | ||
@click="ssoAuth('google')" | ||
> | ||
<v-icon left> mdi-google </v-icon> | ||
Sign up with Google | ||
</v-btn> | ||
<v-btn | ||
v-if="providers.includes('github')" | ||
class="sso-auth-button" | ||
color="white" | ||
outlined | ||
@click="ssoAuth('github')" | ||
> | ||
<v-icon left> mdi-github </v-icon> | ||
Sign up with Github | ||
</v-btn> | ||
</v-layout> | ||
</template> | ||
|
||
<script> | ||
export default { | ||
props: { | ||
usernameErrors: { | ||
type: Array, | ||
required: true, | ||
}, | ||
}, | ||
data() { | ||
return { | ||
providers: [], | ||
localUsernameErrors: this.usernameErrors, | ||
} | ||
}, | ||
beforeMount() { | ||
const error = this.$route.query.error | ||
if (error) { | ||
this.localUsernameErrors.push(error) | ||
this.$emit("update-list", this.localUsernameErrors) | ||
} | ||
}, | ||
beforeCreate() { | ||
this.$axios.get("/manage/providers").then((r) => { | ||
this.providers = r.data | ||
}) | ||
}, | ||
methods: { | ||
ssoAuth(provider) { | ||
window.open( | ||
this.$axios.defaults.baseURL + "/users/login/" + provider, | ||
"_self" | ||
) | ||
}, | ||
}, | ||
} | ||
</script> |
Oops, something went wrong.