mirror of
https://github.com/pyscript/pyscript.git
synced 2025-12-20 02:37:41 -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>
59 lines
2.2 KiB
TypeScript
59 lines
2.2 KiB
TypeScript
import { getAttribute, addClasses, htmlDecode, ensureUniqueId, createDeprecationWarning } from '../utils';
|
|
import { getLogger } from '../logger';
|
|
import type { Runtime } from '../runtime';
|
|
|
|
const logger = getLogger('py-inputbox');
|
|
|
|
export function make_PyInputBox(runtime: Runtime) {
|
|
class PyInputBox extends HTMLElement {
|
|
widths: string[] = [];
|
|
label: string | undefined = undefined;
|
|
mount_name: string | undefined = undefined;
|
|
code: string;
|
|
|
|
constructor() {
|
|
super();
|
|
|
|
const label = getAttribute(this, 'label');
|
|
if (label) {
|
|
this.label = label;
|
|
}
|
|
}
|
|
|
|
connectedCallback() {
|
|
const deprecationMessage =
|
|
'The element <py-input> is deprecated, ' + 'use <input class="py-input"> instead.';
|
|
createDeprecationWarning(deprecationMessage, 'py-input');
|
|
ensureUniqueId(this);
|
|
this.code = htmlDecode(this.innerHTML);
|
|
this.mount_name = this.id.split('-').join('_');
|
|
this.innerHTML = '';
|
|
|
|
const mainDiv = document.createElement('input');
|
|
mainDiv.type = 'text';
|
|
addClasses(mainDiv, ['py-input']);
|
|
|
|
mainDiv.id = this.id;
|
|
this.id = `${this.id}-container`;
|
|
this.appendChild(mainDiv);
|
|
|
|
// now that we appended and the element is attached, lets connect with the event handlers
|
|
// defined for this widget
|
|
this.appendChild(mainDiv);
|
|
this.code = this.code.split('self').join(this.mount_name);
|
|
let registrationCode = `from pyodide.ffi import create_proxy`;
|
|
registrationCode += `\n${this.mount_name} = Element("${mainDiv.id}")`;
|
|
if (this.code.includes('def on_keypress')) {
|
|
this.code = this.code.replace('def on_keypress', `def on_keypress_${this.mount_name}`);
|
|
registrationCode += `\n${this.mount_name}.element.addEventListener('keypress', create_proxy(on_keypress_${this.mount_name}))`;
|
|
}
|
|
|
|
runtime.runButDontRaise(this.code);
|
|
runtime.runButDontRaise(registrationCode);
|
|
logger.debug('py-inputbox connected');
|
|
}
|
|
}
|
|
|
|
return PyInputBox;
|
|
}
|