mirror of
https://github.com/pyscript/pyscript.git
synced 2025-12-19 18:27:29 -05:00
* add test and example files * update config to include python plugins in build * add markdown plugin * remove full pyscript execution from pyodide * move loading of pyscript.py from pyodide loagInterpreter to main setupVirtualEnv and add function to create python CE plugins * add plugin class to pyscript.py * add missing import * fix plugin path * add fetchPythonPlugins to PyScriptApp * remove old comments * fix test * add support for python plugins beyond custom elements and add app to python namespace in main * inject reference to PyScript app onto python plugins * add example hook onto markdown plugin * change plugin events logs * remove unused PyPlugin * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * fix type import * add docstring to fetchPythonPlugins * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * rename addPythonPlugin method * address PR comment * call python plugins on hooks after the interpreted is ready * add test for event hooks and split the test in 2 separate plugins to isolte type of plugins tests * change python plugins initialization and registration, to inject the app from app itself instead of on the plugins themselves * handle case when plugin cannot load due to missing plugin attribute * add test for fail scenario when a plugin module does not have a plugin attribute * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * add deprecation warning for pyscript objects loaded in global namespace * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * remove all from global scope * remove create_custom_element from global scope * rename create_custom_element to define_custom_element * rename attributes in define_custom_element and add docstrings * better handle connect event output * add warning to py_markdown plugin * remove debugging logs * improve tests * remove debugging log * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * remove unused import * add executable shebang * add pyodide mock module * fmt and lint * Update to pyodide.ffi.create_proxy per pyodide v21 api change * Mock pyodide as package instead of mdoule * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * add __init__ to pyodide package * Update pyscriptjs/src/plugin.ts fix logger name Co-authored-by: Antonio Cuni <anto.cuni@gmail.com> * fix pyodide import but handling the diff in their API change * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * oops, conflict resolution blooper * Fix failing integration tests Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> Co-authored-by: Jeff Glass <glass.jeffrey@gmail.com> Co-authored-by: Antonio Cuni <anto.cuni@gmail.com> Co-authored-by: FabioRosado <fabiorosado@outlook.com>
69 lines
1.7 KiB
JavaScript
69 lines
1.7 KiB
JavaScript
import commonjs from "@rollup/plugin-commonjs";
|
|
import resolve from "@rollup/plugin-node-resolve";
|
|
import { terser } from "rollup-plugin-terser";
|
|
import legacy from '@rollup/plugin-legacy';
|
|
import typescript from "@rollup/plugin-typescript";
|
|
import css from "rollup-plugin-css-only";
|
|
import serve from "rollup-plugin-serve";
|
|
import { string } from "rollup-plugin-string";
|
|
import copy from 'rollup-plugin-copy'
|
|
|
|
const production = !process.env.ROLLUP_WATCH || (process.env.NODE_ENV === "production");
|
|
|
|
const copy_targets = {
|
|
targets: [
|
|
{ src: 'public/index.html', dest: 'build' },
|
|
{ src: 'src/plugins/*', dest: 'build/plugins' }
|
|
]
|
|
}
|
|
|
|
if( !production ){
|
|
copy_targets.targets.push({ src: 'build/*', dest: 'examples/build' })
|
|
}
|
|
|
|
export default {
|
|
input: "src/main.ts",
|
|
output:[
|
|
{
|
|
sourcemap: true,
|
|
format: "iife",
|
|
inlineDynamicImports: true,
|
|
name: "pyscript",
|
|
file: "build/pyscript.js",
|
|
},
|
|
{
|
|
file: "build/pyscript.min.js",
|
|
format: "iife",
|
|
sourcemap: true,
|
|
inlineDynamicImports: true,
|
|
plugins: [terser()],
|
|
},
|
|
],
|
|
plugins: [
|
|
css({ output: "pyscript.css" }),
|
|
// Bundle all the Python files into the output file
|
|
string({
|
|
include: "./src/**/*.py",
|
|
}),
|
|
legacy({ 'src/toml.js': 'toml' }),
|
|
resolve({
|
|
browser: true,
|
|
}),
|
|
commonjs(),
|
|
typescript({
|
|
sourceMap: !production,
|
|
inlineSources: !production,
|
|
}),
|
|
// This will make sure that examples will always get the latest build folder
|
|
copy(copy_targets),
|
|
// production && terser(),
|
|
!production && serve({
|
|
port: 8080,
|
|
contentBase: 'examples'}
|
|
)
|
|
],
|
|
watch: {
|
|
clearScreen: false,
|
|
},
|
|
};
|