import "module"
->import "module.js"
substitution fix;- Fix of https://sciter.com/forums/topic/style-set-specificity-breaking-change/ ;
- [reactor]
<div state-html={...} />
update optimization; - [CSS]
attr(window-frame): "...";
fix;
-
[globalThis.]evalModule("module text");
- likeeval("text")
but "module text" is parsed by module rules;
-
- [virtual-list]
scrollBy(deltay)
method;
- [virtual-list]
<input|time no-seconds />
fix.- fix of positioned double painting: https://sciter.com/forums/topic/problem-with-4-4-8-30/
parseValue()
support of BigInt's- SDK sdk[.js]/include/value.h VALUE::T_CURRENCY is renamed to VALUE::T_BIG_INT - that allows to pass int64 from native code to JS as BigInt value.
- [windows] fix of 1px border around maximized window;
- [macos] navigation shortcuts (CMD+LEFT/RIGHT, OPTION+UP/DOWN etc.)
- behavior:selection fix;
- Skia backend, fix of bitmap_graphics, text rendering.
flow:horizontal;
layout fix;@media width > 600px {...}
;
- new sample samples.sciter/immediate-mode-painting/pie-chart.htm - circular progress indicator. Demonstrates use of units with Graphics;
- [JS++]fix of angle literals parsing, like const s = 90deg;
- [MacOS] fix of
doubleclick
andtripleclick
event generation; - [MacOS] fix of AV in spellcheck functionality;
- [a11y] fix of aria-labeledby handling;
- [CSS] fix of rules application ordering;
Sciter.parseValue()
fix of error generation on erroneous inputs;
-
JS extended by Length, Duration and Angle units.
ES2017 introduced numbers with units already, like BigInt:
const maxSafeInteger = 9007199254740991n;
This version adds more number units:
- lengths:
100px
,12pt
,1em
, ... - durations:
20ms
,2s
- angles:
90deg
,0.5rad
,1turn
, ...
- lengths:
-
sciter.parseValue(string): any
That's "JSON++" parser - parses the string using JSON extended by CSS syntax rules, this is valid JSON++ format:
// Note: comments are supported in JSON++: { date: 2020-10-11; // date literal width: 200px; // length literal; number: 42; // guess what? // Note: names may have '-' in them array-plain: [1,2,3,4]; // plain JS array array-list: 1 2 3 4, 5 6 7 8; // JS [[1,2,3,4],[5,6,7,8]] // name tokens are parsed to strings: foo: incredible; // JSON eq. "foo": "incredible" }
-
Event.platformKeyCode
- reports native key code like wParam in WM_KEYDOWN on Windows. -
physicalDevicePixelRatio
- [MacOS] "retina" pixel ratio, on other platforms it is1
.
- z-index handling fix.
<input|number>
layout fix.- Regression fix of "preventing secondary style loading from the same url".
progresss.setAttribute()
fix;- Fix of AV in frame deletion while loading.
- Fix of window alignment on multihome systems with different scale factors.
-
css selectors:
:last-of-type
,:first-of-type
,:only-of-type
-
[JS] implementation of
-
console.assert(expr,fmt, ...)
console.assert(expr,{fields...})
Note that in Sciter
console.assert
throws error if expr is falsy - in browsers console.assert() just prints stuff to console. -
- sdk.js/widgets/tabs/ sample - that
<tabs>
thing.
- sdk.js/widgets/tabs/ sample - that
-
Experimental support of system menus:
<menu role="window-menu"> <li>File <menu> <li accesskey="^N">New</li> <li accesskey="^O">Open</li> <hr/> <li accesskey="Q">Quit</li> </menu> </li> ... </menu>
On Windows this creates native menu bar in the window. On MacOS it populates application menu bar. On Linux - not ready yet.
Note for window-frame != "standard" the menu is invisible but still makes sense as global hotkeys table.
For the demo see integration project in SDK.
-
include/sciter-x-key-codes.h - list of key codes that are coming to KEY_DOWN/KEY_UP events.
NOTE: that can be a breaking change if you use platform dependent key codes (like
VK_ENTER
on Windows) in your code.
- Fix of
KeyboardEvent.code
values to generaly match W3C specification; - Fix of functions taking varargs, like
@env.exec(...)
,printf(fmt,...)
and others; - Fix of mouse reactivity in regard
:hover
styles. - Fix of stack overflow in style-set: "..." applying roots with appearance:none.
- Fix of position:relative inside position:absolute, see: https://sciter.com/forums/topic/css-position-issue/
-
- support of CSS selectors
:only-of-type
,first-of-type
andlast-of-type
;
- support of CSS selectors
- regression fixes of
@env.exec()
andelement.classList.add/remove()
; :hover
style reactivity on mouse moves;
Maintainance build: use of latest libjpeg, libwebp, libuv. This closes 32 CVEs found in those libraries.
-
Virtual desktops/spaces support:
- Window event spacechange is sent to the window when space / virtual desktop changes/ Use
window.on("spacechange",handler)
to subscribe to that event. window.isOnActiveSpace
property. true if the window is on active space and false otherwise.- sample: /samples.sciter/window/virtual-spaces.htm
- Window event spacechange is sent to the window when space / virtual desktop changes/ Use
-
[CSS]
attr(name): value;
attribute-property declaration. This allows to define default values of DOM attributes in CSS. Example:input|number { attr(min):0; attr(max):100; attr(step):1 }
-
sdk.js/samples.sciter/unit-test - unit test framework, modelled after JEST.
Initial implementation, to be extended and documented. -
[reactor/JSX] Support of inline style definitions
<div style={obj}>
. see. -
[SDK/API]
HANDLE_ATTRIBUTE_CHANGE
event_handler callback:virtual void event_handler::handle_attribute_change(HELEMENT he, ATTRIBUTE_CHANGE_PARAMS& params) { return on_attribute_change(he, params.name, params.value); }
Useful in cases when Reactor manages elements with custom behaviors.
componentWillUnmount()
is coming whileelement.parentElement
is still valid.- [macosx] frequent click events generation fix.
- Fix of
:popup
style application, see issue. - Fix of initial window position if it is defined in
SciterCreateWindow()
. - Fix of scrollbar dpi issue.
- Sciter's animated scroll-indicator is back.
- Preventing multiple loading of the same CSS file.
- [windows] mouse-enter/leave on popup menus fix.
- [CSS] Fix of
position:absolute
positioning withz-index
. see. - Fix of arrays handling in
xcall("...",)
SciterSetVariable()
andSciterGetVariable()
API implementation.SciterSetVariable()
function allows to initialize variables in global JS context of documents.sciter.decode(..., "utf-16le/be")
support.- window-mixin integration demo - demonstrates mixin Sciter integration.
- "Script injects" :
static void set_init_script(const char* utf8z_js) { SBOOL r = SciterSetOption(NULL, SCITER_SET_INIT_SCRIPT, UINT_PTR(utf8z_js)); assert(r); (void)r; }
usciter.exe -o filename.htm
fix.scapp.exe
style fixes.- [inspector] fix of frame content inspection.
- [inspector] reporting initialization errors.
- [DOM]
Element.elementFromPoint(x,y)
- find element by coordinates and so - [DOM]
Document.elementFromPoint(x,y)
is also available.
- Fix of window creation sequence.
- Fix
form.value
to collect only named (having name attribute defined) fields (used to be id's too). - Fix
form.value
to collect custom elements withvalue
property defined. - [integration] Disabling
SetErrorMode(SEM_FAILCRITICALERRORS | SEM_NOGPFAULTERRORBOX | SEM_NOOPENFILEERRORBOX);
in libuv that prevents dump collection on app level. - [graphics] Fix of
graphics.pushLayer("...area...")
geometry calculation. - [Audio] fix of AV after
stop()
call.
- [css] flow:horizontal, percent calculation in children;
- fix of potential av in htmlarea drag operation;
- [macos] fix of AV on window closing;
- [macos] fix of operation on versions of MacOS prior 10.14;
<input|number>
rendering optimization;- [rtl]
<input>
,<plaintext>
CTRL|SHIFT directionality switch; - Support of
sciter::value::make_error("text")
to rise errors from native code; behavior:form
/<form>
, element.value fix;- scapp.exe, cmdline parameters handling fix;
- generalization of initial window pos and size;
- [JS/DOM]
styleElement.innerText = "...."
to update CSS rules in<style>
elements; - [hyperlink] fix of NUMPAD-ENTER handling;
- [JS/DOM] fix of Event.eventPhase / AT_TARGET;
- [JS/DOM] fix of erroneous
Window.this
value afterWindow.this.load(...)
call.
- enable multiple handlers on sizechange and visualstatechange events:
document.on("sizechange",function(){}); document.on("visualstatechange",function(){});
- [macosx] IME regression fix;
- [css]
@media ... {}
handling fix inside style sets; - [reactor] attribute
checked
andstate-checked
are interchangeable; - [macosx] light/dark theme switch event, regression fix;
- event "close" on window objects;
behavior:video-coordinator
- orchestrates multiple<video>
to be rendering in sync to minimize CPU load.- Code linting ports by David Monbaron: /samples.sciter/code-linting
- [macOS] generation of event
mediachange
on Window.this when light/dark theme is applied.
- [rtl] fix of
input|checkbox
andinput|radio
; - [rtl] fix of
input|hslider
; - [rtl] fix of
input|number
,select|dropdown editable
- [css,js] aspect loading fix in context of scapp;
- [macOS] internal BGRA format enforced on MacOS too.
- usciter[exe/app] dark/light theme handling refactoring.
- fetch API:
options.downloadProgress(loaded,total)
- download progress callback.
- [JSX] fix of
disabled={true|false}
attribute handling. componentDidMount
/componentWillUnmount
fix for css::prototype definitions.- Fix of loading document in frame.
- [macos] performance fixes in video rendering.
- [macos] window level fix for dialogs.
- Environment variable SCAPP-DEBUG=ON to enable sciter debugger in scapp and custom applications. Same as explicit
--debug
argument. window.modal()
returnsundefined
if the dialog is closed by "X" window button.Window.this.modal(<alert resizable=true>...</alert>)
to enable resizable dialog.- Fix of memory leak in
sciter::value::operator["key"|index]
- Fix of threading issue in sciter::value, see: https://sciter.com/forums/topic/an-access-violation-occurred-while-reading-position-0x0000002c/
- JSX: - to call NS.Comp component (fully qualified names).
- [css] +
:window-root
selector - matches only root DOM element that is loaded into window directly. elem.state.flow
property - reports CSS flow manager used on the element.SciterSetOption(NULL,SCITER_SET_INIT_SCRIPT, (UINT_PTR) "/* JS module here */" )
- support of script injects.
- Fix of
Clipboard.writeText("...")
, see: https://sciter.com/forums/topic/clipboard-write-bug/ - ACRYLIC_BLURBEHIND is disabled again - too many problems, for example: https://sciter.com/forums/topic/memory-leak/, Sciter still provides blurbehind but less blurry that acrylic.
- [osx] better handling of
window.isEnabled
. - [virtual-list]
vlist.navigateTo(v)
andvlist.advanceTo(n)
fixes. - fix of custom scrollbar styling.
NOTE: that is probaly the last release of 4.4.x.x series.
Next releases will switch to latest Skia version that enables Vulkan (Linux, Windows) and DirectX 12 (Windows) backends.
Most of the changes will be on Linux: I am dropping use of GTK - Sciter will be purely X Window based.
Default backends on Linux will be: Vulkan -> OpenGL -> Raster with Skia graphics (no Cairo anymore).
- [virtual-list] better scrollbar handling - less "jumpy".
- [i18n]:
let str = @"to translate"
- translatable string literals./*@context for translation*/
- translation context, see documentation.
-
- sdk.js/samples.app/classic - application template / prototype.
- sciter.dll is not using uxtheme.dll on Windows anymore. Internal "theme:" URL scheme handling is disabled;
- [osx] fix of loading files that contain non-trivial unicode characters;
- [osx] compatibility with 10.13;
- [osx] behavior:shell-icon fix;
- [osx] CoreGraphics backend regression fix;
Window.this.modal(<alert caption="Bar">Foo</alert>)
, @caption fix.<input|slider min>
handling fix.<include></include>
pair parsing fix.<select>
click handling fix.- [windows]
@media high-contrast {...}
handling fix.
- [C++ api] + window::eval();
- [C++ api] +
sciter::window::close()
to force window closure. Alsosciter::window::request_close()
- [integration] demos of call_function() and call_method();
SciterLoadFile()
, support paths starting "./" and "../" - to open resources relative to CWD (whatever it means);
- scrolling / animated scrolling: "overscroll" feature and touch specific functionality are disabled for now, more problems than solutions;
- [css] fix of
*
selector specificity handling; - [reactor]
element.patch()
refactoring , speed up and better support of fragments; - [MacOS] fullscreen fix;
- [MacOS]
window.move(...)
1px offset fixed; - [MacOS] fix of window closure delay;
- [MacOS] fix of role="window-caption" handling in custom frames;
- [win] scapp.exe + productDescription (David's patch);
Graphics.strokeRect()
fix;- [inspector] fix of second instance detection handling;
- Fix of mem-leak alike timers pileup, see: https://sciter.com/forums/topic/serious-memory-leak-that-leads-to-frequent-crashes-reproducible/ ;
- Fix of popup closure: https://sciter.com/forums/topic/there-are-multiple-elements-on-the-page/ ;
Graphics.draw(element)
, see: sdk.js/samples.sciter/immediate-mode-painting/draw-element.htm- [inspector] eval runs in context of 'this' that is set to current selected element.
- win7 compatibility of usciter.exe, inspector.exe, etc. Note window-blurbehind works now on Win10 and above;
- graphics.clearRect() fix on MacOS;
sciter::value::call(...)
fix of error string generation.- [MacOS] font ascent / descent calculation fix.
- [MacOS] fix of "missed idle events" bug that may manifset in non responsive UI.
<toggle disabled>
styling fix.- [JS]
event.button
fix, see: https://sciter.com/forums/topic/bug-with-the-evt-button-processing-in-sciterjs/
- [Windows] acrylic blur behind is back.
Window.send(event)
- send event synchronously to all windows.Window.share : object
- data shared among all windows and documents - application wide data container.<select|dropdown>
:novalue
is back- event
change
on<select editable>
:evt.source
is either<caption>
or<option>
that caused the change;
- sdk.js/widgets/tag-list component.
env.exec(...)
fix. See: https://sciter.com/forums/topic/call-executable-with-args/#post-74647- fix of
overflow:scroll;
handling, see: https://sciter.com/forums/topic/scroll-function-will-freeze/ - event "change" from
<input|date>
; - [reactor] reconciliation / focus fix;
- Reactor namespace - high-level Reactor API functions.
- [css] role property, allows to define element role in CSS:
tr { role:"option"; } header { role:"window-caption"; }
- [JS]
sciter.import("module")
- sync version ofimport("module")
JS built-in; element.animate(stepFn, {FPS:30})
to cap animation callback frequency;<input type=slider>
fix of "change" event generation;
- CommonJS modules support,
require()
function implementation: sdk.js/samples/commonJS; <html disable-debug="true" >
to disable connection with inspector.- [css]
var(--somename,#F00)
andvar(somename,#F00)
are equivalents now.
<select|dropdown editable placeholder="...">
fix.- [Win,a11y] fix of accName reporting if it was redefined by CSS content:"new text".
- [MacOS] fix of minimizable/maximizable button appearance.
Window.this.modal
styling;- [MacOS] better painting;
- [MacOS] fix of layered windows (window-frame=transparent) update.
- [MacOS] date.toLocaleDateTimeString() fixes;
- [Win] Fix of
Clipboard.write(...)
- cleans clipboard first. - JS, better error reporting on erroneous modules.
- Skia backend fix that prevents re-entrant engine creation, affects Sciter.Lite on all platforms and Sciter on MacOS.
document.on("beforeunload", function() { console.log("xxx") })
fix.
- JSX built-in internalization / translation support. Works with Reactor, ReactJS, PReact, Mithril - all libraries that provide JSX driver.
debug.callStackAt(level)
method, see: https://sciter.com/forums/topic/get-js-function-name-within-function/Event.keyState("A"):boolean
- is key "A" pressed or not at the moment?
slider.max
property handling fix.SciterSetValue
/SciterGetValue
to obey propertyvalue
defined in script.behavior:menu-bar
, keyboard operation fix.
Audio.stop()
fix to stop async operation;- [reactor] fix of fragment handling;
Storage.Index.delete(key)
implementation;element.off(".ns")
fix (unsubscribe by namespace);- [MacOS] fix of
Clipboard.write({...})
;
Audio.stop()
method.
- various regression fixes;
- fix of
element.getElementById()
, see: https://sciter.com/forums/topic/getelementbyid-return-null-after-refresh-div-list/ ; - fix of possible AV in textarea;
- [Skia backend], fix of possible deadlock on rendering;
- fix of
element.onsizechange()
callback generation in components; sys.fs.splitpath()
fixes;new Image(painter)
andImage.update(painter)
fixes;Graphics.ellipse()
fix;Graphics.pushLayer(x,y,w,h,filter)
fix;- CSS/painting, fix of text-decoration and selection painting;
element.append/perpend(<fragment>...</fragment>)
fix;sys.fs.match(filename,pattern)
fix of string leak;- VALUE API fix, correct coercion to T_BYTES in
nativeFunc(new ArrayBuffer(...))
; Graphics.pushLayer("border-box")
generates error when Image based Graphics is used.- [reactor]
.componentDidCatch(error,contextElement/*performing patch()*/)
- processing errors in render() methods (ReactJS notation);
window.requestAttention("info" | "alert" | "stop")
- app icon blinking on OSes that support that (Windows, MacOS);- JSX: <Foo {...props} /> support. See: https://sciter.com/forums/topic/react-spread-attributes/
- [SQLite] + recordset.field("name") method. See: https://sciter.com/forums/topic/name-can-not-be-used-as-column-name-of-sqlite/
- [reactor] - warning if incompatible (non string convertible) value is passed.
- [JSX] fragment support using notation
<>...</>
, see: https://reactjs.org/docs/fragments.html#short-syntax
- element.post() fix, see: https://sciter.com/forums/topic/virtual-list-vlist-navigate-issue/
- WM_INPUT handling fix (might causing non-handled exceptions);
- Windows: UIAutomation support is back, but requres SciterSetOption(NULL,SCITER_ENABLE_UIAUTOMATION,TRUE);
- env.home(path) - returns normalized path - without "..";
- flow:stack fix.
- VirtualSelect/VirtualList fix of the issue: https://sciter.com/forums/topic/virtual-list-vlist-navigate-issue/#post-73783
- reactor: fix of handling
(name)
as key in r13n; - Tokenizer: fix of freeze on EOI marker;
- [JSX] better errors handling.
- fix of freeze in video rendering + behavior:file-icon/shell-icon;
- [CSS/JS]
prototype: Component
, fix of private fields handling; - "on click at :root" handling fix;
- Fix of hanging on
::after { position:absolute }
rules; - Fix of script debugger in x64 versions;
element.matches("selector")
/element.$is("selector")
- API:
SciterEvalElementScript()
implementation for JS; Element.animate(options,onEnd)
- non-promise version;element.mapLocalToWindow(x,y)
andelement.mapWindowToLocal(x,y)
element.swapWith(otherElement)
image.colorAt(x,y): Color
image.compose(other, op)
overflow:scroll
, fix of non-overflow SB rendering.- [debugging] drain logs (a.k.a. flush) before document unload. See: https://sciter.com/forums/topic/wait-for-closerequest-function-calls-to-complete/
- leaflet.js compatibility fix, by adding document.createElementNS();
- command event
"^exec:***"
handling fix; - [VirtualList] fix of
render()
; - [websocket] fix of AV in
new WebSocket("badaddr")
; Clipboard.has("image"|"file"|"text")
- check if clipboard has needed data;self
- yet another alias to current namespace (self == globalThis
)- fix of splitter handling in Sciter.Lite.
- fix of element.click() event click generation.
- samples/compatibility.js/.css - compatibility layer for browsers. Not complete, features will be added when required;
- samples/leaflet/test-geoJSON.htm sample - demo of layers in leaflet;
<select|list treelines>
rendering;- leaflet.js compatibility fix;
- Fix of
<select|dropdown multiple>
- Fix of
Audio.resume()
- Fix of https://sciter.com/forums/topic/wrong-style-attribute-in-reactor-when-new-element-has-the-same-tag/ in Sciter.TIS and .JS
- Sciter.JS: events "change" (synchronous) and "input" (posted, asynchronous) are distinct now.
- [virtual-list] + scroll-manner: scroll-manner(animation:false); //to disable animated scroll
- fix of divide by zero in esoteric situation of zero sized window.
- sdk.js/samples.sciter/virtual-list/virtual-multi-column.htm sample.
- inspector exe fix to show real DOM structure;
- [osx] fix of ligatures handling in inputs;
- [osx] fix of transparent windows handling;
- [virtual-list] fix of scrollable table;
- [DOM] ===
- lottie playback API and samples in samples.sciter/lottie/
Window.this.monitor:int
- reports monitor index this window is on;Window.monitors:int
- number of screens/monitors;
- [JSX] fix of
<div tabindex state-selected={selected}>
parsing. - [API/SOM] integration.exe, test of const methods.
- fix of Color values passing to built-in methods.
-
new Graphics.Image(w,h,painter(gfx))
- generation of image by painting on it. -
Window.this.screen:int
- reports monitor index this window is on; -
Window.screens:int
- number of screens/monitors; -
Window.screenBox(N, "devicePixelRatio")
- reports dip/ppx ratio on Nth monitor; -
New
EDIT_VALUE_CHANGE
event (JS: "change"). Sequence now:EDIT_VALUE_CHANGING
(JS: "changing") - before changes, sync event;EDIT_VALUE_CHANGE
(JS: "change") - immediately after changes but before screen update, sync event;EDIT_VALUE_CHANGED
(JS: "input") - after changes, after screen update, async/posted event.behavior:video
->VIDEO_FRAME_REQUEST
event (a.k.a. animation frame)element.state.pixelsIn("1em")
- method to convert CSS length units to CSS pixels.- [DOM] attribute "selectable" - enables "HTML range selection" and copying on given element.
- new sample sdk.js/samples.sciter/menu/custom-shape-menu.htm
- SDK headers reorganization: sciter-x-primitives.h - non-GUI primitive types;
- fix of console.log() interaction with inspector;
placeholder
runtime change fix;- [CSS]
html:owns-focus
flag on active window; - [js] persistence fixes;
- virtual-list mouse hover fix;
- fix of mouse-over-scrollbar issue, see: https://sciter.com/forums/topic/sciter-scroll-popup-issue/
event.windowX/Y
are in CSS pixels (dips) now.- color to string conversion fix.
- fix of behavior:virtual-list samples.
- [osx] window update fix on MacOS Mojave.
- websocket events notification fix.
- [css] rgba(255,255,255,var(opacity)) - rgb() and rgba() may use variables now.
window-state="hidden" | "shown" | "minimized" | "maximized" | "full-screen"
attribute support on HTML element element. This attribute defines initial state of the window.
- element.append/insert/children fixes;
element.takeOff(...)
parameters are in dips (CSS pixels);- fix of cascaded css vars;
element.componentDidMount()
invocation fix;- behavior:pager fix of AV.
- [Storage] fixes.
- [reactor]
this(props,kids)
method in reactive components, a.k.a Reactor's constructor. - components, support of
>
in event handling selectors "on click at >child" to match immediate child ofthis
.
- [css variables] fix of variable value resolving in cascaded rules.
- [vue|preact] compatibility, element.checked property.
- Fix of AV in timer in some cases.
fetch()
, allow use of relative URLs.- [virtual-list] first|lastVisibleItem, fix of AV on empty list.
- [virtual-list] touchpad scrolling fix on MacOS.
- fix of sdk.js/samples.sciter/drag-n-drop/simplest.htm demo.
- inspector fix.
- element.innerHTML fix.
- [css] + support of + general sibling combinator (
~
):p ~ span { color: red; }
behavior:hyperlink
support oftarget="@system"
attribute to open link in system's default application (default browser for example) rather than Sciter.- [module sciter], new functions
sciter.compress()
sciter.decompress()
sciter.toBase64()
sciter.fromBase64()
sciter.md5()
sciter.crc32()
devicePixelRatio
fix.
- CSS variables:
- now support all types of values (used to be just lengths and colors);
- Sciter supports as its own
var(name)
as standard--name
variable declarations. See /samples.css/css-variables;
- [html-window] window-min-width/height, window-max-width/height attributes.
- [css] svg image used as background/foreground image inherits stroke, fill colors and set of CSS variables of element where it is applied.
- zepto patch for mouseenter/mouseleave to work in Sciter. Sciter supports mouseenter/leave events but not mouseove/out.
- [JS DOM API] fix of <select|dropdown> handling, os it is compatible now with Mithril/PReact, Vue, etc.;
- dispatchEvent preventing recursive call;
- virtual-list fixes;
- [QuickJS]
getTimezoneOffset()
implementation for Windows so Date reports values properly.
-
highlightion API, new methods:
range.marks()
range.setToMark(name)
element.rangeFromPoint(x,y)
See /samples.sciter/editor-plaintext/highlighting-marks.htm
-
fetch()
API - POSTing JSON and other textual or binary data; -
sdk.js/samples.sciter/reactor-form/ - forms handling in reactor, inspired by Formik/ReactJS;
-
SDK headers: SOM_PROP_EX + SOM_RO_PROP_EX
- fix of window.close(val) for main window;
- virtual-list scroll fixes;
- fix of css::prototype and JS subclassing;
- optimiziation of
<img src="....svg">
handling;
- new global functions:
decode(arraybuffer,encoding): string
, character encoding/decodingencode(string,encoding): arraybuffer
btoa(arraybuffer): string
- Base64 encoding/decodingatob(string): arraybuffer
element.popup(element | vnode,options)
- popup generalization. This makes element.popupAt/For() functions obsolete;element.animate(stepfunc,options)
- another mode of animate function.element.state.occluded
- reports occlusion state of the element (partial or full invisibility);Window.elementAt(screenX,screenY)
- find DOM element by screen coordinates;- [reactor] + reactor-routing sample;
- sdk.js/samples.sciter/input-elements-styling - custom styling demos;
- sdk.js/samples.sciter/menu - menu samples;
- fix of
element.onmouseXXXX()
handlers; - [reactor] tunelling key attribute;
- scroll, 1ppx extra fix;
- [virtual-list] initialization fix;
- [css] fix of
currentcolor
handling; - [dom] fix of
element.attributes["style"] = ...
updates (memory consumption);
- Clipboard support;
- `clearInterval()`` fix, see: https://sciter.com/forums/topic/calling-clearinterval-inside-setinterval-has-no-effect/
- [zepto.js] compatibility, element.style.cssText prop support;
- behavior: virtual-list fixes;
element.animate()
- various animation effects;element.takeOff()
- "airborn" DOM elements - replaced outside of host window;element.popupFor()
- showing popup elements using this one as anchor;node.parentWindow
- window that hosts this node;Window.this.parent
- parent window of this one;- events "closerequest", "beforeunload", "close" on Window.this contain event.data of window.close(data) call;
- [svg] SVG images used as back/foreground images inherit CSS variables from host document. This allows change colors/lengths from CSS of host document, see: samples.sciter/svg-icons demo.
- [virtual-list] fix on initialization sequence: samples.sciter/virtual-list/test-table.htm
- [reactor]
render([props,kids])
- props and kids are not provided when rendering is don in response ofthis.componentUpdate()
; - [reactor] fix of attribute "value" handling;
- graphics, path images, proper handling of repeat-x, repeat-y;
- http client, support of "content-type" override;
- Window's "size" event is generated after window size change but before DOM layout - can be used in cases when DOM needs to be changed in response of window size changing.
-
[windows] new demo sdk.js/demos/windows-directx demo project, demonstrates
- mixin style of Sciter integration;
- use of Sciter on DirectX windows;
-
behavior:video
, "assetified", documented and sampled, see: sdk.js/samples.sciter/video/ -
printf(format, ...): string
- C-styleprintf()
as a global function. -
scanf(format, str): [...]
- C-stylescanf()
as a global function. -
fetch()
refactoring:- Request/Response split;
- samples/fetch(AJAX)/test-upload.htm - test of file upload
-
transactional updates in <plaintext> , see samples.sciter/editor-plaintext/transactional-update.htm
- fix of
element.innerText
for elements with behaviors. - fix of AV in window event handlers - Window.this.on("...", function) - automatic un-subscription of subscribed documents.
- fix in
element.selection.setBaseAndExtent()
- offsets normalization. - fix of asset methods calling in external behaviors.
- Implementation of missed
sciter::dom::element::call_method(...)
,sciter::dom::element::call_function(...)
- [behavior:richtext and behavior:plaintext] method `richtext|plaintex.update(function(tctx){})`` - transactional updates.
- [sdk, C++ headers] sciter::vfunc() was replaced by sciter::value() constructors;
- fix of sys.fs.$readfile(), was not closing the file properly;
- [reactor.js] reconciliation fix.
- fix of issues in behavior:virtual-list;
- [css] fix of max-width handling;
- fix of https://sciter.com/forums/topic/svg-does-not-render-until-hover/
- fix of https://sciter.com/forums/topic/widthmax-intrinsic-bug-on-hover/
- css: horizontal-align / flow:vertical combination fix.
<select>
uses@as="string"
by default in Sciter.JS.- fix of https://sciter.com/forums/topic/aspect/
Unified API: ISciterAPI uses the same structure (list of functions) on all platforms and variants (Sciter and Sciter.Lite). Functions that are not available on particular platform/variant are set to NULL.
Note: that is breaking change for Rust/Go/Python/C# wrappers - they need to be updated.
- fix of scrollable rendering;
- [select|dropdown] fix of first item set when @novalue is used.
- [drawing] fix of position:absolute / outline drawing.
- behavior:virtual-list; fix of https://sciter.com/forums/topic/bug-scroll-indicator-not-work/
Windows.this.performDrag()
- initiates Drag-n-Drop from your code side. This way you can support dragging of text,html,files,JSON from your application to outside. + D&D samples in samples.sciter/drag-n-drop-system/
- fix of scrollables rendering;
- [Sciter.JS/SDK] `value::date()`` conversion fix.
behavior:virtual-list
fix of first/lastVisibleElement properties.- more docs on behaviors (still not complete but closer).
[Sciter.API] Sciter and Sciter.Lite use the same struct SciterAPI {} so non-C++ language wrappers can be used as for Sciter as for Sciter.Lite. Functions that are not available in Sciter.Lite are just NULLs in SciterAPI struct.
- , more Reactor friendly.
- [inspector] breakpoint handling fixes.
- support of element.onsizechange = function(){}
- element.style.setCursor(image) - set custom cursor.
- Linux/iot/arm32 - Sciter.JS.Lite for Raspberry Pi.
- [scrollable] 1px off at last position.
- [inspector.js] enabling F5...F11 shortcuts in debugger.
- [inspector.js/debug] more reliable debug output in frames.
- [Sciter.JS]
input.value = null
support. - [behavior:calendar] $(input).calendar.mode = "months"; or <input|calendar mode="months" />
- [behavior:virtual-list] fix of element.vlist.navigate("start"|"end") method;
- [SDK/headers], custom to/from sciter::value serialization support:
T getter(const sciter::value& v, T*); sciter::value setter(const T& t);
scrollanimationstart
andscrollanimationend
events.- [SciterJS] usciter + help button is operational.
- [SciterJS] mdview update with the help of MustafHi
- fix of breakpoint handling in inspector
-
Element.selection
support.
-
Element.onGlobalEvent()
andElement.offGlobalEvent()
, see : samples.sciter/global-events/README.md for the idea.
- [JSX] fix of line number reports when JSX is used in presence of tabs (
\t
); - [Sciter.JS, Reactor] fix of "falsy" values handling.
- [OSX] better font ascent/descent calculation.
- MacOS - inspector.app and usciter.app
- [sciter.js/JSX] + support of numeric and boolean attributes
- [sciter.js] + sample : sdk.js/samples.sciter/lightbox-dialog.
- [Sciter.JS] window.load(url) - loads document into this window.
- [Sciter][Sciter.JS] Reactor fix of <select|dropdown> reconciliation. See: https://sciter.com/forums/topic/select-behaves-erratically-in-reactor-component/
- [Sciter.JS] better console.log() output when inspector is not present.
- [Sciter.JS] behavior:virtual-list - scroll animation outside of virtual scroll functionality.
- [linux] fix of AV on msgbox close.
- [inspector/debugger] fix of breakpoint set.
- [frameset] fix of https://sciter.com/forums/topic/frameset-column-changes-height-when-container-is-resized/ issue.
- [reactor] fix of missed didMount/willUnmount() call when element changes prototype.
- MacOS/ARM - MacOS binaries are universal now - contain as x64 as ARM (M1) code.
- Sciter.JS.Quark is operational now. Use bat/sh files in bin/quark. Source code of the Quark is in /quark folder.
- JSX support of HTML style no-value attributes like:
sys.fs.$readfile()
- synchronous file read.canvas.canvasUpdate(function(gfx){...});
- transactional painitng on<canvas>
, see discussion.- [API] window::broadcast_event(BEHAVIOR_EVENT_PARAMS event); post/send customs events to all windows of the application. See demos/integration project.
- MDView at sdk.js/samples.sciter/applications.quark/mdview - viewer of MD files:
- can be compiled as Quark monolitic application;
- demonstrates Sciter.JS printing support;
- Sciter.JS.Lite - GLFW based demo in demos.lite/sciter-glfw-opengl/
- Sciter.JS.Lite builds on:
- Windows
- MacOS
- Linux
- CSS - support of
@keyframes
inside@set
's; - video - new event "videocoordinate" - allows to coordinate output of multiple
<video>'
s. Coordinated output allows to reduce FPS rate of several videos running at the same time. See: sdk/samples/video/video-25-videos.htm - Audio, basic audio playback, see: sdk.js/samples.sciter/audio/test-basic.htm;
- module @storage - persistent storage, NoSQL DB built into JS runtime.
sys.fs.$readdir()
- sync version of readdir.Color.RGB(0..255,0..255,0..255[,0..255])
- The
$
- Zepto (micro jQuery) sample, see: sdk.js/samples/$ - samples.sciter/sys/folder.htm -
sys.fs.readdir()
demo. - samples.sciter/process/spawn.htm - process spawning demo with stdout redirection.
- inspector fix of style url reporting, see: https://sciter.com/forums/topic/inspector-cant-loads-css-files/
<frame>
, fix offrame.attributes["src"] = ...;
- [core]
flow:vertical-wrap;
fix of stack overflow when percent units used.
behavior:virtual-list
- native virtual list;element.post(function | event)
- posts either function or event to the element;- [JS runtime]
sys.fs.watch(path,callback)
- watch changes on FS (folders and files); - [JS runtime]
sys.fs.splitpath(path) -> [dirpath,file]
; - [usctier] LiveReload functionality is operational;
- samples.sciter/virtual-list - vurtual list samples;
- Sciter.JS.Lite - Linux
- demos/integration - demonstrates native code <-> JavaScript interaction, running native worker threads, exposing native classes and objects, etc.
- docs/md - documentation as part of SDK, markdown formatted.
- samples.sciter/input-elements/ - home of various samples of built-in input elements.
- samples.sciter/themes/ - demo of built-in theme (light/dark), MS Metro and Android Material.
- samples.sciter/tray-icon/ - tray icon demo.
- samples.sciter/window/ - demo of different types of window chromes (window frame types).
- samples/markdown/ - demo of RemarkableJS library.
- graphics.push/popLayer() - clipping(rect,path,bitmap), filters, opacity layers.
- graphics.draw(path|text|image|element, {options}) - drawing those objects.
- class Graphics.Text - text drawing and measurement.
- class Graphics.Path - paths
- class Graphics.Color - color object (RGBA/HSLA/HSLV)
- element.style.colorOf(prop) - getting used color values
- element.style.pixelsOf(prop) - getting used length values
- window.isResizable, isMinimizable and other prperties.
- Sciter.JS.Lite - Windows
- Sciter.JS.Skia - Windows
- Sciter.JS.Lite - Android
- Immediate mode drawing support, element.paintBackground, element.paintForeground, element.paintContent and element.paintOutline properties/methods.
- debugger/inspector support by sciter.dll and scapp.exe
By this release Sciter.JS has reached BETA phase.
- [CSS] +
appearance
property. Examplebutton { appearance:none; }
will suppress default styling of button elements. - [CSS] + support of
transition: ... cubic-bezier(x1,y1,x2,y2);
ease function.
-
- support of JavaScript debugger in scapp, usciter and user applications. Window shall be created with SW_ENABLE_DEBUG flag in order to be debugable.
- Element.onclick and other property-ehandlers.
window.xcall("name"[,arg0,... argN])
andelement.xcall("name"[,arg0,... argN])
- calling methods of native behaviors attached to window and elements.
- PReact framework is generally operational "as it is". JSX (built-in native implementation) can be used with PReact by defining
JSX = h;
-h()
function of PReact is used as a driver of JSX expressions. See: sdk.js/samples/preact/ demos.
- various fixes in HTML/CSS core;
- QuickJS has upgraded to latest (2020-11-08) version. This fixes several issues in JS core.
element.children
supportelement.removeEventListener
supportCSS.supports()
supportnavigator
object support- inspector.exe is more or less operational but JS debugger functionality is still in progress.
- Leaflet.JS demo. See: sdk.js/samples/leaflet . Note: Leaflet runs "as it is" with minor tweaks - Leaflet has outdated feature detection.
- event.clientX/Y ppx/px fix.
- Event, various fixes.
element.tag
- lowercase tag name,element.tagName
uppercase tagnameelement.hasAttributes
element.hasAttribute()
element.attributes
- note in Sciter this returns an array of {name:..., value:...} objects - snapshot of current attributes collection (but not a live map).element.disabled
- in Sciter it is a synonym ofelement.state.disabled
element.readonly
- in Sciter it is a synonym ofelement.state.readonly
Window.this.data
as semi-persistent object - survives document reload.Range
classTokenizer
class (Sciter specific), see samples.sciter/colorizer/element.state.value
value (of input and other elements)scapp.exe -debug
to support connection with inspector.exe, inspector.exe should be running.usciter.exe
supports connection with inspector.exe, inspector.exe should be running.
Note: I am using inspector project as a testing tool for sciter.js
- fix of loading local resources (including
file://
) byfetch()
. - Promise rejection is reported as an error on console.error() channel.
- Various rendering fixes.
document.createNodeIterator()
document.url([relurl])
- Sciter specificelement.click()
element.childNodes
event.altKey
,event.ctrlKey
,event.metaKey
,event.shiftKey
,event.button
,event.buttons
,event.clientX/Y
,event.screenX/Y
,event.x/y
,class Text extends Node
;class Comment extends Node
;class Graphics.Image
- sciter specific;- native module "@debug" - sciter specific;
Element.state.box()
- sciter specific;sciter.uuid()
- uuid string generator- event
"reloaddocument"
; - samples/debug-peer.js (this will move inside sciter.dll) + inspector.exe, console log is operational there + F5 support (by debug-peer.js).
- JSX, fix of , etc parsing;
- WebSocket support, see sdk/samples/websockets/. Note: that is home grown implementation on top of libuv sockets - only basic functionality.
- Node.remove() added.
- [css] hit test fix on inline-block/transform elements;
Window.modal()
- modal windowed message boxes and dialogsWindow.modal(<info>...</info>)
Window.modal(<alert>...</alert>)
Window.modal(<error>...</error>)
Window.modal(<question>...</question>)
Window.modal{ params }
- showing arbitrary window as a modal dialog
Element.classList
Element.classList.item()
Element.classList.add()
Element.classList.remove()
Element.classList.toggle()
Element.classList.contains()
Element.classList.length
Element.classList.entries()
class CustomEvent
Element.dispatchEvent(new CustomEvent(...))
window.dispatchEvent(new CustomEvent(...))
window.minSize = [w,h]
window.maxSize = [w,h]
window.on("eventname", cb)
andwindow.addEventHandler("eventname", cb)
window.off("eventname" | cb)
- [Window events]:
"statechange"
,"resolutionchange"
,"replacementstart"
,"replacementend"
- [API]
SciterCall()
,SciterEval()
are operational - [@sciter module]
loadLibrary("name")
- load Sciter extension native library (dll,so,dylib). "name" is dll name without extension. The dll shall reside in the same folder as executable. SQLite demo operational in scapp.exe.
- [css] hit test fix on inline-block/transform elements;
- [jsx] fix of white space runs handling.
- [css] fix of box calculation in case of box-sizing:border-box / display:inline-block combination;
Element.dispatchEvent()
Element.queryCommand()
Element.executeCommand()
Element.prepend(vnode)
Element.append(vnode)
Element.patch(vnode)
- core of the Sciter's Reactor, a.k.a. "Native React"Element.componentUpdate(props)
- Sciter's Reactor, request to render/patch the component.