Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for Web NFC API #806

Merged
merged 3 commits into from
Dec 21, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
56 changes: 56 additions & 0 deletions api-reports/2_12.txt
Original file line number Diff line number Diff line change
Expand Up @@ -16464,6 +16464,62 @@ MutationRecord[JT] def previousSibling: Node
MutationRecord[JT] def removedNodes: NodeList[Node]
MutationRecord[JT] def target: Node
MutationRecord[JT] def `type`: String
NDEFMessage[JC] def records: FrozenArray[NDEFRecord]
NDEFReader[JC] def addEventListener[T <: Event](`type`: String, listener: js.Function1[T, _], options: EventListenerOptions): Unit
NDEFReader[JC] def addEventListener[T <: Event](`type`: String, listener: js.Function1[T, _], useCapture: Boolean?): Unit
NDEFReader[JC] def dispatchEvent(evt: Event): Boolean
NDEFReader[JC] var onreading: js.Function1[NDEFReadingEvent, Any]
NDEFReader[JC] var onreadingerror: js.Function1[Event, Any]
NDEFReader[JC] def removeEventListener[T <: Event](`type`: String, listener: js.Function1[T, _], options: EventListenerOptions): Unit
NDEFReader[JC] def removeEventListener[T <: Event](`type`: String, listener: js.Function1[T, _], useCapture: Boolean?): Unit
NDEFReader[JC] def scan(options: NDEFScanOptions?): js.Promise[Unit]
NDEFReader[JC] def write(message: String): js.Promise[Unit]
NDEFReader[JC] def write(message: String, options: NDEFWriteOptions): js.Promise[Unit]
NDEFReader[JC] def write(message: js.Array[NDEFRecord]): js.Promise[Unit]
NDEFReader[JC] def write(message: js.Array[NDEFRecord], options: NDEFWriteOptions): js.Promise[Unit]
NDEFReader[JC] def write(message: js.typedarray.ArrayBuffer): js.Promise[Unit]
NDEFReader[JC] def write(message: js.typedarray.ArrayBuffer, options: NDEFWriteOptions): js.Promise[Unit]
NDEFReader[JC] def write(message: js.typedarray.DataView): js.Promise[Unit]
NDEFReader[JC] def write(message: js.typedarray.DataView, options: NDEFWriteOptions): js.Promise[Unit]
NDEFReader[JC] def write(message: js.typedarray.TypedArray[_, _], options: NDEFWriteOptions?): js.Promise[Unit]
NDEFReadingEvent[JC] def bubbles: Boolean
NDEFReadingEvent[JC] def cancelBubble: Boolean
NDEFReadingEvent[JC] def cancelable: Boolean
NDEFReadingEvent[JC] def composed: Boolean
NDEFReadingEvent[JC] def currentTarget: EventTarget
NDEFReadingEvent[JC] def defaultPrevented: Boolean
NDEFReadingEvent[JC] def eventPhase: Int
NDEFReadingEvent[JC] def isTrusted: Boolean
NDEFReadingEvent[JC] def message: NDEFMessage
NDEFReadingEvent[JC] def preventDefault(): Unit
NDEFReadingEvent[JC] def serialNumber: String
NDEFReadingEvent[JC] def stopImmediatePropagation(): Unit
NDEFReadingEvent[JC] def stopPropagation(): Unit
NDEFReadingEvent[JC] def target: EventTarget
NDEFReadingEvent[JC] def timeStamp: Double
NDEFReadingEvent[JC] def `type`: String
NDEFReadingEventInit[JT] var bubbles: js.UndefOr[Boolean]
NDEFReadingEventInit[JT] var cancelable: js.UndefOr[Boolean]
NDEFReadingEventInit[JT] var composed: js.UndefOr[Boolean]
NDEFReadingEventInit[JT] var message: NDEFRecordInit
NDEFReadingEventInit[JT] var scoped: js.UndefOr[Boolean]
NDEFReadingEventInit[JT] var serialNumber: js.UndefOr[AbortSignal]
NDEFRecord[JC] def data: js.typedarray.DataView
NDEFRecord[JC] def encoding: js.UndefOr[String]
NDEFRecord[JC] def id: js.UndefOr[String]
NDEFRecord[JC] def lang: js.UndefOr[String]
NDEFRecord[JC] def mediaType: js.UndefOr[String]
NDEFRecord[JC] def recordType: String
NDEFRecord[JC] def toRecords(): js.UndefOr[js.Array[NDEFRecord]]
NDEFRecordInit[JT] var data: js.UndefOr[String | js.typedarray.DataView | js.typedarray.ArrayBuffer | js.typedarray.TypedArray[_, _] | js.typedarray.DataView | js.Array[NDEFRecord]]
NDEFRecordInit[JT] var encoding: js.UndefOr[String]
NDEFRecordInit[JT] var id: js.UndefOr[String]
NDEFRecordInit[JT] var lang: js.UndefOr[String]
NDEFRecordInit[JT] var mediaType: js.UndefOr[String]
NDEFRecordInit[JT] var recordType: String
NDEFScanOptions[JT] var signal: js.UndefOr[AbortSignal]
NDEFWriteOptions[JT] var overwrite: js.UndefOr[Boolean]
NDEFWriteOptions[JT] var signal: js.UndefOr[AbortSignal]
NamedNodeMap[JC] @scala.scalajs.js.annotation.JSBracketAccess def apply(index: Int): Attr
NamedNodeMap[JC] def getNamedItem(name: String): Attr
NamedNodeMap[JC] def getNamedItemNS(namespaceURI: String, localName: String): Attr
Expand Down
56 changes: 56 additions & 0 deletions api-reports/2_13.txt
Original file line number Diff line number Diff line change
Expand Up @@ -16464,6 +16464,62 @@ MutationRecord[JT] def previousSibling: Node
MutationRecord[JT] def removedNodes: NodeList[Node]
MutationRecord[JT] def target: Node
MutationRecord[JT] def `type`: String
NDEFMessage[JC] def records: FrozenArray[NDEFRecord]
NDEFReader[JC] def addEventListener[T <: Event](`type`: String, listener: js.Function1[T, _], options: EventListenerOptions): Unit
NDEFReader[JC] def addEventListener[T <: Event](`type`: String, listener: js.Function1[T, _], useCapture: Boolean?): Unit
NDEFReader[JC] def dispatchEvent(evt: Event): Boolean
NDEFReader[JC] var onreading: js.Function1[NDEFReadingEvent, Any]
NDEFReader[JC] var onreadingerror: js.Function1[Event, Any]
NDEFReader[JC] def removeEventListener[T <: Event](`type`: String, listener: js.Function1[T, _], options: EventListenerOptions): Unit
NDEFReader[JC] def removeEventListener[T <: Event](`type`: String, listener: js.Function1[T, _], useCapture: Boolean?): Unit
NDEFReader[JC] def scan(options: NDEFScanOptions?): js.Promise[Unit]
NDEFReader[JC] def write(message: String): js.Promise[Unit]
NDEFReader[JC] def write(message: String, options: NDEFWriteOptions): js.Promise[Unit]
NDEFReader[JC] def write(message: js.Array[NDEFRecord]): js.Promise[Unit]
NDEFReader[JC] def write(message: js.Array[NDEFRecord], options: NDEFWriteOptions): js.Promise[Unit]
NDEFReader[JC] def write(message: js.typedarray.ArrayBuffer): js.Promise[Unit]
NDEFReader[JC] def write(message: js.typedarray.ArrayBuffer, options: NDEFWriteOptions): js.Promise[Unit]
NDEFReader[JC] def write(message: js.typedarray.DataView): js.Promise[Unit]
NDEFReader[JC] def write(message: js.typedarray.DataView, options: NDEFWriteOptions): js.Promise[Unit]
NDEFReader[JC] def write(message: js.typedarray.TypedArray[_, _], options: NDEFWriteOptions?): js.Promise[Unit]
NDEFReadingEvent[JC] def bubbles: Boolean
NDEFReadingEvent[JC] def cancelBubble: Boolean
NDEFReadingEvent[JC] def cancelable: Boolean
NDEFReadingEvent[JC] def composed: Boolean
NDEFReadingEvent[JC] def currentTarget: EventTarget
NDEFReadingEvent[JC] def defaultPrevented: Boolean
NDEFReadingEvent[JC] def eventPhase: Int
NDEFReadingEvent[JC] def isTrusted: Boolean
NDEFReadingEvent[JC] def message: NDEFMessage
NDEFReadingEvent[JC] def preventDefault(): Unit
NDEFReadingEvent[JC] def serialNumber: String
NDEFReadingEvent[JC] def stopImmediatePropagation(): Unit
NDEFReadingEvent[JC] def stopPropagation(): Unit
NDEFReadingEvent[JC] def target: EventTarget
NDEFReadingEvent[JC] def timeStamp: Double
NDEFReadingEvent[JC] def `type`: String
NDEFReadingEventInit[JT] var bubbles: js.UndefOr[Boolean]
NDEFReadingEventInit[JT] var cancelable: js.UndefOr[Boolean]
NDEFReadingEventInit[JT] var composed: js.UndefOr[Boolean]
NDEFReadingEventInit[JT] var message: NDEFRecordInit
NDEFReadingEventInit[JT] var scoped: js.UndefOr[Boolean]
NDEFReadingEventInit[JT] var serialNumber: js.UndefOr[AbortSignal]
NDEFRecord[JC] def data: js.typedarray.DataView
NDEFRecord[JC] def encoding: js.UndefOr[String]
NDEFRecord[JC] def id: js.UndefOr[String]
NDEFRecord[JC] def lang: js.UndefOr[String]
NDEFRecord[JC] def mediaType: js.UndefOr[String]
NDEFRecord[JC] def recordType: String
NDEFRecord[JC] def toRecords(): js.UndefOr[js.Array[NDEFRecord]]
NDEFRecordInit[JT] var data: js.UndefOr[String | js.typedarray.DataView | js.typedarray.ArrayBuffer | js.typedarray.TypedArray[_, _] | js.typedarray.DataView | js.Array[NDEFRecord]]
NDEFRecordInit[JT] var encoding: js.UndefOr[String]
NDEFRecordInit[JT] var id: js.UndefOr[String]
NDEFRecordInit[JT] var lang: js.UndefOr[String]
NDEFRecordInit[JT] var mediaType: js.UndefOr[String]
NDEFRecordInit[JT] var recordType: String
NDEFScanOptions[JT] var signal: js.UndefOr[AbortSignal]
NDEFWriteOptions[JT] var overwrite: js.UndefOr[Boolean]
NDEFWriteOptions[JT] var signal: js.UndefOr[AbortSignal]
NamedNodeMap[JC] @scala.scalajs.js.annotation.JSBracketAccess def apply(index: Int): Attr
NamedNodeMap[JC] def getNamedItem(name: String): Attr
NamedNodeMap[JC] def getNamedItemNS(namespaceURI: String, localName: String): Attr
Expand Down
22 changes: 22 additions & 0 deletions dom/src/main/scala/org/scalajs/dom/NDEFMessage.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
package org.scalajs.dom

import scala.scalajs.js
import scala.scalajs.js.annotation.JSGlobal

/** The [[NDEFMessage]] interface of the Web NFC API represents the content of an NDEF message that has been read from
* or could be written to an NFC tag. An instance is acquired by calling the NDEFMessage() constructor or from the
* NDEFReadingEvent.message property, which is passed to the reading event.
*
* @see
* https://w3c.github.io/web-nfc/#the-ndefmessage-interface
*
* @param messageInit
* property of NDEFMessage interface represents a list of NDEFRecords present in the NDEF message.
*/
@js.native
@JSGlobal
class NDEFMessage(messageInit: js.Array[NDEFRecordInit]) extends js.Object {

/** Returns the list of NDEF records contained in the message. */
def records: FrozenArray[NDEFRecord] = js.native
}
63 changes: 63 additions & 0 deletions dom/src/main/scala/org/scalajs/dom/NDEFReader.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
package org.scalajs.dom

import scala.scalajs.js
import scala.scalajs.js.annotation.JSGlobal

/** The [[NDEFReader]] interface of the Web NFC API (https://developer.mozilla.org/en-US/docs/Web/API/Web_NFC_API) is
* used to read from and write data to compatible NFC devices, e.g. NFC tags supporting NDEF, when these devices are
* within the reader's magnetic induction field.
*
* @see
* https://w3c.github.io/web-nfc/#the-ndefreader-object
*/
@JSGlobal("NDEFReader")
@js.native
class NDEFReader() extends EventTarget {
FabioPinheiro marked this conversation as resolved.
Show resolved Hide resolved

/** Activates a reading device and returns a Promise that either resolves when an NFC tag read operation is scheduled
* or rejects if a hardware or permission error is encountered. This method triggers a permission prompt if the "nfc"
* permission has not been previously granted.
*
* @return
* a Promise that resolves immediately after scheduling read operations for the NFC adapter.
*/
def scan(options: NDEFScanOptions = js.native): js.Promise[Unit] = js.native

/** Attempts to write an NDEF message to a tag and returns a Promise that either resolves when a message has been
* written to the tag or rejects if a hardware or permission error is encountered. This method triggers a permission
* prompt if the "nfc" permission has not been previously granted.
*
* @param message
* The message to be written, either a string object or literal, an ArrayBuffer, a TypedArray, a DataView, or an
* array of records. A record has the following members:
* @param options
* An object with the following properties:
*
* @return
* a Promise that either resolves when a message has been written to the tag or rejects if a hardware or permission
* error is encountered.
*/
def write(message: String, options: NDEFWriteOptions): js.Promise[Unit] = js.native
def write(message: js.typedarray.ArrayBuffer, options: NDEFWriteOptions): js.Promise[Unit] = js.native

def write(message: js.typedarray.TypedArray[_, _],
options: NDEFWriteOptions = js.native): js.Promise[Unit] = js.native
def write(message: js.typedarray.DataView, options: NDEFWriteOptions): js.Promise[Unit] = js.native
def write(message: js.Array[NDEFRecord], options: NDEFWriteOptions): js.Promise[Unit] = js.native

def write(message: String): js.Promise[Unit] = js.native
def write(message: js.typedarray.ArrayBuffer): js.Promise[Unit] = js.native
// def write(message:js.typedarray.TypedArray[NDEFRecord, ???]): js.Promise[Unit] = js.native
def write(message: js.typedarray.DataView): js.Promise[Unit] = js.native
def write(message: js.Array[NDEFRecord]): js.Promise[Unit] = js.native

/** The reading event of the NDEFReader interface is fired whenever a new reading is available from compatible NFC
* devices (e.g. NFC tags supporting NDEF) when these devices are within the reader's magnetic induction field.
*/
var onreading: js.Function1[NDEFReadingEvent, Any] = js.native

/** The readingerror event of the NDEFReader interface is fired whenever an error occurs during reading of NFC tags,
* e.g. when tags leave the reader's magnetic induction field.
*/
var onreadingerror: js.Function1[Event, Any] = js.native
}
25 changes: 25 additions & 0 deletions dom/src/main/scala/org/scalajs/dom/NDEFReadingEvent.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
package org.scalajs.dom

import scala.scalajs.js
import scala.scalajs.js.annotation.JSGlobal

/** The NDEFReadingEvent interface of the Web NFC API represents events dispatched on new NFC readings obtained by
* NDEFReader.
*
* @see
* https://developer.mozilla.org/en-US/docs/Web/API/NDEFReadingEvent
* @see
* https://w3c.github.io/web-nfc/#the-ndefreader-object
*/
@js.native
@JSGlobal
class NDEFReadingEvent(typeArg: String, init: NDEFReadingEventInit) extends Event(typeArg, init) {

/** Returns an NDEFMessage object containing the received message. */
def message: NDEFMessage = js.native

/** Returns the serial number of the device, which is used for anti-collision and identification, or an empty string
* if no serial number is available.
*/
def serialNumber: String = js.native
}
24 changes: 24 additions & 0 deletions dom/src/main/scala/org/scalajs/dom/NDEFReadingEventInit.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
package org.scalajs.dom

import scala.scalajs.js

/** NDEFReadingEventInit is used to initialize a new event with a serial number and the NDEFMessageInit data via the
* message member. If serialNumber is not present or is null, empty string will be used to init the event.
*
* @see
* https://developer.mozilla.org/en-US/docs/Web/API/NDEFReadingEvent/NDEFReadingEvent#parameters
* @see
* https://w3c.github.io/web-nfc/#the-ndefreader-object
*/
trait NDEFReadingEventInit extends EventInit {

/** A string with the name of the event. It is case-sensitive and browsers always set it to reading. Default is "" an
* empty string
*/
var serialNumber: js.UndefOr[AbortSignal] = js.undefined

/** An object that, in addition of the properties defined in Event(), can have the following properties: serialNumber;
* message
*/
var message: NDEFRecordInit
}
44 changes: 44 additions & 0 deletions dom/src/main/scala/org/scalajs/dom/NDEFRecord.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
package org.scalajs.dom

import scala.scalajs.js
import scala.scalajs.js.annotation.JSGlobal

/** The [[NDEFRecord]] interface of the Web NFC API provides data that can be read from, or written to, compatible NFC
* devices, e.g. NFC tags supporting NDEF.
*
* @see
* https://w3c.github.io/web-nfc/#the-ndefrecord-interface
*/
@js.native
@JSGlobal
class NDEFRecord(init: NDEFRecordInit) extends js.Object {

/** Returns the record type of the record. Records must have either a standardized well-known type name such as
* "empty", "text", "url", "smart-poster", "absolute-url", "mime", or "unknown" or else an external type name, which
* consists of a domain name and custom type name separated by a colon (":").
*/
def recordType: String = js.native

/** Returns the MIME type of the record. This value will be null if recordType is not equal to "mime". */
def mediaType: js.UndefOr[String] = js.native

/** Returns the record identifier, which is an absolute or relative URL used to identify the record.
*
* Note: The uniqueness of the identifier is enforced only by the generator of the record.
*/
def id: js.UndefOr[String] = js.native

/** Returns a DataView containing the raw bytes of the record's payload. */
def data: js.typedarray.DataView = js.native

/** Returns the encoding of a textual payload, or null otherwise. */
def encoding: js.UndefOr[String] = js.native

/** Returns the language of a textual payload, or null if one was not supplied. */
def lang: js.UndefOr[String] = js.native

/** Converts [[NDEFRecord.data]] to a sequence of records. This allows parsing the payloads of record types which may
* contain nested records, such as smart poster and external type records.
*/
def toRecords(): js.UndefOr[js.Array[NDEFRecord]] = js.native
}
55 changes: 55 additions & 0 deletions dom/src/main/scala/org/scalajs/dom/NDEFRecordInit.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
package org.scalajs.dom

import scala.scalajs.js
import scala.scalajs.js.|

/** The NDEFRecordInit dictionary is used to initialize an NDEF record with its record type recordType, and optional
* record identifier id and payload data data.
* @see
* https://developer.mozilla.org/en-US/docs/Web/API/NDEFMessage/NDEFMessage
* @see
* https://developer.mozilla.org/en-US/docs/Web/API/NDEFRecord/NDEFRecord
* @see
* https://w3c.github.io/web-nfc/#the-ndefrecord-interface
*/
trait NDEFRecordInit extends js.Object {

/** Contains the data to be transmitted. It can be a string object or literal, an ArrayBuffer, a TypedArray, a
* DataView, or an array of nested records.
*/
var data: js.UndefOr[
String |
js.typedarray.DataView |
js.typedarray.ArrayBuffer |
js.typedarray.TypedArray[_, _] |
js.typedarray.DataView |
js.Array[NDEFRecord]
] = js.undefined

/** A string specifying the record's encoding. */
var encoding: js.UndefOr[String] = js.undefined

/** A developer-defined identifier for the record. */
var id: js.UndefOr[String] = js.undefined

/** A valid language tag according to [RFC 5646: Tags for Identifying Languages (also known as BCP
* 47)](https://datatracker.ietf.org/doc/html/rfc5646).
*/
var lang: js.UndefOr[String] = js.undefined

/** A valid MIME type. */
var mediaType: js.UndefOr[String] = js.undefined

/** A string indicating the type of data stored in data.
*
* It must be one of the following values:
* - "absolute-url" - An absolute URL to the data.
* - "empty" - An empty NDEFRecord.
* - "mime" - A valid MIME type.
* - "smart-poster" - A smart poster as defined by the NDEF-SMARTPOSTER specification.
* - "text" - Text as defined by the NDEF-TEXT specification.
* - "unknown" - The record type is not known.
* - "URL" - A URL as defined by the NDEF-URI specification.
*/
var recordType: String
}
10 changes: 10 additions & 0 deletions dom/src/main/scala/org/scalajs/dom/NDEFScanOptions.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
package org.scalajs.dom

import scala.scalajs.js

/** @see https://w3c.github.io/web-nfc/#the-ndefscanoptions-dictionary */
trait NDEFScanOptions extends js.Object {

/** An AbortSignal that allows the current write operation to be canceled. */
var `signal`: js.UndefOr[AbortSignal] = js.undefined
}
19 changes: 19 additions & 0 deletions dom/src/main/scala/org/scalajs/dom/NDEFWriteOptions.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
package org.scalajs.dom

import scala.scalajs.js

/** @see
* https://w3c.github.io/web-nfc/#the-ndefwriteoptions-dictionary
* @see
* https://developer.mozilla.org/en-US/docs/Web/API/NDEFReader/write
*/
trait NDEFWriteOptions extends js.Object {

/** A boolean value specifying whether or not existing records should be overwritten, if such exists. Default is true
*/
var `overwrite`: js.UndefOr[Boolean] = js.undefined

/** An AbortSignal that allows the current write operation to be canceled. */
var `signal`: js.UndefOr[AbortSignal] = js.undefined

}
Loading