primevue-mirror/apps/showcase/components/layout/AppDesigner.vue

137 lines
5.1 KiB
Vue
Raw Normal View History

2024-11-10 19:16:58 +00:00
<template>
2024-11-14 10:02:52 +00:00
<Drawer
2024-11-22 10:02:06 +00:00
v-model:visible="$appState.designer.active"
2024-11-14 10:02:52 +00:00
position="right"
class="designer !w-screen md:!w-[48rem]"
:modal="false"
:dismissable="false"
@after-show="onShow"
@after-hide="onHide"
:pt="{
header: 'p-5',
content: '!p-5',
footer: '!p-5'
}"
>
2024-12-26 14:41:51 +00:00
<template #header>
<div class="flex items-center gap-2">
<Button v-if="$appState.designer.activeView !== 'dashboard'" variant="text" severity="secondary" rounded type="button" icon="pi pi-chevron-left" @click="openDashboard" />
<span class="font-bold text-xl">{{ viewTitle }}</span>
</div>
</template>
2024-11-10 19:16:58 +00:00
2024-12-26 14:41:51 +00:00
<DesignDashboard v-if="$appState.designer.activeView === 'dashboard'" />
<DesignCreateTheme v-else-if="$appState.designer.activeView === 'create_theme'" />
<DesignEditor v-else-if="$appState.designer.activeView === 'editor'" :deferred="deferredTabs" />
2024-11-10 19:16:58 +00:00
<template #footer>
2024-12-26 14:41:51 +00:00
<div v-if="$appState.designer.active.view === 'editor'" class="flex justify-between gap-2">
<button
type="button"
@click="download"
icon="pi pi-download"
2024-11-13 11:35:07 +00:00
class="px-3 py-2 bg-transparent border border-gray-200 dark:border-gray-700 hover:border-gray-800 dark:hover:border-gray-500 text-black dark:text-white rounded-md font-medium cursor-pointer transition-colors duration-200 focus:outline focus:outline-offset-2 focus:outline-zinc-950 focus:dark:outline-white"
>
Download
</button>
<button
type="button"
@click="apply"
2024-12-26 14:41:51 +00:00
icon="pi pi-download"
2024-11-13 11:35:07 +00:00
class="px-3 py-2 bg-zinc-950 hover:bg-zinc-800 text-white dark:bg-white dark:hover:bg-gray-100 dark:text-black rounded-md font-medium cursor-pointer transition-colors duration-200 focus:outline focus:outline-offset-2 focus:outline-zinc-950 focus:dark:outline-white"
>
Apply
</button>
2024-11-10 19:16:58 +00:00
</div>
</template>
</Drawer>
</template>
<script>
2024-12-26 14:41:51 +00:00
import { $dt } from '@primevue/themes';
2024-11-10 19:16:58 +00:00
export default {
provide() {
return {
2024-12-26 14:41:51 +00:00
designerUtils: {
refreshACTokens: this.refreshACTokens,
saveTheme: this.saveTheme
}
2024-11-10 19:16:58 +00:00
};
},
data() {
return {
2024-12-26 14:41:51 +00:00
deferredTabs: true
2024-11-10 19:16:58 +00:00
};
},
methods: {
2024-12-26 14:41:51 +00:00
onShow() {
this.deferredTabs = false;
},
onHide() {
this.deferredTabs = true;
2024-11-12 09:56:37 +00:00
},
download() {
2024-12-26 14:41:51 +00:00
// TODO: Fetch from endpoint
2024-11-12 12:38:29 +00:00
},
2024-12-26 14:41:51 +00:00
apply() {
saveTheme();
updatePreset(this.$appState.designer.theme.preset);
EventBus.emit('theme-palette-change');
2024-11-12 12:38:29 +00:00
},
saveTheme() {
2024-12-26 14:41:51 +00:00
// TODO: Save to DB or Local Storage
console.log('theme saved');
2024-11-12 23:14:58 +00:00
},
camelCaseToDotCase(name) {
return name.replace(/([a-z])([A-Z])/g, '$1.$2').toLowerCase();
},
generateACTokens(parentPath, obj) {
for (let key in obj) {
if (key === 'dark' || key === 'components') {
continue;
}
if (key === 'primitive' || key === 'semantic' || key === 'colorScheme' || key === 'light' || key === 'extend') {
this.generateACTokens(null, obj[key]);
} else {
if (typeof obj[key] === 'object') {
this.generateACTokens(parentPath ? parentPath + '.' + key : key, obj[key]);
} else {
const regex = /\.\d+$/;
const tokenName = this.camelCaseToDotCase(parentPath ? parentPath + '.' + key : key);
const tokenValue = $dt(tokenName).value;
const isColor = tokenName.includes('color') || tokenName.includes('background') || regex.test(tokenName);
2024-12-26 14:41:51 +00:00
this.$appState.designer.theme.acTokens.push({ token: tokenName, label: '{' + tokenName + '}', variable: $dt(tokenName).variable, value: tokenValue, isColor: isColor });
}
}
}
2024-11-12 23:39:09 +00:00
},
refreshACTokens() {
2024-12-26 14:41:51 +00:00
this.$appState.designer.theme.acTokens = [];
this.generateACTokens(null, this.$appState.designer.theme.preset);
console.log('refresh tokens');
2024-11-13 10:00:37 +00:00
},
2024-12-26 14:41:51 +00:00
openDashboard() {
this.$appState.designer.activeView = 'dashboard';
}
},
computed: {
viewTitle() {
const view = this.$appState.designer.activeView;
if (view === 'dashboard') {
return 'Theme Designer';
} else if (view === 'create_theme') {
return 'Create Theme';
} else if (view === 'editor') {
return this.$appState.designer.theme.name;
2024-11-13 10:00:37 +00:00
}
2024-12-26 14:41:51 +00:00
return null;
2024-11-10 19:16:58 +00:00
}
}
};
</script>