Add download option

pull/7024/head
Cagatay Civici 2024-12-28 11:59:21 +03:00
parent 1c7e4f9baf
commit 686eba4ea1
3 changed files with 61 additions and 34 deletions

View File

@ -31,15 +31,24 @@
</template>
<script>
import { $dt } from '@primevue/themes';
import EventBus from '@/app/AppEventBus';
import { $dt, updatePreset } from '@primevue/themes';
export default {
setup() {
const runtimeConfig = useRuntimeConfig();
return {
designerApiBase: runtimeConfig.public.designerApiBase
};
},
provide() {
return {
designerService: {
refreshACTokens: this.refreshACTokens,
saveTheme: this.saveTheme,
downloadTheme: this.downloadTheme
downloadTheme: this.downloadTheme,
applyTheme: this.applyTheme
}
};
},
@ -55,8 +64,49 @@ export default {
onHide() {
this.deferredTabs = true;
},
downloadTheme(theme) {
// TODO: Fetch from endpoint
async downloadTheme(theme) {
try {
const response = await $fetch(this.designerApiBase + '/theme/download/' + this.$appState.designer.licenseKey + '/' + theme.t_key, {
responseType: 'blob'
});
if (response.error) {
this.$toast.add({ severity: 'error', summary: 'An Error Occurred', detail: error.message, life: 3000 });
} else {
const blobUrl = window.URL.createObjectURL(response);
const link = document.createElement('a');
link.href = blobUrl;
link.download = theme.t_name + '.zip';
document.body.appendChild(link);
link.click();
document.body.removeChild(link);
window.URL.revokeObjectURL(blobUrl);
}
} catch (err) {
console.log(err);
this.$toast.add({ severity: 'error', summary: 'An Error Occurred', detail: 'Failed to download file', life: 3000 });
}
},
async updateTheme(theme) {
const { error } = await $fetch(this.designerApiBase + '/theme/update', {
method: 'POST',
body: {
key: theme.key,
preset: theme.preset,
config: theme.config,
license_key: this.$appState.designer.licenseKey
}
});
if (error) {
this.$toast.add({ severity: 'error', summary: 'An error occured', detail: error.message, life: 3000 });
}
},
applyTheme(theme) {
this.updateTheme(theme);
updatePreset(theme.preset);
EventBus.emit('theme-palette-change');
},
camelCaseToDotCase(name) {
return name.replace(/([a-z])([A-Z])/g, '$1.$2').toLowerCase();

View File

@ -77,10 +77,11 @@ export default {
default: true
}
},
inject: ['designerService'],
methods: {
onKeyDown(event) {
if (event.code === 'Enter' || event.code === 'NumpadEnter') {
this.apply();
this.designerService.applyTheme(this.$appState.designer.theme);
event.preventDefault();
}
}

View File

@ -20,41 +20,17 @@
</template>
<script>
import EventBus from '@/app/AppEventBus';
import { updatePreset } from '@primevue/themes';
export default {
setup() {
const runtimeConfig = useRuntimeConfig();
return {
designerApiBase: runtimeConfig.public.designerApiBase
};
},
inject: ['designerService'],
methods: {
download() {
this.designerService.downloadTheme(this.$appState.desiger.theme);
this.designerService.downloadTheme({
t_key: this.$appState.designer.theme.key,
t_name: this.$appState.designer.theme.name
});
},
apply() {
this.updateTheme();
updatePreset(this.$appState.designer.theme.preset);
EventBus.emit('theme-palette-change');
},
async updateTheme() {
const { error } = await $fetch(this.designerApiBase + '/theme/update', {
method: 'POST',
body: {
key: this.$appState.designer.theme.key,
preset: this.$appState.designer.theme.preset,
config: this.$appState.designer.theme.config,
license_key: this.$appState.designer.licenseKey
}
});
if (error) {
this.$toast.add({ severity: 'error', summary: 'An error occured', detail: error.message, life: 3000 });
}
this.designerService.applyTheme(this.$appState.designer.theme);
}
}
};