2014-10-02 06:32:05 +04:00
|
|
|
/* -*- Mode: IDL; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
|
|
|
* You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
*
|
|
|
|
* The origin of this IDL file is
|
|
|
|
* http://dev.w3.org/csswg/css-font-loading/#FontFaceSet-interface
|
|
|
|
*
|
|
|
|
* Copyright © 2014 W3C® (MIT, ERCIM, Keio, Beihang), All Rights Reserved. W3C
|
|
|
|
* liability, trademark and document use rules apply.
|
|
|
|
*/
|
|
|
|
|
2015-03-31 06:05:33 +03:00
|
|
|
// To implement FontFaceSet's iterator until we can use setlike.
|
|
|
|
dictionary FontFaceSetIteratorResult
|
|
|
|
{
|
|
|
|
required any value;
|
|
|
|
required boolean done;
|
|
|
|
};
|
|
|
|
|
|
|
|
// To implement FontFaceSet's iterator until we can use setlike.
|
|
|
|
[NoInterfaceObject]
|
|
|
|
interface FontFaceSetIterator {
|
|
|
|
[Throws] FontFaceSetIteratorResult next();
|
|
|
|
};
|
|
|
|
|
2015-03-31 06:05:33 +03:00
|
|
|
callback FontFaceSetForEachCallback = void (FontFace value, FontFace key, FontFaceSet set);
|
|
|
|
|
2014-10-02 06:32:05 +04:00
|
|
|
enum FontFaceSetLoadStatus { "loading", "loaded" };
|
|
|
|
|
|
|
|
// Bug 1072762 is for the FontFaceSet constructor.
|
|
|
|
// [Constructor(sequence<FontFace> initialFaces)]
|
|
|
|
[Pref="layout.css.font-loading-api.enabled"]
|
|
|
|
interface FontFaceSet : EventTarget {
|
|
|
|
|
2015-03-31 06:05:33 +03:00
|
|
|
// Emulate setlike behavior until we can use that directly.
|
|
|
|
readonly attribute unsigned long size;
|
2014-10-02 06:32:05 +04:00
|
|
|
[Throws] void add(FontFace font);
|
|
|
|
boolean has(FontFace font);
|
2015-05-13 05:24:34 +03:00
|
|
|
boolean delete(FontFace font);
|
2014-10-02 06:32:05 +04:00
|
|
|
void clear();
|
2015-03-31 06:05:33 +03:00
|
|
|
[NewObject] FontFaceSetIterator entries();
|
2014-10-02 06:32:05 +04:00
|
|
|
// Iterator keys();
|
2015-03-31 06:05:33 +03:00
|
|
|
[NewObject, Alias=keys, Alias="@@iterator"] FontFaceSetIterator values();
|
2015-03-31 06:05:33 +03:00
|
|
|
[Throws] void forEach(FontFaceSetForEachCallback cb, optional any thisArg);
|
2014-10-02 06:32:05 +04:00
|
|
|
|
|
|
|
// -- events for when loading state changes
|
|
|
|
attribute EventHandler onloading;
|
|
|
|
attribute EventHandler onloadingdone;
|
|
|
|
attribute EventHandler onloadingerror;
|
|
|
|
|
|
|
|
// check and start loads if appropriate
|
|
|
|
// and fulfill promise when all loads complete
|
2015-06-27 04:41:10 +03:00
|
|
|
[NewObject] Promise<sequence<FontFace>> load(DOMString font, optional DOMString text = " ");
|
2014-10-02 06:32:05 +04:00
|
|
|
|
|
|
|
// return whether all fonts in the fontlist are loaded
|
|
|
|
// (does not initiate load if not available)
|
2015-06-27 04:41:10 +03:00
|
|
|
[Throws] boolean check(DOMString font, optional DOMString text = " ");
|
2014-10-02 06:32:05 +04:00
|
|
|
|
|
|
|
// async notification that font loading and layout operations are done
|
|
|
|
[Throws] readonly attribute Promise<void> ready;
|
|
|
|
|
|
|
|
// loading state, "loading" while one or more fonts loading, "loaded" otherwise
|
|
|
|
readonly attribute FontFaceSetLoadStatus status;
|
|
|
|
};
|