Releases: jeroen1602/flutter_web_bluetooth
Releases · jeroen1602/flutter_web_bluetooth
V1.1.0
- Breaking-ish Requesting devices or scans now no longer checks if a bluetooth device is available.
The browser will return aDeviceNotFoundErrorif the bluetooth adapter was unavailable while a scan was requested.- If you want the old behaviour then set
checkingAvailabilitytotrueforrequestDevice,
requestAdvertisementDevice, and/ orrequestLEScan.
- If you want the old behaviour then set
- You can now call
getAvailabilityto get a (new)Futurethat will check if there is currently a bluetooth adapter
available. - Updated list of manufacturer identifiers
V1.0.0
- Changed from
dart:htmltodart:js_interopto support wasm builds. - Dependencies:
- Bluetooth advertisements
- Breaking:
src/AdvertisementReceivedEventno longer extendsweb/AdvertisementReceivedEventInterface src/AdvertisementReceivedEventnow has awithMemoryconstructor- Breaking:
web/AdvertisementReceivedEventInterfaceno longer exists - Breaking:
web/WebAdvertisementReceivedEventhas been renamed toweb/BluetoothAdvertisementReceivedEvent - Breaking:
web/WebAdvertisementReceivedEvent.fromJSObjectconstructor no longer exists - Breaking:
web/WebAdvertisementReceivedEvent.withMemoryconstructor no longer exists
- Breaking:
- Bluetooth filters:
web/BluetoothScanFilterHelperis now deprecated. Useweb/BluetoothManufacturerDataFilter.create(),
web/BluetoothServiceDataFilter.create(), andweb/BluetoothScanFilter.create()instead.- Breaking:
web/BluetoothServiceDataFilternow requires a service UUID. Following spec - Breaking:
web/BluetoothManufacturerDataFilternow requires a company identifier. Following spec - Breaking:
src/ServiceDataFilterBuildernow requires a service UUID. Following spec - Breaking:
src/ManufacturerDataFilterBuildernow requires a company identifier. Following spec
- Breaking:
web/js/AbortControllerhas been removed in favor of the implementation form thewebpackage - Breaking:
web/js/JSUtilshas been removed (this was an internal library so it shouldn't have any impact on most
projects) - Breaking:
web/NativeBluetoothnow returnsJSPromisesand other native objects instead ofobject - Breaking:
web/testingSetNavigator()now requires that you set awebnavigator object. - Breaking:
web/*alladdEventListenerandremoveEventListenerfunctions now extend fromweb/EventTarget - Breaking:
web/*all objects now implementJSObjectand have been marked with@JS. This also removes all
fromJSObjectconstructors. - Breaking: removed
web/WebBluetoothConverters web/WatchAdvertisementsOptionsthe signal property is now nullable. Following the spec.web/*created event streams usingBluetoothEventStreamProviders.- created
web/WebBluetoothValueEventfor theavailabilitychangedevent. - Changed example project to also use
dart:js_interopinstead ofdart:html. - Breaking: Removed all deprecated
BluetoothDefaultManufacturerIdentifierscases. That were deprecated pre this
release. - Breaking: Removed all deprecated
BluetoothDefaultServiceUUIDScases. That were deprecated pre this release.
V0.2.4
- Updated
BluetoothDefaultManufacturerIdentifiers, some identifiers have been renamed, the old names have been marked
as deprecated.- Use
BluetoothDefaultManufacturerIdentifiers.manufacturerIdentifiersto get a list of all the non-deprecated
identifiers.
- Use
- Updated
BluetoothDefaultServiceUUIDSwith the latest service UUIDS. Some services now use the official name from the
Bluetooth SIG, the old names have been marked as deprecated.- Use
BluetoothDefaultServiceUUIDS.servicesto get a list of all the non-deprecated service UUIDS. - Added the
idfield to the enum, this contains the official Bluetooth SIG id of the UUID.
- Use
- Updated
BluetoothDefaultCharacteristicUUIDSwith the latest characteristic UUIDS. Some characteristic now use the
official name from the Bluetooth SIG, some characteristics no longer exist in the spec. The old names and values have
been marked as deprecated- Use
BluetoothDefaultCharacteristicUUIDS.characteristicsto get a list of all the non-deprecated characteristic
UUIDS. - Added the
idfield to the enum, this contains the official Bluetooth SIG id of the UUID.
- Use
- Updated docs to link to the current version of the
service,characteristic, andmanufacturer datablocklists
V0.2.3
- Added
optionalManufacturerDatatoRequestOptions. This is needed to get the manufacture data when watching
advertisements. - Added
BluetoothDefaultManufacturerIdentifiersenum with all the registered manufacturer identifiers - Fixed the conversion from a JS map to a dart map for manufacturer data and service data.
If you are listening to advertisements then these values will now be returned correctly. - Update dependencies.
V0.2.2
- Added
exclusionFilterstoRequestOptionsBuilder. - Added new MissingUserGestureError that you may need to handle.
- Updated dependencies to be more broad. (The minimum versions are still supported.)
V0.2.1
- Updated dependencies.
V0.2.0
- Breaking Removed SNAKE_CASE uuids.
- The default uuids are now an enum since dart supports enums with values.
- If you were using
defaultUuid.ordinalthen you should now usedefaultUuid.index. - Some names may slightly differ.
- Breaking Upgraded minimum dart sdk to
2.17 - Added
forgetto aBluetoothDevice, to forget a device.
v0.1.0
Added requestLEScan to Bluetooth and FlutterWebBluetooth. You can now scan for devices advertisements without needing to pair with each device. However, a normal pair does need to happen before characteristics can be used.
- Breaking in
Bluetooth.requestDevice()theRequestOptionsare no longer nullable. - Breaking
BluetoothDevice.gattis no longer marked as deprecated, it is still marked asvisibleForTesting. - Added bluetooth advertisements event to a bluetooth device. (Note this is still behind a flag in most browsers.)
- Support the newest version of logging.
- Continuing with the IOS Bluefy browser fix for characteristic properties.
- Added
hasmethods for all the fields in characteristic properties. - Return
falseas default value when a property doesn't exist. - Added
hasPropertiesmethod to check if there are any properties at all. Use this to test if the properties are
even reliable. - You can remove any try-catch logic around reading properties if you added those for the mitigation.
- Added
Note: The next version of the library will probably upgrade the minimum SDK from 2.12 to 2.17 to keep up with other packages. If there are any good reasons to not do this then please create an issue on Github.
V0.0.9
Updated dependencies to work with Flutter 3.3.0
- Added a hotfix for the IOS Bluefy browser. As a side effect none of the characteristic properties are required anymore, but there are no methods yet to check if the properties exist. So add a try-catch around these methods for now! Thanks @rohitsangwan01 for the fix.
V0.0.8
Added manufacturer scan filters and service scan filters