com.phloxui
Version:
PhloxUI Ng2+ Framework
207 lines (206 loc) • 26 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
// unsupported: template constraints.
/**
* <p style="text-indent: 2em;">
* An interface for component class having navigation mechanism. For example, a menu bar having
* menu items to navigate through each page should implement this interface.
* </p>
*
* \@typeparam T A type of <code>navigatee</code> item can be navigated by this <code>navigator</code>.
*
* @author shiorin, tee4cute
* @see [[INavigatee]]
* @record
* @template T
*/
export function INavigator() { }
function INavigator_tsickle_Closure_declarations() {
/**
* <p style="text-indent: 1em;">
* Get <code>navigatee</code> ([[INavigatee]]) items can be navigated by this <code>navigator</code>.
* </p>
*
* \@return An array of <code>navigatee</code> ([[INavigatee]]) items can be navigated by this <code>navigator</code>.
* @type {?}
*/
INavigator.prototype.getItems;
/**
* <p style="text-indent: 1em;">
* Get number of <code>navigatee</code> ([[INavigatee]]) items can be navigated by this <code>navigator</code>.
* This must be the same value as [[getItems]]'s length.
* </p>
*
* \@return The <code>navigatee</code> ([[INavigatee]]) item count.
* @type {?}
*/
INavigator.prototype.getItemCount;
/**
* <p style="text-indent: 1em;">
* Get current active <code>navigatee</code> ([[INavigatee]]) item. In most scenarios, this method should return the item
* representing the component (page) being displayed by this <code>navigator</code>.
* </p>
*
* \@return The current active <code>navigatee</code> ([[INavigatee]]) item being displayed by this <code>navigator</code>.
* Returns <code>null</code> if there is no current active item.
* @type {?}
*/
INavigator.prototype.getActiveItem;
/**
* <p style="text-indent: 1em;">
* Get current active <code>navigatee</code> ([[INavigatee]]) item's index. The value returned from this method must be an
* index of array returning from method [[getItems]].
* </p>
*
* \@return The index of <code>navigatee</code> ([[INavigatee]]) item currently active. Returns <code>-1</code> if there is no
* current active item.
* @type {?}
*/
INavigator.prototype.getActiveIndex;
/**
* <p style="text-indent: 1em;">
* Find the index of the given <code>navigatee</code> <code><b>item</b></code> in the items array returned from method [[getItems]].
* </p>
*
* \@param item The <code>navigatee</code> item to find the index.
* \@return The index of the given <code><b>item</b></code>. Returns <code>-1</code> if not found.
* @type {?}
*/
INavigator.prototype.getItemIndex;
/**
* <p style="text-indent: 1em;">
* Find the index of <code>navigatee</code> item having <code>item name</code> ([[INavigatee.getName]]) matches the <code><b>name</b></code>
* passed as a parameter.
* </p>
*
* \@param name The name of <code>navigatee</code> item to find the index.
* \@return The index of the <code>navigatee</code> item having <code>item name</code> ([[INavigatee.getName]]) matches the <code><b>name</b></code>
* passed as a parameter. Returns <code>-1</code> if not found.
* @type {?}
*/
INavigator.prototype.getItemIndexByName;
/**
* <p style="text-indent: 1em;">
* Get the <code>navigatee</code> item ([[INavigatee]]) by the given <code><b>idx</b></code>.
* </p>
*
* \@param idx The <code>navigatee</code> item array index (starting from <code>0</code>).
* \@return The <code>navigatee</code> item ([[INavigatee]]) at the specified <code><b>idx</b></code>. If the specified <code><b>idx</b></code> is
* out of bound, this method will returns <code>null</code> without throwing any exceptions.
* @type {?}
*/
INavigator.prototype.getItemByIndex;
/**
* <p style="text-indent: 1em;">
* Get the <code>navigatee</code> item ([[INavigatee]]) by the given item <code><b>name</b></code>.
* </p>
*
* \@param name The name of <code>navigatee</code> item.
* \@return The <code>navigatee</code> item having the name ([[INavigatee.getName]]) matches the <code><b>name</b></code> passed as a parameter.
* Returns <code>null</code> if not found.
* @type {?}
*/
INavigator.prototype.getItemByName;
/**
* <p style="text-indent: 1em;">
* Set <code>navigatee</code> items ([[INavigatee]]) into this <code>navigator</code>.
* </p>
*
* \@param items The <code>navigatee</code> items ([[INavigatee]]) to be set into this <code>navigator</code>.
* @type {?}
*/
INavigator.prototype.setItems;
/**
* <p style="text-indent: 1em;">
* Add a new <code>navigatee</code> <code><b>item</b></code> ([[INavigatee]]) into this <code>navigator</code>. This method will check that there already is the
* given <code><b>item</b></code> in this <code>navigator</code> or not. If yes, the <code><b>item</b></code> will not be added and this method
* will return <code>false</code>.
* </p>
*
* \@param item A new <code>navigatee</code> item ([[INavigatee]]) to be added into this <code>navigator</code>.
* \@return Returns <code>true</code> if the given <code><b>item</b></code> is newly added into this <code>navigator</code>. Otherwise, returns
* <code>false</code>.
* @type {?}
*/
INavigator.prototype.addItem;
/**
* <p style="text-indent: 1em;">
* Remove the given <code>navigatee</code> <code><b>item</b></code> ([[INavigatee]]) from this <code>navigator</code>. If the given <code><b>item</b></code> is
* not currently in this <code>navigator</code>, this method will do nothing and return <code>false</code>.
* </p>
*
* \@param item The <code>navigatee</code> item to be removed from this <code>navigator</code>.
* \@return Returns <code>true</code> if the given <code><b>item</b></code> is in this <code>navigator</code> and successfully removed. Otherwise, returns
* <code>false</code>.
* @type {?}
*/
INavigator.prototype.removeItem;
/**
* <p style="text-indent: 1em;">
* To check that the given <code>navigatee</code> <code><b>item</b></code> ([[INavigatee]]) is currently in this <code>navigator</code> or not.
* </p>
*
* \@param item The <code>navigatee</code> item to be checked.
* \@return Returns <code>true</code> if the given <code><b>item</b></code> is currently in this <code>navigator</code>. Otherwise, returns <code>false</code>.
* @type {?}
*/
INavigator.prototype.containsItem;
/**
* <p style="text-indent: 1em;">
* Navigate this <code>navigator</code> to the given <code><b>item</b></code> ([[INavigatee]]). This method returns <code>Promise</code> to allow the navigation to be
* asynchronous. If the <code><b>item</b></code> is not in this <code>navigator</code>, this method will suddenly return resolved <code>Promise</code> having result value
* <code>"false"</code>. Otherwise, it'll return a <code>Promise</code> which will be resolved when the navigation is done with result value <code>"true"</code>. The
* navigated-to <code><b>item</b></code> will be set <code>active</code> flag to <code>true</code> and all other <code>navigatee</code> items in this <code>navigator</code>
* will be set <code>active</code> flag to <code>false</code>.
* </p>
*
* \@param item The <code>navigatee</code> item to be navigated to.
* \@param options The <code>options</code> object used for the navigation. This will depend on each navigator implementation.
* \@return A <code>Promise</code> which will be resolved when the navigation is done with result value <code>"true"</code>. If the given <code><b>item</b></code> is not
* in this <code>navigator</code>, this method will return a resolved <code>Promise</code> with result value <code>"false"</code>.
* @type {?}
*/
INavigator.prototype.navigateTo;
/**
* <p style="text-indent: 1em;">
* Navigate this <code>navigator</code> to the given <code>navigatee</code> item <code><b>idx</b></code>. This method returns <code>Promise</code> to allow the navigation to be
* asynchronous. If the given <code><b>idx</b></code> is out of bound, this method will suddenly return resolved <code>Promise</code> having result value <code>"false"</code>.
* Otherwise, it'll return a <code>Promise</code> which will be resolved when the navigation is done with result value <code>"true"</code>. The navigated-to <code><b>item</b></code>
* will be set <code>active</code> flag to <code>true</code> and all other <code>navigatee</code> items in this <code>navigator</code> will be set <code>active</code> flag to
* <code>false</code>.
* </p>
*
* \@param idx The <code>navigatee</code> item <code><b>idx</b></code> to be navigated to.
* \@param options The <code>options</code> object used for the navigation. This will depend on each navigator implementation.
* \@return A <code>Promise</code> which will be resolved when the navigation is done with result value <code>"true"</code>. If the given <code><b>idx</b></code> is out of
* bound, this method will return a resolved <code>Promise</code> with result value <code>"false"</code>.
* @type {?}
*/
INavigator.prototype.navigateToIndex;
/**
* <p style="text-indent: 1em;">
* Navigate this <code>navigator</code> to the given <code>navigatee</code> item <code><b>name</b></code>. This method returns <code>Promise</code> to allow the navigation to be
* asynchronous. If the given item <code><b>name</b></code> does not exist, this method will suddenly return resolved <code>Promise</code> having result value <code>"false"</code>.
* Otherwise, it'll return a <code>Promise</code> which will be resolved when the navigation is done with result value <code>"true"</code>. The navigated-to <code><b>item</b></code>
* will be set <code>active</code> flag to <code>true</code> and all other <code>navigatee</code> items in this <code>navigator</code> will be set <code>active</code> flag to
* <code>false</code>.
* </p>
*
* \@param name The <code>navigatee</code> item <code><b>name</b></code> to be navigated to.
* \@param options The <code>options</code> object used for the navigation. This will depend on each navigator implementation.
* \@return A <code>Promise</code> which will be resolved when the navigation is done with result value <code>"true"</code>. If the given item <code><b>name</b></code> does not
* exist, this method will return a resolved <code>Promise</code> with result value <code>"false"</code>.
* @type {?}
*/
INavigator.prototype.navigateToName;
/**
* <p style="text-indent: 1em;">
* Reset this <code>navigator</code> to the original state.
* </p>
* @type {?}
*/
INavigator.prototype.reset;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"INavigator.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/INavigator.ts"],"names":[],"mappings":"","sourcesContent":["import { INavigatee } from './INavigatee';\n\n/**\n * <p style=\"text-indent: 2em;\">\n * An interface for component class having navigation mechanism. For example, a menu bar having\n * menu items to navigate through each page should implement this interface.\n * </p>\n *\n * @typeparam T A type of <code>navigatee</code> item can be navigated by this <code>navigator</code>.\n *\n * @author shiorin, tee4cute\n * @see [[INavigatee]]\n */\nexport interface INavigator<T extends INavigatee> {\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Get <code>navigatee</code> ([[INavigatee]]) items can be navigated by this <code>navigator</code>.\n     * </p>\n     *\n     * @returns An array of <code>navigatee</code> ([[INavigatee]]) items can be navigated by this <code>navigator</code>.\n     */\n    getItems(): T[];\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Get number of <code>navigatee</code> ([[INavigatee]]) items can be navigated by this <code>navigator</code>.\n     * This must be the same value as [[getItems]]'s length.\n     * </p>\n     *\n     * @returns The <code>navigatee</code> ([[INavigatee]]) item count.\n     */\n    getItemCount(): number;\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Get current active <code>navigatee</code> ([[INavigatee]]) item. In most scenarios, this method should return the item\n     * representing the component (page) being displayed by this <code>navigator</code>.\n     * </p>\n     *\n     * @returns The current active <code>navigatee</code> ([[INavigatee]]) item being displayed by this <code>navigator</code>.\n     * Returns <code>null</code> if there is no current active item.\n     */\n    getActiveItem(): T;\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Get current active <code>navigatee</code> ([[INavigatee]]) item's index. The value returned from this method must be an\n     * index of array returning from method [[getItems]].\n     * </p>\n     *\n     * @returns The index of <code>navigatee</code> ([[INavigatee]]) item currently active. Returns <code>-1</code> if there is no\n     * current active item.\n     */\n    getActiveIndex(): number;\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Find the index of the given <code>navigatee</code> <code><b>item</b></code> in the items array returned from method [[getItems]].\n     * </p>\n     *\n     * @param item The <code>navigatee</code> item to find the index.\n     * @returns The index of the given <code><b>item</b></code>. Returns <code>-1</code> if not found.\n     */\n    getItemIndex(item: T): number;\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Find the index of <code>navigatee</code> item having <code>item name</code> ([[INavigatee.getName]]) matches the <code><b>name</b></code>\n     * passed as a parameter.\n     * </p>\n     *\n     * @param name The name of <code>navigatee</code> item to find the index.\n     * @returns The index of the <code>navigatee</code> item having <code>item name</code> ([[INavigatee.getName]]) matches the <code><b>name</b></code>\n     * passed as a parameter. Returns <code>-1</code> if not found.\n     */\n    getItemIndexByName(name: string): number;\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Get the <code>navigatee</code> item ([[INavigatee]]) by the given <code><b>idx</b></code>.\n     * </p>\n     *\n     * @param idx The <code>navigatee</code> item array index (starting from <code>0</code>).\n     * @returns The <code>navigatee</code> item ([[INavigatee]]) at the specified <code><b>idx</b></code>. If the specified <code><b>idx</b></code> is\n     * out of bound, this method will returns <code>null</code> without throwing any exceptions.\n     */\n    getItemByIndex(idx: number): T;\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Get the <code>navigatee</code> item ([[INavigatee]]) by the given item <code><b>name</b></code>.\n     * </p>\n     *\n     * @param name The name of <code>navigatee</code> item.\n     * @returns The <code>navigatee</code> item having the name ([[INavigatee.getName]]) matches the <code><b>name</b></code> passed as a parameter.\n     * Returns <code>null</code> if not found.\n     */\n    getItemByName(name: string): T;\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Set <code>navigatee</code> items ([[INavigatee]]) into this <code>navigator</code>.\n     * </p>\n     *\n     * @param items The <code>navigatee</code> items ([[INavigatee]]) to be set into this <code>navigator</code>.\n     */\n    setItems(items: T[]): void;\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Add a new <code>navigatee</code> <code><b>item</b></code> ([[INavigatee]]) into this <code>navigator</code>. This method will check that there already is the\n     * given <code><b>item</b></code> in this <code>navigator</code> or not. If yes, the <code><b>item</b></code> will not be added and this method\n     * will return <code>false</code>.\n     * </p>\n     *\n     * @param item A new <code>navigatee</code> item ([[INavigatee]]) to be added into this <code>navigator</code>.\n     * @returns Returns <code>true</code> if the given <code><b>item</b></code> is newly added into this <code>navigator</code>. Otherwise, returns\n     * <code>false</code>.\n     */\n    addItem(item: T): boolean;\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Remove the given <code>navigatee</code> <code><b>item</b></code> ([[INavigatee]]) from this <code>navigator</code>. If the given <code><b>item</b></code> is\n     * not currently in this <code>navigator</code>, this method will do nothing and return <code>false</code>.\n     * </p>\n     *\n     * @param item The <code>navigatee</code> item to be removed from this <code>navigator</code>.\n     * @returns Returns <code>true</code> if the given <code><b>item</b></code> is in this <code>navigator</code> and successfully removed. Otherwise, returns\n     * <code>false</code>.\n     */\n    removeItem(item: T): boolean;\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * To check that the given <code>navigatee</code> <code><b>item</b></code> ([[INavigatee]]) is currently in this <code>navigator</code> or not.\n     * </p>\n     *\n     * @param item The <code>navigatee</code> item to be checked.\n     * @returns Returns <code>true</code> if the given <code><b>item</b></code> is currently in this <code>navigator</code>. Otherwise, returns <code>false</code>.\n     */\n    containsItem(item: T): boolean;\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Navigate this <code>navigator</code> to the given <code><b>item</b></code> ([[INavigatee]]). This method returns <code>Promise</code> to allow the navigation to be\n     * asynchronous. If the <code><b>item</b></code> is not in this <code>navigator</code>, this method will suddenly return resolved <code>Promise</code> having result value\n     * <code>\"false\"</code>. Otherwise, it'll return a <code>Promise</code> which will be resolved when the navigation is done with result value <code>\"true\"</code>. The\n     * navigated-to <code><b>item</b></code> will be set <code>active</code> flag to <code>true</code> and all other <code>navigatee</code> items in this <code>navigator</code>\n     * will be set <code>active</code> flag to <code>false</code>.\n     * </p>\n     *\n     * @param item The <code>navigatee</code> item to be navigated to.\n     * @param options The <code>options</code> object used for the navigation. This will depend on each navigator implementation.\n     * @returns A <code>Promise</code> which will be resolved when the navigation is done with result value <code>\"true\"</code>. If the given <code><b>item</b></code> is not\n     * in this <code>navigator</code>, this method will return a resolved <code>Promise</code> with result value <code>\"false\"</code>.\n     */\n    navigateTo(item: T, options?: any): Promise<boolean>;\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Navigate this <code>navigator</code> to the given <code>navigatee</code> item <code><b>idx</b></code>. This method returns <code>Promise</code> to allow the navigation to be\n     * asynchronous. If the given <code><b>idx</b></code> is out of bound, this method will suddenly return resolved <code>Promise</code> having result value <code>\"false\"</code>.\n     * Otherwise, it'll return a <code>Promise</code> which will be resolved when the navigation is done with result value <code>\"true\"</code>. The navigated-to <code><b>item</b></code>\n     * will be set <code>active</code> flag to <code>true</code> and all other <code>navigatee</code> items in this <code>navigator</code> will be set <code>active</code> flag to\n     * <code>false</code>.\n     * </p>\n     *\n     * @param idx The <code>navigatee</code> item <code><b>idx</b></code> to be navigated to.\n     * @param options The <code>options</code> object used for the navigation. This will depend on each navigator implementation.\n     * @returns A <code>Promise</code> which will be resolved when the navigation is done with result value <code>\"true\"</code>. If the given <code><b>idx</b></code> is out of\n     * bound, this method will return a resolved <code>Promise</code> with result value <code>\"false\"</code>.\n     */\n    navigateToIndex(idx: number, options?: any): Promise<boolean>;\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Navigate this <code>navigator</code> to the given <code>navigatee</code> item <code><b>name</b></code>. This method returns <code>Promise</code> to allow the navigation to be\n     * asynchronous. If the given item <code><b>name</b></code> does not exist, this method will suddenly return resolved <code>Promise</code> having result value <code>\"false\"</code>.\n     * Otherwise, it'll return a <code>Promise</code> which will be resolved when the navigation is done with result value <code>\"true\"</code>. The navigated-to <code><b>item</b></code>\n     * will be set <code>active</code> flag to <code>true</code> and all other <code>navigatee</code> items in this <code>navigator</code> will be set <code>active</code> flag to\n     * <code>false</code>.\n     * </p>\n     *\n     * @param name The <code>navigatee</code> item <code><b>name</b></code> to be navigated to.\n     * @param options The <code>options</code> object used for the navigation. This will depend on each navigator implementation.\n     * @returns A <code>Promise</code> which will be resolved when the navigation is done with result value <code>\"true\"</code>. If the given item <code><b>name</b></code> does not\n     * exist, this method will return a resolved <code>Promise</code> with result value <code>\"false\"</code>.\n     */\n    navigateToName(name: string, options?: any): Promise<boolean>;\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Reset this <code>navigator</code> to the original state.\n     * </p>\n     */\n    reset(): void;\n\n}\n"]}