mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-17 06:37:23 +01:00
* add colors palette * add secondary menu component and style it * add box shadow to secondary menu * misc css, fixes for secondary menu * client: add equipment page with grouping, css: add some styles * add typography * more equipment * stable: fix linting * equipment: add styles (lots of general styles too) * remove duplicate google fonts loading * add dropdowns * design: white search input background, remove gray from items * start adding drawer and selected indicator * wip equipment * fix equipment * equipment: correctly bind new properties on items.gear.equipped * equipment: fix vue binding. version 2 * equipment: fix vue binding. version 3 * back to first fix for equip op, fix for sourcemaps, send http request when an item is equipped, load bootstrap-vue components where needed * checkboxes and radio buttons * correctly renders selected items in first postion during the first render * add search * general changes, constants part of app state, add popovers * add toggle switch, rename css * correct offset * upgrade deps * upgrade deps * drawer and lot of other work * update equipping mechanism * finish equipment * fix compilation and upgrade deps * use v-show in place of v-if to fix ui issues * v-show -> v-if * Start of guild syyles * fix linting in test/client * fix es6 compilation in test/client * fix babel compilation for tests * fix groupsUtilities mixin tests * More designs * Added public guild state * Added my guilds store * client: buttons * client: buttons: fix colors * Added join and leave * Began adding new guild form * Create form updates * Added search to local data * Added filtering * Added initial code for group create * Added more create checks * Added more guild routes * Added styles to guild page * Added more chat styles * Began porting over angular functions * Moved over group service functions * Added paging * Updated sidebar * Updated join/leave and minor text * Added new sidebar functions * Updated paging * Added some form updates * Added more translations and styles * Updated shrinkwrap * Removed features config * Lint cleanup * Added member modal * Added more member actions * Updated nav * Fixed filter toggling * Updated create guild * Added no guild page * Added sort select * Added more styles * Added update guild form * Removed extra css and other minor changes * Many css and syntax fixes * Fixed color and merge conflic * Removed paging from my guilds * Removed extra strings * Many requests updates * Small style fixes
120 lines
2.2 KiB
Vue
120 lines
2.2 KiB
Vue
<template lang="pug">
|
|
.clearfix.toggle-switch-container
|
|
.float-left.toggle-switch-description {{ label }}
|
|
.toggle-switch.float-left
|
|
input.toggle-switch-checkbox(
|
|
type='checkbox', :id="id",
|
|
@change="$emit('change', $event.target.checked)",
|
|
:checked="checked",
|
|
)
|
|
label.toggle-switch-label(:for="id")
|
|
span.toggle-switch-inner
|
|
span.toggle-switch-switch
|
|
</template>
|
|
|
|
<style lang="scss" scoped>
|
|
@import '~client/assets/scss/colors.scss';
|
|
|
|
.toggle-switch-container {
|
|
margin-top: 6px;
|
|
}
|
|
|
|
.toggle-switch {
|
|
position: relative;
|
|
width: 40px;
|
|
user-select: none;
|
|
margin-left: 9px;
|
|
}
|
|
|
|
.toggle-switch-description {
|
|
height: 20px;
|
|
border-bottom: 1px dashed $gray-200;
|
|
}
|
|
|
|
.toggle-switch-checkbox {
|
|
display: none;
|
|
}
|
|
|
|
.toggle-switch-label {
|
|
display: block;
|
|
overflow: hidden;
|
|
cursor: pointer;
|
|
border-radius: 100px;
|
|
margin-bottom: 0px;
|
|
margin-top: 3px;
|
|
}
|
|
|
|
.toggle-switch-inner {
|
|
display: block;
|
|
width: 200%;
|
|
margin-left: -100%;
|
|
transition: margin 0.3s ease-in 0s;
|
|
}
|
|
|
|
.toggle-switch-inner:before, .toggle-switch-inner:after {
|
|
display: block;
|
|
float: left;
|
|
width: 50%;
|
|
height: 16px;
|
|
padding: 0;
|
|
}
|
|
|
|
.toggle-switch-inner:before {
|
|
content: "";
|
|
padding-left: 10px;
|
|
background-color: $purple-400;
|
|
}
|
|
|
|
.toggle-switch-inner:after {
|
|
content: "";
|
|
padding-right: 10px;
|
|
background-color: $gray-200;
|
|
text-align: right;
|
|
}
|
|
|
|
.toggle-switch-switch {
|
|
box-shadow: 0 1px 2px 0 rgba($black, 0.32);
|
|
display: block;
|
|
width: 20px;
|
|
margin: -2px;
|
|
margin-top: 1px;
|
|
height: 20px;
|
|
background: $white;
|
|
position: absolute;
|
|
top: 0;
|
|
bottom: 0;
|
|
right: 22px;
|
|
border-radius: 100px;
|
|
transition: all 0.3s ease-in 0s;
|
|
}
|
|
|
|
.toggle-switch-checkbox:checked + .toggle-switch-label .toggle-switch-inner {
|
|
margin-left: 0;
|
|
}
|
|
|
|
.toggle-switch-checkbox:checked + .toggle-switch-label .toggle-switch-switch {
|
|
right: 0px;
|
|
}
|
|
</style>
|
|
|
|
<script>
|
|
export default {
|
|
data () {
|
|
return {
|
|
// A value is required for the required for the for and id attributes
|
|
id: Math.random(),
|
|
};
|
|
},
|
|
props: {
|
|
label: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
checked: {
|
|
type: Boolean,
|
|
default: false,
|
|
},
|
|
},
|
|
};
|
|
</script>
|