You've already forked AstralRinth
forked from didirus/AstralRinth
* refactor: migrate to common eslint+prettier configs * fix: prettier frontend * feat: config changes * fix: lint issues * fix: lint * fix: type imports * fix: cyclical import issue * fix: lockfile * fix: missing dep * fix: switch to tabs * fix: continue switch to tabs * fix: rustfmt parity * fix: moderation lint issue * fix: lint issues * fix: ui intl * fix: lint issues * Revert "fix: rustfmt parity" This reverts commit cb99d2376c321d813d4b7fc7e2a213bb30a54711. * feat: revert last rs
68 lines
1.3 KiB
Vue
68 lines
1.3 KiB
Vue
<script setup lang="ts">
|
|
import {
|
|
DEFAULT_FEATURE_FLAGS,
|
|
type FeatureFlag,
|
|
saveFeatureFlags,
|
|
} from '~/composables/featureFlags.ts'
|
|
|
|
const flags = shallowReactive(useFeatureFlags().value)
|
|
</script>
|
|
|
|
<template>
|
|
<div class="page">
|
|
<h1>Feature flags</h1>
|
|
<div class="flags">
|
|
<div
|
|
v-for="flag in Object.keys(flags) as FeatureFlag[]"
|
|
:key="`flag-${flag}`"
|
|
class="adjacent-input small card"
|
|
>
|
|
<label :for="`toggle-${flag}`">
|
|
<span class="label__title">
|
|
{{ flag.replaceAll('_', ' ') }}
|
|
</span>
|
|
<span class="label__description">
|
|
<p>
|
|
Default:
|
|
<span
|
|
:style="`color:var(--color-${
|
|
DEFAULT_FEATURE_FLAGS[flag] === false ? 'red' : 'green'
|
|
})`"
|
|
>{{ DEFAULT_FEATURE_FLAGS[flag] }}</span
|
|
>
|
|
</p>
|
|
</span>
|
|
</label>
|
|
<input
|
|
:id="`toggle-${flag}`"
|
|
v-model="flags[flag]"
|
|
class="switch stylized-toggle"
|
|
type="checkbox"
|
|
@change="() => saveFeatureFlags()"
|
|
/>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<style lang="scss" scoped>
|
|
.page {
|
|
width: calc(100% - 2 * var(--spacing-card-md));
|
|
max-width: 800px;
|
|
margin-inline: auto;
|
|
box-sizing: border-box;
|
|
margin-block: var(--spacing-card-md);
|
|
}
|
|
|
|
.flags {
|
|
}
|
|
|
|
.label__title {
|
|
text-transform: capitalize;
|
|
}
|
|
|
|
.label__description p {
|
|
margin: 0;
|
|
}
|
|
</style>
|