primevue-mirror/layouts/doc/codeeditor/index.js

61 lines
2.4 KiB
JavaScript
Raw Normal View History

2023-02-28 08:29:30 +00:00
import sdk from '@stackblitz/sdk';
import { getVueApp } from './templates';
const useCodeSandbox = (language, code, service, extPages, dependencies, component, extFiles) => {
const getSandboxParameters = (sourceType) => {
const { files, dependenciesDemo, sourceFileName } = getVueApp({ code, service, extPages, dependencies, component, extFiles }, sourceType);
files['sandbox.config.json'] = {
content: {
infiniteLoopProtection: false
}
};
return { files, dependenciesDemo, sourceFileName };
};
const sandboxParameters = getSandboxParameters({ language });
fetch('https://codesandbox.io/api/v1/sandboxes/define?json=1', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
Accept: 'application/json'
},
body: JSON.stringify(sandboxParameters)
})
.then((response) => response.json())
.then((data) => window.open(`https://codesandbox.io/s/${data.sandbox_id}`, '_blank'));
};
const useStackBlitz = (language, code, service, extPages, dependencies, component, extFiles) => {
const getStackBlitzParameters = (sourceType) => {
const { files, dependenciesDemo, sourceFileName } = getVueApp({ code, service, extPages, dependencies, component, extFiles }, sourceType);
return { files, dependenciesDemo, sourceFileName };
};
const stackBlitzParameters = getStackBlitzParameters({ language });
let files = {};
Object.entries(stackBlitzParameters.files).forEach(([k, v]) => (files[`${k}`] = typeof v.content === 'object' ? JSON.stringify(v.content, null, 2) : v.content));
sdk.openProject(
{
title: 'PrimeVue Demo',
template: 'node',
description:
'**\n PrimeVue is an open source UI library for Vue featuring a rich set of 90+ components, a theme designer, various theme alternatives such as Material, Bootstrap, Tailwind, premium templates and professional support. In addition, it integrates with PrimeBlock, which has 400+ ready to use UI blocks to build spectacular applications in no time.',
dependencies: stackBlitzParameters.dependencies,
files
},
{
newWindow: true,
openFile: [stackBlitzParameters.sourceFileName]
}
);
};
export { useCodeSandbox, useStackBlitz };