primevue-mirror/src/AppConfigurator.vue

378 lines
19 KiB
Vue
Raw Normal View History

2019-12-20 13:49:40 +00:00
<template>
<div :class="containerClass">
<div class="layout-config-content-wrapper">
<a href="#" class="layout-config-button" @click="toggleConfigurator">
<i class="pi pi-cog"></i>
</a>
<a href="#" class="layout-config-close" @click="hideConfigurator">
<i class="pi pi-times"></i>
</a>
<div class="layout-config-content">
2020-06-19 09:41:05 +00:00
<div>
2020-06-17 19:29:33 +00:00
<h4>Component Scale</h4>
2020-05-14 08:37:01 +00:00
<div class="config-scale">
2020-06-25 13:04:00 +00:00
<Button icon="pi pi-minus" @click="decrementScale()" class="p-button-text" :disabled="scale === scales[0]"/>
2020-05-14 08:37:01 +00:00
<i class="pi pi-circle-on" v-for="s of scales" :class="{'scale-active': s === scale}" :key="s"/>
2020-06-25 13:04:00 +00:00
<Button icon="pi pi-plus" @click="incrementScale()" class="p-button-text" :disabled="scale === scales[scales.length - 1]" />
2020-05-14 08:37:01 +00:00
</div>
2020-06-20 09:40:01 +00:00
<AppInputStyleSwitch />
2020-06-25 13:04:00 +00:00
<h4>Ripple Effect</h4>
<InputSwitch :value="rippleActive" @input="onRippleChange" />
2020-06-17 19:29:33 +00:00
<h4>Free Themes</h4>
2019-12-22 09:59:34 +00:00
<p>Built-in component themes created by the <a href="https://www.primefaces.org/designer/primevue">PrimeVue Theme Designer</a>.</p>
2020-05-07 19:16:41 +00:00
2020-06-19 09:16:03 +00:00
<h5>Bootstrap</h5>
2020-06-19 09:41:05 +00:00
<div class="p-grid free-themes">
2020-06-25 09:49:23 +00:00
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'bootstrap4-light-blue')">
<img src="demo/images/themes/bootstrap4-light-blue.svg" alt="Bootstrap Light Blue" />
2020-06-25 09:49:23 +00:00
</button>
2020-06-26 13:37:03 +00:00
<span>Blue</span>
2020-06-25 09:49:23 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'bootstrap4-light-purple')">
<img src="demo/images/themes/bootstrap4-light-purple.svg" alt="Bootstrap Light Blue" />
2020-06-19 09:16:03 +00:00
</button>
2020-06-26 13:37:03 +00:00
<span>Purple</span>
2020-06-19 09:16:03 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'bootstrap4-dark-blue', true)">
<img src="demo/images/themes/bootstrap4-dark-blue.svg" alt="Bootstrap Dark Blue" />
2020-06-19 09:16:03 +00:00
</button>
2020-06-26 13:37:03 +00:00
<span>Blue</span>
2020-06-25 09:49:23 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'bootstrap4-dark-purple', true)">
<img src="demo/images/themes/bootstrap4-dark-purple.svg" alt="Bootstrap Dark Blue" />
2020-06-25 09:49:23 +00:00
</button>
2020-06-26 13:37:03 +00:00
<span>Purple</span>
2020-06-19 09:16:03 +00:00
</div>
</div>
2020-06-25 09:49:23 +00:00
<h5>Material Design</h5>
2020-06-19 09:41:05 +00:00
<div class="p-grid free-themes">
2020-06-19 09:16:03 +00:00
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'md-light-indigo')">
<img src="demo/images/themes/md-light-indigo.svg" alt="Material Light Indigo" />
2020-06-19 09:16:03 +00:00
</button>
2020-06-26 12:24:56 +00:00
<span>Indigo</span>
2020-06-19 09:16:03 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'md-light-deeppurple')">
<img src="demo/images/themes/md-light-deeppurple.svg" alt="Material Light Deep Purple" />
2020-06-19 09:16:03 +00:00
</button>
2020-06-26 12:24:56 +00:00
<span>Deep Purple</span>
2020-06-25 09:19:23 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'md-dark-indigo', true)">
<img src="demo/images/themes/md-dark-indigo.svg" alt="Material Dark Indigo" />
2020-06-25 09:19:23 +00:00
</button>
2020-06-26 12:24:56 +00:00
<span>Indigo</span>
2020-06-25 09:19:23 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'md-dark-deeppurple', true)">
<img src="demo/images/themes/md-dark-deeppurple.svg" alt="Material Dark Deep Purple" />
2020-06-25 09:19:23 +00:00
</button>
2020-06-26 12:24:56 +00:00
<span>Deep Purple</span>
2020-06-25 09:19:23 +00:00
</div>
</div>
2020-06-25 09:49:23 +00:00
<h5>Material Design Compact</h5>
2020-06-25 09:19:23 +00:00
<div class="p-grid free-themes">
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'mdc-light-indigo')">
<img src="demo/images/themes/md-light-indigo.svg" alt="Material Compact Light Indigo"/>
2020-06-25 09:19:23 +00:00
</button>
2020-06-26 12:24:56 +00:00
<span>Indigo</span>
2020-06-25 09:19:23 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'mdc-light-deeppurple')">
<img src="demo/images/themes/md-light-deeppurple.svg" alt="Material Compact Deep Purple" />
2020-06-25 09:19:23 +00:00
</button>
2020-06-26 12:24:56 +00:00
<span>Deep Purple</span>
2020-06-25 09:19:23 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'mdc-dark-indigo', true)">
<img src="demo/images/themes/md-dark-indigo.svg" alt="Material Compact Dark Indigo" />
2020-06-25 09:19:23 +00:00
</button>
2020-06-26 12:24:56 +00:00
<span>Indigo</span>
2020-06-25 09:19:23 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'mdc-dark-deeppurple', true)">
<img src="demo/images/themes/md-dark-deeppurple.svg" alt="Material Compact Dark Deep Purple" />
2020-06-25 09:19:23 +00:00
</button>
2020-06-26 12:24:56 +00:00
<span>Deep Purple</span>
2020-06-19 09:16:03 +00:00
</div>
</div>
<h5>PrimeOne Design</h5>
2020-06-19 09:41:05 +00:00
<div class="p-grid free-themes">
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'saga-blue')">
<img src="demo/images/themes/saga-blue.png" alt="Saga Blue" />
</button>
2020-05-12 22:46:48 +00:00
<span>Saga Blue</span>
</div>
2020-05-08 10:30:55 +00:00
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'saga-green')">
<img src="demo/images/themes/saga-green.png" alt="Saga Green" />
</button>
2020-05-12 22:46:48 +00:00
<span>Saga Green</span>
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'saga-orange')">
<img src="demo/images/themes/saga-orange.png" alt="Saga Orange" />
</button>
2020-05-12 22:46:48 +00:00
<span>Saga Orange</span>
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'saga-purple')">
<img src="demo/images/themes/saga-purple.png" alt="Saga Purple" />
2020-05-08 10:30:55 +00:00
</button>
2020-05-12 22:46:48 +00:00
<span>Saga Purple</span>
2020-05-08 10:30:55 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'vela-blue', true)">
<img src="demo/images/themes/vela-blue.png" alt="Vela Blue" />
</button>
2020-05-12 22:46:48 +00:00
<span>Vela Blue</span>
</div>
2020-05-08 10:30:55 +00:00
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'vela-green', true)">
<img src="demo/images/themes/vela-green.png" alt="Vela Green" />
</button>
2020-05-12 22:46:48 +00:00
<span>Vela Green</span>
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'vela-orange', true)">
<img src="demo/images/themes/vela-orange.png" alt="Vela Orange" />
</button>
2020-05-12 22:46:48 +00:00
<span>Vela Orange</span>
</div>
2020-05-08 10:30:55 +00:00
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'vela-purple', true)">
<img src="demo/images/themes/vela-purple.png" alt="Vela Purple" />
2020-05-08 10:30:55 +00:00
</button>
2020-05-12 22:46:48 +00:00
<span>Vela Purple</span>
2020-05-08 10:30:55 +00:00
</div>
2020-06-17 14:09:39 +00:00
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'arya-blue', true)">
<img src="demo/images/themes/arya-blue.png" alt="Arya Blue" />
2020-06-17 14:09:39 +00:00
</button>
2020-06-18 09:01:31 +00:00
<span>Arya Blue</span>
2020-06-17 14:09:39 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'arya-green', true)">
<img src="demo/images/themes/arya-green.png" alt="Arya Green" />
2020-06-17 14:09:39 +00:00
</button>
2020-06-18 09:01:31 +00:00
<span>Arya Green</span>
2020-06-17 14:09:39 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'arya-orange', true)">
<img src="demo/images/themes/arya-orange.png" alt="Arya Orange" />
2020-06-17 14:09:39 +00:00
</button>
2020-06-18 09:01:31 +00:00
<span>Arya Orange</span>
2020-06-17 14:09:39 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'arya-purple', true)">
<img src="demo/images/themes/arya-purple.png" alt="Arya Purple" />
2020-06-17 14:09:39 +00:00
</button>
2020-06-18 09:01:31 +00:00
<span>Arya Purple</span>
2020-06-17 14:09:39 +00:00
</div>
2020-06-19 09:16:03 +00:00
</div>
<h5>Legacy</h5>
2020-06-19 09:41:05 +00:00
<div class="p-grid free-themes">
2019-12-20 13:49:40 +00:00
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'nova')">
<img src="demo/images/themes/nova.png" alt="Nova" />
2019-12-20 13:49:40 +00:00
</button>
2020-05-16 08:13:09 +00:00
<span>Nova</span>
2019-12-20 13:49:40 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'nova-alt')">
<img src="demo/images/themes/nova-alt.png" alt="Nova Alt" />
2019-12-20 13:49:40 +00:00
</button>
2020-05-16 08:13:09 +00:00
<span>Nova Alt</span>
2019-12-20 13:49:40 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'nova-accent')">
<img src="demo/images/themes/nova-accent.png" alt="Nova Accent" />
2019-12-20 13:49:40 +00:00
</button>
2020-05-16 08:13:09 +00:00
<span>Nova Accent</span>
2019-12-20 13:49:40 +00:00
</div>
2019-12-20 14:22:50 +00:00
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'nova-vue')">
<img src="demo/images/themes/nova-vue.png" alt="Nova Colored" />
2019-12-20 14:22:50 +00:00
</button>
2020-05-12 22:46:48 +00:00
<span>Nova Vue</span>
2019-12-20 14:22:50 +00:00
</div>
2019-12-20 13:49:40 +00:00
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'luna-blue', true)">
<img src="demo/images/themes/luna-blue.png" alt="Luna Blue" />
2019-12-20 13:49:40 +00:00
</button>
2020-05-12 22:46:48 +00:00
<span>Luna Blue</span>
2019-12-20 13:49:40 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'luna-green', true)">
<img src="demo/images/themes/luna-green.png" alt="Luna Green" />
2019-12-20 13:49:40 +00:00
</button>
2020-05-12 22:46:48 +00:00
<span>Luna Green</span>
2019-12-20 13:49:40 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'luna-amber', true)">
<img src="demo/images/themes/luna-amber.png" alt="Luna Amber" />
2019-12-20 13:49:40 +00:00
</button>
2020-05-12 22:46:48 +00:00
<span>Luna Amber</span>
2019-12-20 13:49:40 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'luna-pink', true)">
<img src="demo/images/themes/luna-pink.png" alt="Luna Pink" />
2019-12-20 13:49:40 +00:00
</button>
2020-05-12 22:46:48 +00:00
<span>Luna Pink</span>
2019-12-20 13:49:40 +00:00
</div>
<div class="p-col-3">
2020-07-23 08:36:29 +00:00
<button class="p-link" @click="changeTheme($event, 'rhea', false)">
<img src="demo/images/themes/rhea.png" alt="Rhea" />
2019-12-20 13:49:40 +00:00
</button>
<span>Rhea</span>
</div>
</div>
2020-06-19 09:41:05 +00:00
2020-06-19 09:16:03 +00:00
<h4>Premium Vue-CLI Templates</h4>
2019-12-22 10:02:19 +00:00
<p>Beautifully crafted premium <a href="https://cli.vuejs.org">Vue CLI</a> application templates by the PrimeTek design team.</p>
2020-06-19 09:41:05 +00:00
<div class="p-grid premium-themes">
2020-03-23 12:31:25 +00:00
<div class="p-col-12 p-md-6">
<a href="https://www.primefaces.org/layouts/ultima-vue">
<img alt="Ultima" src="./assets/images/layouts/ultima-vue.jpg">
</a>
</div>
2020-02-28 09:35:04 +00:00
<div class="p-col-12 p-md-6">
2019-12-20 13:49:40 +00:00
<a href="https://www.primefaces.org/layouts/sapphire-vue">
2020-02-28 09:35:04 +00:00
<img alt="Sapphire" src="./assets/images/layouts/sapphire-vue.jpg">
2019-12-20 13:49:40 +00:00
</a>
</div>
2020-02-28 09:35:04 +00:00
<div class="p-col-12 p-md-6">
2020-01-10 11:56:46 +00:00
<a href="https://www.primefaces.org/layouts/serenity-vue">
2020-02-28 09:35:04 +00:00
<img alt="Serenity" src="./assets/images/layouts/serenity-vue.jpg">
2020-01-10 11:56:46 +00:00
</a>
</div>
2020-02-28 09:35:04 +00:00
<div class="p-col-12 p-md-6">
2019-12-20 13:49:40 +00:00
<a href="https://www.primefaces.org/layouts/babylon-vue">
2020-02-28 09:35:04 +00:00
<img alt="Babylon" src="./assets/images/layouts/babylon-vue.jpg">
2019-12-20 13:49:40 +00:00
</a>
</div>
2020-02-28 09:35:04 +00:00
<div class="p-col-12 p-md-6">
2019-12-20 13:49:40 +00:00
<a href="https://www.primefaces.org/layouts/avalon-vue">
2020-02-28 09:35:04 +00:00
<img alt="Avalon" src="./assets/images/layouts/avalon-vue.jpg">
2019-12-20 13:49:40 +00:00
</a>
</div>
2020-02-28 09:35:04 +00:00
<div class="p-col-12 p-md-6">
2019-12-24 08:45:43 +00:00
<a href="https://www.primefaces.org/layouts/apollo-vue">
2020-02-28 09:35:04 +00:00
<img alt="Apollo" src="./assets/images/layouts/apollo-vue.jpg">
2019-12-24 08:45:43 +00:00
</a>
</div>
2020-02-28 09:35:04 +00:00
<div class="p-col-12 p-md-6">
2020-01-07 15:38:02 +00:00
<a href="https://www.primefaces.org/layouts/roma-vue">
2020-02-28 09:35:04 +00:00
<img alt="Roma" src="./assets/images/layouts/roma-vue.jpg">
2020-01-07 15:38:02 +00:00
</a>
</div>
2020-07-05 11:07:29 +00:00
<div class="p-col-12 p-md-6">
<a href="https://www.primefaces.org/layouts/prestige-vue">
<img alt="Prestige" src="./assets/images/layouts/prestige-vue.jpg">
</a>
</div>
2019-12-20 13:49:40 +00:00
</div>
</div>
</div>
</div>
</div>
</template>
<script>
export default {
props: {
2020-06-20 09:40:01 +00:00
theme: String,
inputStyle: String
},
2019-12-20 13:49:40 +00:00
data() {
return {
2020-05-14 08:37:01 +00:00
active: false,
scale: 14,
scales: [12,13,14,15,16]
2019-12-20 13:49:40 +00:00
}
},
outsideClickListener: null,
watch: {
$route() {
if (this.active) {
this.active = false;
this.unbindOutsideClickListener();
}
}
},
methods: {
toggleConfigurator(event) {
this.active = !this.active;
event.preventDefault();
if (this.active)
this.bindOutsideClickListener();
else
this.unbindOutsideClickListener();
},
hideConfigurator(event) {
this.active = false;
this.unbindOutsideClickListener();
event.preventDefault();
},
changeTheme(event, theme, dark) {
this.$emit('change-theme', {theme: theme, dark: dark});
2019-12-20 13:49:40 +00:00
event.preventDefault();
},
bindOutsideClickListener() {
if (!this.outsideClickListener) {
this.outsideClickListener = (event) => {
if (this.active && this.isOutsideClicked(event)) {
this.active = false;
}
};
document.addEventListener('click', this.outsideClickListener);
}
},
unbindOutsideClickListener() {
if (this.outsideClickListener) {
document.removeEventListener('click', this.outsideClickListener);
this.outsideClickListener = null;
}
},
isOutsideClicked(event) {
return !(this.$el.isSameNode(event.target) || this.$el.contains(event.target));
2020-05-14 08:37:01 +00:00
},
decrementScale() {
this.scale--;
document.documentElement.style.fontSize = this.scale + 'px';
},
incrementScale() {
this.scale++;
document.documentElement.style.fontSize = this.scale + 'px';
2020-06-25 13:04:00 +00:00
},
onRippleChange(value) {
2020-06-27 22:43:07 +00:00
this.$primevue.ripple = value;
}
2020-06-27 22:43:07 +00:00
},
computed: {
containerClass() {
return ['layout-config', {'layout-config-active': this.active}];
},
rippleActive() {
return this.$primevue.ripple;
}
2020-07-10 11:47:18 +00:00
}
2019-12-20 13:49:40 +00:00
}
2019-12-20 14:22:50 +00:00
</script>