mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-01 11:37:58 +00:00
FE support for https://github.com/chatwoot/chatwoot/pull/12290 ## Linear: - https://github.com/chatwoot/chatwoot/issues/486 ## Description This PR implements Multi-Factor Authentication (MFA) support for user accounts, enhancing security by requiring a second form of verification during login. The feature adds TOTP (Time-based One-Time Password) authentication with QR code generation and backup codes for account recovery. ## Type of change - [ ] New feature (non-breaking change which adds functionality) ## How Has This Been Tested? - Added comprehensive RSpec tests for MFA controller functionality - Tested MFA setup flow with QR code generation - Verified OTP validation and backup code generation - Tested login flow with MFA enabled/disabled ## Checklist: - [ ] My code follows the style guidelines of this project - [ ] I have performed a self-review of my code - [ ] I have commented on my code, particularly in hard-to-understand areas - [ ] I have made corresponding changes to the documentation - [ ] My changes generate no new warnings - [ ] I have added tests that prove my fix is effective or that my feature works - [ ] New and existing unit tests pass locally with my changes - [ ] Any dependent changes have been merged and published in downstream modules --------- Co-authored-by: Pranav <pranav@chatwoot.com> Co-authored-by: iamsivin <iamsivin@gmail.com> Co-authored-by: Sivin Varghese <64252451+iamsivin@users.noreply.github.com> Co-authored-by: Muhsin Keloth <muhsinkeramam@gmail.com> Co-authored-by: Sojan Jose <sojan@pepalo.com>
86 lines
1.9 KiB
Vue
86 lines
1.9 KiB
Vue
<script>
|
|
import SnackbarContainer from './components/SnackBar/Container.vue';
|
|
|
|
export default {
|
|
components: { SnackbarContainer },
|
|
data() {
|
|
return { theme: 'light' };
|
|
},
|
|
mounted() {
|
|
this.setColorTheme();
|
|
this.listenToThemeChanges();
|
|
this.setLocale(window.chatwootConfig.selectedLocale);
|
|
},
|
|
methods: {
|
|
setColorTheme() {
|
|
if (window.matchMedia('(prefers-color-scheme: dark)').matches) {
|
|
this.theme = 'dark';
|
|
document.documentElement.classList.add('dark');
|
|
} else {
|
|
this.theme = 'light';
|
|
document.documentElement.classList.remove('dark');
|
|
}
|
|
},
|
|
listenToThemeChanges() {
|
|
const mql = window.matchMedia('(prefers-color-scheme: dark)');
|
|
|
|
mql.onchange = e => {
|
|
if (e.matches) {
|
|
this.theme = 'dark';
|
|
document.documentElement.classList.add('dark');
|
|
} else {
|
|
this.theme = 'light';
|
|
document.documentElement.classList.remove('dark');
|
|
}
|
|
};
|
|
},
|
|
setLocale(locale) {
|
|
this.$root.$i18n.locale = locale;
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
|
|
<template>
|
|
<div class="h-full min-h-screen w-full antialiased" :class="theme">
|
|
<router-view />
|
|
<SnackbarContainer />
|
|
</div>
|
|
</template>
|
|
|
|
<style lang="scss">
|
|
@tailwind base;
|
|
@tailwind components;
|
|
@tailwind utilities;
|
|
|
|
@import '../dashboard/assets/scss/next-colors';
|
|
|
|
html,
|
|
body {
|
|
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto,
|
|
Oxygen-Sans, Ubuntu, Cantarell, 'Helvetica Neue', sans-serif;
|
|
@apply h-full w-full;
|
|
|
|
input,
|
|
select {
|
|
outline: none;
|
|
}
|
|
}
|
|
|
|
.text-link {
|
|
@apply text-n-brand font-medium hover:text-n-blue-10;
|
|
}
|
|
|
|
.v-popper--theme-tooltip .v-popper__inner {
|
|
background: black !important;
|
|
font-size: 0.75rem;
|
|
padding: 4px 8px !important;
|
|
border-radius: 6px;
|
|
font-weight: 400;
|
|
}
|
|
|
|
.v-popper--theme-tooltip .v-popper__arrow-container {
|
|
display: none;
|
|
}
|
|
</style>
|