API changes
Table of contents
- v1.6.1
- v1.6.0
- v1.5.1
- v1.5.0
- v1.4.1
- v1.4.0
- v1.3.0
- v1.2.2
- v1.2.0
- v1.1.2
- v1.1.0
- v1.0.5
- v1.0.4
- v1.0.3
- v1.0.1
- v1.0.0
For the latest detailed documentation use docs/html/index.html inside your foo_spider_monkey_panel installation (e.g. foobar2000/user-components/foo_spider_monkey_panel/docs).
Legend:
- API marked with [Experimental] is subject to change and might not be stable or fully functional.
- API marked with [Deprecated] will be removed in future versions and thus should not be used.
v1.6.1
Changed
- Reverted changes in window.NotifyOthers()behaviour. Now it’s executed synchronously as before.
v1.6.0
Added
- Added a boolean IsInternalfield toactionargument (that is passed toon_drag_*callbacks). This field holdstrueif the drag-n-drop session was started byfb.DoDragDrop()inside the same panel.
- Added an ability to generate main menu items dynamically and handle it via the following API: - fb.RegisterMainMenuCommand(id, name, description): registers a main menu item that will be displayed under- main menu>- File>- Spider Monkey Panel>- Script commands>- {Current panel name}>- {name}.
- fb.UnregisterMainMenuCommand(id, name): unregisters the item from- fb.RegisterMainMenuCommand(). Execution of registered command will trigger the new- on_main_menu_dynamic(id)callback.
 Note: SMP uses a combination of panel name and command id to identify and bind the command. Hence all the corresponding binds will fail if the id or the panel name is changed. This also means that collision WILL occur if there are two panels with the same name. 
- Expanded playlist undo API: Undo/Redomenu items only apply to active playlist, the following methods are introduced to rectify that:- plman.Undo(playlistIndex).
- plman.Redo(playlistIndex).
- plman.IsUndoAvailable(playlistIndex).
- plman.IsRedoAvailable(playlistIndex).
 
Changed
- fb.DoDragDrop()is now executed asynchronously. Which means that it might exit before- on_drag_dropcallback is triggered when dropping data on the same panel as the one that had a call to- fb.DoDragDrop().
- [Rollbacked in v1.6.1] window.NotifyOthers()is now executed asynchronously, hence the data passed viainfoargument must NOT be used or modified in the source panel after invoking this method.
- on_main_menu()callback is marked as [Deprecated]. Use dynamically generated main menu items and corresponding- on_main_menu_dynamic()callback instead.
v1.5.1
Added
- Added plman.GetPlaylistLockName(playlist_index)method. Returns the name of the lock. It can be used to check whether the lock is owned byfoo_spider_monkey_paneland thus can be modified withplman.SetPlaylistLockedActions().
v1.5.0
Added
- Added plman.GetPlaylistLockedActions(playlist_index)method. Returns an array of strings, which represent actions that can’t be performed on the specidified playlist.
 These actions may be one or multiple of the following:AddItems,RemoveItems,ReorderItems,ReplaceItems,RenamePlaylist,RemovePlaylist,ExecuteDefaultAction.
- Added plman.SetPlaylistLockedActions(playlist_index, locked_actions)method. Sets actions that can’t be performed on the specified playlist.
 Accepts an array of strings that may contain the same items as actions described above forplman.GetPlaylistLockedActions().
- Added utils.GetPackageInfo(package_id)method. Returnsnull, if the package is not found, or, if found, an object of the following format:{ Version, // Package version Directories: { Root, // Root directory of the package Script, // Directory inside package folder that contains assets Assets, // Directory inside package folder that contains Storage // Persistent and unique directory inside foobar2000 profile folder that can be used to store runtime data (e.g. cache) } }
- Added fb.Restart()method. Restarts the player.
Changed
- Added an optional use_exactargument toGdiGraphics.CalcTextWidth()(falseby default). If set totruewill use a more accurate width calculation algorithm in certain cases. See (#140) for more info on these cases.
- utils.GetPackagePath()is marked as [Deprecated]. Use- utils.GetPackageInfo()instead.
- plman.IsPlaylistLocked()is marked as [Deprecated]. Use- plman.GetPlaylistLockedActions()instead.
v1.4.1
Changed
- [BREAKING] Changed casing of window.JsMemoryStatsfields for consistency with the rest of API:- memory_usageto- MemoryUsage.
- total_memory_usageto- TotalMemoryUsage.
- total_memory_limitto- TotalMemoryLimit.
 
v1.4.0
Added
- Added iterator protocol support to FbMetadbHandleList: see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Iteration_protocols for more info.
- Added iterator protocol support to enumerable ActiveXObjectobjects.
- Added typeargument toFbUiSelectionHolder.SetSelection(). Wheretypecan be one of the following values:- 0: undefined (no item), default value.
- 1: active_playlist_selection.
- 2: caller_active_playlist.
- 3: playlist_manager.
- 4: now_playing.
- 5: keyboard_shortcut_list.
- 6: media_library_viewer.
 
- Added fb.Versionproperty: returns foobar2000 version as a string, e.g.1.4.1.
- Added utils.DetectCharset(path)method. Does the same thing asutils.FileTest(path, 'chardet').
- Added utils.EditTextFile(path)method. It uses the same editor as the one that is set for editing scripts inwindow.ShowConfigureV2().
- Added utils.FileExists(path)method. Does the same thing asutils.FileTest(path, 'e').
- Added utils.GetFileSize(path)method. Does the same thing asutils.FileTest(path, 's').
- Added utils.GetPackagePath(package_id)method. Package id can be retrieved fromwindow.ScriptInfo(only if the panel actually uses script package).
- Added utils.IsDirectory(path)method. Does the same thing asutils.FileTest(path, 'd').
- Added utils.IsFile(path)method.
- Added utils.SplitFilePath(path)method. Does the same thing asutils.FileTest(path, 'split').
- Added window.DefineScript(script_name, { author: author_name, version: version_string, features: {drag_n_drop: boolean, grab_focus: boolean} })method.- grab_focushas the same behaviour as the checkbox in the old- window.Configure()dialog, i.e. if true, grabs user input when mouse is over the panel.- trueby default.
 
- Added window.EditScript()method. Uses editor that is set inwindow.ShowConfigureV2(). By default works the same as the oldwindow.Configure()dialog.
- Added window.ShowConfigureV2()method. This dialog contains only various panel settings. Script editing is now invoked viaEditbuttons orwindow.EditScript().
- Added window.JsMemoryStatsproperty.- memory_usage: same values as- window.PanelMemoryUsage.
- total_memory_usage: same values as- window.TotalMemoryUsage.
- total_memory_limit: same values as- window.MemoryLimit.
 
- Added window.ScriptInfoproperty. Contains all the info about the script that was either set up withwindow.DefineScript()or was defined in script package.
Changed
- utils.FileTest()is marked as [Deprecated]. Use new corresponding methods instead.
- window.IDis now optional and unused in all methods that required it.
- window.DefinePanel()is marked as [Deprecated]. Use- window.DefineScript()instead. Note: to retain backward compatibility this method sets both script name and panel name.
- window.MemoryLimit,- window.PanelMemoryUsageand- window.TotalMemoryUsageare marked as [Deprecated]. Use- window.JsMemoryStatsinstead.
- window.Namenow returns panel name instead of script name. Use- window.ScriptInfo.Nameto retrieve script name.
- window.ShowConfigure()is marked as [Deprecated]. Use- window.ShowConfigureV2()to configure panel and- window.EditScriptto edit script.
v1.3.0
Added
- Added GdiBitmap.InvertColours()method: returns aGdiBitmapwith inverted colours.
- Added window.Tooltipproperty: returns aFbTooltipobject associated with the current panel.
- Added FbTooltip.SetFont(font_name, font_size_px, font_style)method: changes tooltip font.
- Added ActiveXObject.ActiveX_CreateArray(arr, element_variant_type)method: converts a JavaScript array toActiveXObjectthat contains an object of typeVT_ARRAY|element_variant_type. Arguments:- arr: a JS array that consists of elements of primitive type.
- element_variant_typea numerial value of variant type (e.g.- 0x11for- VT_UI1).
 
Changed
- Updated SpiderMonkey JavaScript engine to 68.8.0 ESR: - ECMAScript 2019 conformant JavaScript. See ‘What’s new in ES2019’ for more info.
 
- [Deprecated] window.CreateTooltip(): usewindow.TooltipandFbTooltip.SetFont()instead.
v1.2.2
Added
- Added global constructor for GdiFont: same arguments asgdi.Font().
- Added support for passing arguments to the callback in setIntervalandsetTimeout(see JavaScript docs for usage example).
v1.2.0
Added
- Changed includebehaviour:- pathargument now supports relative paths.
- Has include guards- script won’t be evaluated a second time if it was evaluated before in the same panel.
- Has script caching - script file will be read only once from filesystem (even if it is included from different panels).
 
- Added optional optionsargument toinclude, which might contain the following modifiers:- always_evaluate(default- false): If true, evaluates the script even if it was included before.
 
v1.1.2
Added
- Added optional optionsargument tofb.DoDragDrop, which might contain the following modifiers:- show_text(default- true): if true, will add track count text
- use_album_art(default- true): if true, will use album art of the focused item from dragged tracks (if available)
- use_theming(default- true): if true, will use Windows drag window style. Album art and custom image are resized to fit when Windows style is active.
- custom_image(default- undefined): custom dragging image. Will be also displayed if- use_album_artis true, but there is no album art available.
 
v1.1.0
Added
- Added clearInterval(),clearTimeout(),setInterval(),setTimeout()methods to global namespace.
 They work the same as correspondingwindow.ClearInterval(),window.ClearTimeout(),window.SetInterval(),window.SetTimeout()methods.
- Added gdi.LoadImageSyncV2()method.
 Works the same asgdi.LoadImageSync, but returns a Promise object instead of callingon_load_image_done().
- Added utils.GetAlbumArtAsyncV2()method.
 Works the same asgdi.GetAlbumArtAsync(), but returns a Promise object instead of callingon_get_album_art_done().
- Added arguments to FbProfiler.Print(): additional message and an option to disable component info.
- Added global constructors for the following objects: - FbMetadbHandleList: from another- FbMetadbHandleList, from an array of- FbMetadbHandle, from a single- FbMetadbHandleand a default constructor.
- GdiBitmap: from another- GdiBitmap.
- FbProfiler: accepts the same arguments as- fb.CreateProfiler().
- FbTitleFormat: accepts the same arguments as- fb.TitleFormat().
 
Changed
- fb.DoDragDrop()now requires an additional- window.IDargument.
- New Textproperty inactionargument ofon_drag_*callbacks: setting this property will change the drop text on drag window.
- [Deprecated]fb.CreateHandleList(): useFbMetadbHandleListconstructor instead.
v1.0.5
Added
- Added windowproperties for memory tracking:- window.MemoryLimit: maximum allowed memory usage for the component. If the total memory usage exceeds this value, all panels will fail with OOM error.
- window.PanelMemoryUsage: memory usage of the current panel.
- window.TotalMemoryUsage: total memory usage of all panels.
 
v1.0.4
Added
- Added FbMetadbHandleList.RemoveAttachImagesmethod.
Changed
- Rewrote plman.PlaylistRecyclerManager, since it was broken:- Replaced Nameproperty withGetName()method.
- Replaced Contentproperty withGetContent()method.
- Renamed to plman.PlaylistRecycler.
 
- Replaced 
v1.0.3
Changed
- Reimplemented utils.ShowHtmlDialog():- No longer considered [Experimental] and is safe to use.
- Does not return a value anymore.
- Utilizes the latest non-Edge IE that you have on your system.
- More options: width,height,x,y,center,context_menu,resizable,selection,scroll.
 
v1.0.1
Added
- [Experimental] Added utils.ShowHtmlDialog()method.
 This method allows the creation of modal HTML windows rendered by IE8 engine.
 utils.ShowHtmlDialog(window_id, code_or_file, { width: window_w, height: window_h, data: callback_data }).- code_or_file: either html code or path to html file (must be set with- file://prefix).
- data: will be saved in- window.external.dialogArgumentsobject and can be accessed from JavaScript executed inside HTML window.
- Method returns value set to window.returnValuefrom HTML code.
 
Removed
- Removed utils.CreateHtmlWindow()method, since it was totally broken.
v1.0.0
Note: despite changing scripting engine to SpiderMonkey, the file-system and web access is still provided via ActiveX objects.
Added
- JavaScript is now conformant to ES2018 standard and has quite a few new features:
- All methods that returned VBArraybefore return a proper JS array now.
- FbMetadbHandleListitems now can be accessed with [ ] operator.
- Added global include('path/to/script.js')method.
 This method is likeeval(ReadFile('path/to/script.js')), but provides better error reporting and might have more features in the future (like script caching or include guards).
- Added window.DefinePanel()method.
 A replacement for the old==PREPROCESSOR==header.
 window.DefinePanel(panel_name, { author: author_name, version: version_string, features: {drag_n_drop: boolean} } ).- The second argument and all of it’s properties are optional.
- drag_n_dropis- falseby default.
 
- [BROKEN, DON’T USE] Added utils.CreateHtmlWindow()method.
Breaking changes
| Change | Reason | Workaround | 
|---|---|---|
| Dropped support for Windows XP/Vista (Windows 7 is the minimum requirement) | SpiderMonkey engine and CUI SDK require Windows 7 or higher | Use foo_jscript_panel or upgrade your OS | 
| All methods and properties are case-sensitive | Required by ECMAScript standard | Fix the wrong casing :) | 
| Removed Dispose() | Not needed anymore: JS GC destroys all objects by itself when corresponding reference count is zero | Remove those methods and assign nullorundefinedto variables if needed | 
| Removed toArray() | Not needed anymore: all corresponding methods return a proper JS array now | Remove those methods | 
| Removed FbMetadbHandleList.Item() | Not needed anymore: FbMetadbHandleListhas proper array accessors now | Replace .Item(i)with[i] | 
| Changed utils.Versionreturn type: returnsstringinstead ofnumber | Component uses semantic versioning, which requires string representation | Remove all version checks - the versioning is different from JSP anyway | 
| New limitations imposed on on_notify_datacallback regardingdataargument(see docs) | Limitations are brought by the JS engine | Don’t modify dataand make a deep clone when storing it | 
| Removed old ==PREPROCESSOR==panel header support | Old header could only be used in the main configure panel and was not a proper JS method | Replace with the following: window.DefinePanel('Panel Name', { author: 'Author', version: 'Version', features: {drag_n_drop: true|false}} ); | 
| Most methods have much stricter error checks | Before, methods could fail silently without doing anything, which made diagnosing errors unnecessary hard | Fix incorrect calls and arguments |