diff --git a/bbm/LICENSE b/bbm/LICENSE index 16d1fa9b..6d3fd464 100644 --- a/bbm/LICENSE +++ b/bbm/LICENSE @@ -1,6 +1,6 @@ - Apache License - Version 2.0, January 2004 - http://www.apache.org/licenses/ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION @@ -200,9 +200,9 @@ See the License for the specific language governing permissions and limitations under the License. - ========================================================== - IScroll.js - ========================================================== +============================================================= + IScroll.js +============================================================= Copyright (c) 2009-2010 Matteo Spinelli, http://cubiq.org/ @@ -227,9 +227,9 @@ FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - ========================================================== - Plastique Icons - ========================================================== +============================================================= + Plastique Icons +============================================================= Plastique Icon Set by Iconify.it, LLC is licensed under a Creative Commons Attribution-Share Alike 3.0 Unported License. @@ -304,3 +304,72 @@ No term or provision of this License shall be deemed waived and no breach consented to unless such waiver or consent shall be in writing and signed by the party to be charged with such waiver or consent. This License constitutes the entire agreement between the parties with respect to the Work licensed here. There are no understandings, agreements or representations with respect to the Work not specified here. Licensor shall not be bound by any additional provisions that may appear in any communication from You. This License may not be modified without the mutual written agreement of the Licensor and You. The rights granted under, and the subject matter referenced, in this License were drafted utilizing the terminology of the Berne Convention for the Protection of Literary and Artistic Works (as amended on September 28, 1979), the Rome Convention of 1961, the WIPO Copyright Treaty of 1996, the WIPO Performances and Phonograms Treaty of 1996 and the Universal Copyright Convention (as revised on July 24, 1971). These rights and subject matter take effect in the relevant jurisdiction in which the License terms are sought to be enforced according to the corresponding provisions of the implementation of those treaty provisions in the applicable national law. If the standard suite of rights granted under applicable copyright law includes additional rights not granted under this License, such additional rights are deemed to be included in the License; this License is not intended to restrict the license of any rights under applicable law. + +============================================================= + Subway Icons Set for RIM BB10 Dev Samples +============================================================= + + This is small Subway Icons Set released specially for RIM BB10 Dev Samples under CC BY 3.0 license. + + Included icons in three size - 81px, 71px and 61px + + Full set is available on Subway website: + http://subway.pixle.pl/rim/ + + + Creative Commons Attribution 3.0 Unported + http://creativecommons.org/licenses/by/3.0/legalcode + + THE WORK (AS DEFINED BELOW) IS PROVIDED UNDER THE TERMS OF THIS CREATIVE COMMONS PUBLIC LICENSE ("CCPL" OR "LICENSE"). THE WORK IS PROTECTED BY COPYRIGHT AND/OR OTHER APPLICABLE LAW. ANY USE OF THE WORK OTHER THAN AS AUTHORIZED UNDER THIS LICENSE OR COPYRIGHT LAW IS PROHIBITED. + + BY EXERCISING ANY RIGHTS TO THE WORK PROVIDED HERE, YOU ACCEPT AND AGREE TO BE BOUND BY THE TERMS OF THIS LICENSE. TO THE EXTENT THIS LICENSE MAY BE CONSIDERED TO BE A CONTRACT, THE LICENSOR GRANTS YOU THE RIGHTS CONTAINED HERE IN CONSIDERATION OF YOUR ACCEPTANCE OF SUCH TERMS AND CONDITIONS. + + 1. Definitions + + "Adaptation" means a work based upon the Work, or upon the Work and other pre-existing works, such as a translation, adaptation, derivative work, arrangement of music or other alterations of a literary or artistic work, or phonogram or performance and includes cinematographic adaptations or any other form in which the Work may be recast, transformed, or adapted including in any form recognizably derived from the original, except that a work that constitutes a Collection will not be considered an Adaptation for the purpose of this License. For the avoidance of doubt, where the Work is a musical work, performance or phonogram, the synchronization of the Work in timed-relation with a moving image ("synching") will be considered an Adaptation for the purpose of this License. + "Collection" means a collection of literary or artistic works, such as encyclopedias and anthologies, or performances, phonograms or broadcasts, or other works or subject matter other than works listed in Section 1(f) below, which, by reason of the selection and arrangement of their contents, constitute intellectual creations, in which the Work is included in its entirety in unmodified form along with one or more other contributions, each constituting separate and independent works in themselves, which together are assembled into a collective whole. A work that constitutes a Collection will not be considered an Adaptation (as defined above) for the purposes of this License. + "Distribute" means to make available to the public the original and copies of the Work or Adaptation, as appropriate, through sale or other transfer of ownership. + "Licensor" means the individual, individuals, entity or entities that offer(s) the Work under the terms of this License. + "Original Author" means, in the case of a literary or artistic work, the individual, individuals, entity or entities who created the Work or if no individual or entity can be identified, the publisher; and in addition (i) in the case of a performance the actors, singers, musicians, dancers, and other persons who act, sing, deliver, declaim, play in, interpret or otherwise perform literary or artistic works or expressions of folklore; (ii) in the case of a phonogram the producer being the person or legal entity who first fixes the sounds of a performance or other sounds; and, (iii) in the case of broadcasts, the organization that transmits the broadcast. + "Work" means the literary and/or artistic work offered under the terms of this License including without limitation any production in the literary, scientific and artistic domain, whatever may be the mode or form of its expression including digital form, such as a book, pamphlet and other writing; a lecture, address, sermon or other work of the same nature; a dramatic or dramatico-musical work; a choreographic work or entertainment in dumb show; a musical composition with or without words; a cinematographic work to which are assimilated works expressed by a process analogous to cinematography; a work of drawing, painting, architecture, sculpture, engraving or lithography; a photographic work to which are assimilated works expressed by a process analogous to photography; a work of applied art; an illustration, map, plan, sketch or three-dimensional work relative to geography, topography, architecture or science; a performance; a broadcast; a phonogram; a compilation of data to the extent it is protected as a copyrightable work; or a work performed by a variety or circus performer to the extent it is not otherwise considered a literary or artistic work. + "You" means an individual or entity exercising rights under this License who has not previously violated the terms of this License with respect to the Work, or who has received express permission from the Licensor to exercise rights under this License despite a previous violation. + "Publicly Perform" means to perform public recitations of the Work and to communicate to the public those public recitations, by any means or process, including by wire or wireless means or public digital performances; to make available to the public Works in such a way that members of the public may access these Works from a place and at a place individually chosen by them; to perform the Work to the public by any means or process and the communication to the public of the performances of the Work, including by public digital performance; to broadcast and rebroadcast the Work by any means including signs, sounds or images. + "Reproduce" means to make copies of the Work by any means including without limitation by sound or visual recordings and the right of fixation and reproducing fixations of the Work, including storage of a protected performance or phonogram in digital form or other electronic medium. + 2. Fair Dealing Rights. Nothing in this License is intended to reduce, limit, or restrict any uses free from copyright or rights arising from limitations or exceptions that are provided for in connection with the copyright protection under copyright law or other applicable laws. + + 3. License Grant. Subject to the terms and conditions of this License, Licensor hereby grants You a worldwide, royalty-free, non-exclusive, perpetual (for the duration of the applicable copyright) license to exercise the rights in the Work as stated below: + + to Reproduce the Work, to incorporate the Work into one or more Collections, and to Reproduce the Work as incorporated in the Collections; + to create and Reproduce Adaptations provided that any such Adaptation, including any translation in any medium, takes reasonable steps to clearly label, demarcate or otherwise identify that changes were made to the original Work. For example, a translation could be marked "The original work was translated from English to Spanish," or a modification could indicate "The original work has been modified."; + to Distribute and Publicly Perform the Work including as incorporated in Collections; and, + to Distribute and Publicly Perform Adaptations. + For the avoidance of doubt: + + Non-waivable Compulsory License Schemes. In those jurisdictions in which the right to collect royalties through any statutory or compulsory licensing scheme cannot be waived, the Licensor reserves the exclusive right to collect such royalties for any exercise by You of the rights granted under this License; + Waivable Compulsory License Schemes. In those jurisdictions in which the right to collect royalties through any statutory or compulsory licensing scheme can be waived, the Licensor waives the exclusive right to collect such royalties for any exercise by You of the rights granted under this License; and, + Voluntary License Schemes. The Licensor waives the right to collect royalties, whether individually or, in the event that the Licensor is a member of a collecting society that administers voluntary licensing schemes, via that society, from any exercise by You of the rights granted under this License. + The above rights may be exercised in all media and formats whether now known or hereafter devised. The above rights include the right to make such modifications as are technically necessary to exercise the rights in other media and formats. Subject to Section 8(f), all rights not expressly granted by Licensor are hereby reserved. + + 4. Restrictions. The license granted in Section 3 above is expressly made subject to and limited by the following restrictions: + + You may Distribute or Publicly Perform the Work only under the terms of this License. You must include a copy of, or the Uniform Resource Identifier (URI) for, this License with every copy of the Work You Distribute or Publicly Perform. You may not offer or impose any terms on the Work that restrict the terms of this License or the ability of the recipient of the Work to exercise the rights granted to that recipient under the terms of the License. You may not sublicense the Work. You must keep intact all notices that refer to this License and to the disclaimer of warranties with every copy of the Work You Distribute or Publicly Perform. When You Distribute or Publicly Perform the Work, You may not impose any effective technological measures on the Work that restrict the ability of a recipient of the Work from You to exercise the rights granted to that recipient under the terms of the License. This Section 4(a) applies to the Work as incorporated in a Collection, but this does not require the Collection apart from the Work itself to be made subject to the terms of this License. If You create a Collection, upon notice from any Licensor You must, to the extent practicable, remove from the Collection any credit as required by Section 4(b), as requested. If You create an Adaptation, upon notice from any Licensor You must, to the extent practicable, remove from the Adaptation any credit as required by Section 4(b), as requested. + If You Distribute, or Publicly Perform the Work or any Adaptations or Collections, You must, unless a request has been made pursuant to Section 4(a), keep intact all copyright notices for the Work and provide, reasonable to the medium or means You are utilizing: (i) the name of the Original Author (or pseudonym, if applicable) if supplied, and/or if the Original Author and/or Licensor designate another party or parties (e.g., a sponsor institute, publishing entity, journal) for attribution ("Attribution Parties") in Licensor's copyright notice, terms of service or by other reasonable means, the name of such party or parties; (ii) the title of the Work if supplied; (iii) to the extent reasonably practicable, the URI, if any, that Licensor specifies to be associated with the Work, unless such URI does not refer to the copyright notice or licensing information for the Work; and (iv) , consistent with Section 3(b), in the case of an Adaptation, a credit identifying the use of the Work in the Adaptation (e.g., "French translation of the Work by Original Author," or "Screenplay based on original Work by Original Author"). The credit required by this Section 4 (b) may be implemented in any reasonable manner; provided, however, that in the case of a Adaptation or Collection, at a minimum such credit will appear, if a credit for all contributing authors of the Adaptation or Collection appears, then as part of these credits and in a manner at least as prominent as the credits for the other contributing authors. For the avoidance of doubt, You may only use the credit required by this Section for the purpose of attribution in the manner set out above and, by exercising Your rights under this License, You may not implicitly or explicitly assert or imply any connection with, sponsorship or endorsement by the Original Author, Licensor and/or Attribution Parties, as appropriate, of You or Your use of the Work, without the separate, express prior written permission of the Original Author, Licensor and/or Attribution Parties. + Except as otherwise agreed in writing by the Licensor or as may be otherwise permitted by applicable law, if You Reproduce, Distribute or Publicly Perform the Work either by itself or as part of any Adaptations or Collections, You must not distort, mutilate, modify or take other derogatory action in relation to the Work which would be prejudicial to the Original Author's honor or reputation. Licensor agrees that in those jurisdictions (e.g. Japan), in which any exercise of the right granted in Section 3(b) of this License (the right to make Adaptations) would be deemed to be a distortion, mutilation, modification or other derogatory action prejudicial to the Original Author's honor and reputation, the Licensor will waive or not assert, as appropriate, this Section, to the fullest extent permitted by the applicable national law, to enable You to reasonably exercise Your right under Section 3(b) of this License (right to make Adaptations) but not otherwise. + 5. Representations, Warranties and Disclaimer + + UNLESS OTHERWISE MUTUALLY AGREED TO BY THE PARTIES IN WRITING, LICENSOR OFFERS THE WORK AS-IS AND MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND CONCERNING THE WORK, EXPRESS, IMPLIED, STATUTORY OR OTHERWISE, INCLUDING, WITHOUT LIMITATION, WARRANTIES OF TITLE, MERCHANTIBILITY, FITNESS FOR A PARTICULAR PURPOSE, NONINFRINGEMENT, OR THE ABSENCE OF LATENT OR OTHER DEFECTS, ACCURACY, OR THE PRESENCE OF ABSENCE OF ERRORS, WHETHER OR NOT DISCOVERABLE. SOME JURISDICTIONS DO NOT ALLOW THE EXCLUSION OF IMPLIED WARRANTIES, SO SUCH EXCLUSION MAY NOT APPLY TO YOU. + + 6. Limitation on Liability. EXCEPT TO THE EXTENT REQUIRED BY APPLICABLE LAW, IN NO EVENT WILL LICENSOR BE LIABLE TO YOU ON ANY LEGAL THEORY FOR ANY SPECIAL, INCIDENTAL, CONSEQUENTIAL, PUNITIVE OR EXEMPLARY DAMAGES ARISING OUT OF THIS LICENSE OR THE USE OF THE WORK, EVEN IF LICENSOR HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. + + 7. Termination + + This License and the rights granted hereunder will terminate automatically upon any breach by You of the terms of this License. Individuals or entities who have received Adaptations or Collections from You under this License, however, will not have their licenses terminated provided such individuals or entities remain in full compliance with those licenses. Sections 1, 2, 5, 6, 7, and 8 will survive any termination of this License. + Subject to the above terms and conditions, the license granted here is perpetual (for the duration of the applicable copyright in the Work). Notwithstanding the above, Licensor reserves the right to release the Work under different license terms or to stop distributing the Work at any time; provided, however that any such election will not serve to withdraw this License (or any other license that has been, or is required to be, granted under the terms of this License), and this License will continue in full force and effect unless terminated as stated above. + 8. Miscellaneous + + Each time You Distribute or Publicly Perform the Work or a Collection, the Licensor offers to the recipient a license to the Work on the same terms and conditions as the license granted to You under this License. + Each time You Distribute or Publicly Perform an Adaptation, Licensor offers to the recipient a license to the original Work on the same terms and conditions as the license granted to You under this License. + If any provision of this License is invalid or unenforceable under applicable law, it shall not affect the validity or enforceability of the remainder of the terms of this License, and without further action by the parties to this agreement, such provision shall be reformed to the minimum extent necessary to make such provision valid and enforceable. + No term or provision of this License shall be deemed waived and no breach consented to unless such waiver or consent shall be in writing and signed by the party to be charged with such waiver or consent. + This License constitutes the entire agreement between the parties with respect to the Work licensed here. There are no understandings, agreements or representations with respect to the Work not specified here. Licensor shall not be bound by any additional provisions that may appear in any communication from You. This License may not be modified without the mutual written agreement of the Licensor and You. + The rights granted under, and the subject matter referenced, in this License were drafted utilizing the terminology of the Berne Convention for the Protection of Literary and Artistic Works (as amended on September 28, 1979), the Rome Convention of 1961, the WIPO Copyright Treaty of 1996, the WIPO Performances and Phonograms Treaty of 1996 and the Universal Copyright Convention (as revised on July 24, 1971). These rights and subject matter take effect in the relevant jurisdiction in which the License terms are sought to be enforced according to the corresponding provisions of the implementation of those treaty provisions in the applicable national law. If the standard suite of rights granted under applicable copyright law includes additional rights not granted under this License, such additional rights are deemed to be included in the License; this License is not intended to restrict the license of any rights under applicable law. \ No newline at end of file diff --git a/bbm/README.md b/bbm/README.md index de95240b..cf2222f7 100644 --- a/bbm/README.md +++ b/bbm/README.md @@ -1,4 +1,15 @@ -This sample is based on the Jam Americas 2012 lab sample that was made available here: -https://github.com/blackberry/BB10-WebWorks-Community-Samples/tree/master/bbm +This application provides a look at **blackberry.bbm.platform** as well as **blackberry.invoke** APIs that will enable developers to leverage BlackBerry Messenger integration within their BlackBerry 10 applications. -Refer to the original sample for more information regarding the UI implementation, however please note that the actual BBM API implementation has since changed, and this sample should be used for reference regarding functionality implementation. \ No newline at end of file +To separate the BBM functionality from the remaining application, all relevant BBM implementation was implemented in **bbm.js** while the remaining files are leveraged to configure UI components, and define actions (click event listeners) connecting those components to the API functionality. + +#Known Issues + +**blackberry.bbm.platform.self.setDisplayPicture** +* Not currently working. +* Can be replaced with the **Set Avatar** invocation. + +**Start Chat** +* Should display Contact Picker if no **uri** is provided; not currently working. +* Can be replaced with the **Share Text* invocation (provide empty **data** string.) +* If a URI is provided that exists in the users's BBM Contact List, a chat will be immediately started; working as intended. +* If a URI is provided that does not exist in the user's BBM Contact List, an invitation to join BBM will be sent instead; working as intended. \ No newline at end of file diff --git a/bbm/config.xml b/bbm/config.xml index c1d7ba2b..a92b403d 100644 --- a/bbm/config.xml +++ b/bbm/config.xml @@ -19,40 +19,27 @@ - BBM Sample - Research In Motion - - + BBM APIs + Oros - - - - - - - - - - - - - - - bbm_connect - - - - + + + + + + + bbm_connect + \ No newline at end of file diff --git a/bbm/css/bbui-0.9.5.css b/bbm/css/bbui-0.9.5.css new file mode 100644 index 00000000..f29d156c --- /dev/null +++ b/bbm/css/bbui-0.9.5.css @@ -0,0 +1,5389 @@ +/* +* Copyright 2010-2011 Research In Motion Limited. +* +* Licensed under the Apache License, Version 2.0 (the "License"); +* you may not use this file except in compliance with the License. +* You may obtain a copy of the License at +* +* http://www.apache.org/licenses/LICENSE-2.0 +* +* Unless required by applicable law or agreed to in writing, software +* distributed under the License is distributed on an "AS IS" BASIS, +* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +* See the License for the specific language governing permissions and +* limitations under the License. +*/ + +body, html { + padding:0; + margin:0; + font-family: "Slate Pro",Slate,"Myriad Pro","BBAlpha Sans",Helvetica; + font-size: 12pt; + overflow:visible; + user-select: none; + -webkit-user-select: none; +} + +@-webkit-keyframes bbUI-fade-in +{ + 0% { opacity: 0; } + 100% { opacity: 1; } +} + +@-webkit-keyframes bbUI-fade-out +{ + 0% { opacity: 1; } + 100% { opacity: 0; } +} + +@-webkit-keyframes bbUI-slide-left +{ + 0% { left: 450px; } + 100% { left: 0px; } +} + +@-webkit-keyframes bbUI-slide-out-left +{ + 0% { left: 0px; } + 100% { left: -720px; } +} + +@-webkit-keyframes bbUI-slide-right +{ + 0% { left: -450px; } + 100% { left: 0px; } +} + +@-webkit-keyframes bbUI-slide-out-right +{ + 0% { left: 0px; } + 100% { left: 720px; } +} + +@-webkit-keyframes bbUI-slide-out-up +{ + 0% { top: 0px; } + 100% { top: -1280px; } +} + +@-webkit-keyframes bbUI-slide-up +{ + 0% { top: 800px; } + 100% { top: 0px; } +} + +@-webkit-keyframes bbUI-slide-out-down +{ + 0% { top: 0px; } + 100% { top: 1280px; } +} + +@-webkit-keyframes bbUI-slide-down +{ + 0% { top: -800px; } + 100% { top: 0px; } +} + +::-webkit-scrollbar { + width: 0px; + height: 0px; +} + +.bb-hires-screen { + font-size: 16pt; +} + +.bb-bb10-lowres-screen { + font-size: 16pt; + position:absolute; + top:0px; + left:0px; + bottom:0px; + right: 0px; + background-color: white; +} + +.bb-bb10-hires-screen { + font-size: 30pt; + position:absolute; + top:0px; + left:0px; + bottom:0px; + right: 0px; + background-color: white; +} + +.bb-transition-overlay +{ + z-index: 1000; + position: fixed; + top: 0px; + right:0px; + bottom:0px; + left:0px; +} +/* ================================================= + Scroll Panel + =================================================*/ +.bb-scroll-panel +{ + overflow:auto; + position:relative; +} + +/* ================================================= + PlayBook Swipe Menu + =================================================*/ +.pb-menu-bar { + font-family: "Myriad Pro", sans serif; + position: fixed; + left: 0px; + width: 100%; + clear: both; + margin: 0; + padding: 0; + line-height: 1; + border: 0; + font-size: 100%; + background: #181818; + border-bottom: solid #626262 1px; + box-shadow: 0px 2px 2px #888; + color: white; + z-index:1002; + height: 100px; + top: -104px; +} + +.pb-menu-bar ul { + float: right; + list-style: none; + margin: 0; + padding-left: 15px; + border: 0; + position: relative; + border-left: solid #626262 1px; +} + +.pb-menu-bar ul li { + margin: 0 2px 0 2px; + border: 0; + cursor: pointer; + text-align: center; + float: left; + font-size: 16pt; + padding-right: 15px; +} + +.pb-menu-bar img +{ + height: 65px; + width: 65px; +} + +.pb-menu-bar-caption +{ + padding-top: 10px; + +} + +/* ================================================= + BB10 Slider + =================================================*/ + @-webkit-keyframes explode { + 0% { -webkit-transform: scale(0); } + 70% { + -webkit-transform: scale(1.2); + -webkit-animation-timing-function: ease-in; + } + 100% { -webkit-transform: scale(1); } +} + +@-webkit-keyframes implode { + 0% { -webkit-transform: scale(1); } + 20% { + -webkit-transform: scale(1.2); + -webkit-animation-timing-function: ease-in; + } + 100% { -webkit-transform: scale(0); } +} + +.bb-bb10-slider-lowres +{ + margin: 1.8em; +} + +.bb-bb10-slider-lowres .outer +{ + display: inline-block; + padding: 0.2em; + position: relative; + padding: 0px; + height: 0.4em; + border-radius: 0.2em; + width:100%; +} + +.bb-bb10-slider-lowres .bb-bb10-slider-outer-dark +{ + background: #070707; + border-top: 1px solid rgba(255,255,255,0.05); + border-right: 1px solid rgba(255,255,255,0.1); + border-left: 1px solid rgba(255,255,255,0.05); + border-bottom: 1px solid rgba(255,255,255,0.4); +} + +.bb-bb10-slider-lowres .bb-bb10-slider-outer-light +{ + background: -webkit-linear-gradient(top, #C9C9C9 0%, #DEDEDE 100%); + border-top: 1px solid #9B9B9B; + border-right: 1px solid #9B9B9B; + border-left: 1px solid #9B9B9B; + border-bottom: 1px solid #C8C8C8; +} + +.bb-bb10-slider-lowres .halo { + margin: 12px; + border-radius: 30px; + width: 60px; + height: 60px; + position: absolute; + display: inline-block; + -webkit-animation-duration: 0.3s; + -webkit-animation-iteration-count: 1; + -webkit-animation-timing-function: linear; + -webkit-scale-origin: center center; + -webkit-transform: scale(0); +} + +.bb-bb10-slider-lowres .indicator +{ + display: inline-block; + padding: 0.5em 1.8em; + cursor: pointer; + position: absolute; + margin: 27px; + width: 28px; + height: 28px; + border-radius: 15px; + padding: 1px; + border: 0px; +} + +.bb-bb10-slider-lowres .bb-bb10-slider-indicator-dark +{ + background: -webkit-linear-gradient(top, #3F3F3F 0%, #252525 100%); + border-top: 1px solid rgba(255,255,255,0.3); + border-right: 1px solid rgba(255,255,255,0.1); + border-left: 1px solid rgba(255,255,255,0.05); + border-bottom: 1px solid rgba(255,255,255,0.025); + box-shadow: 0px 0px 0.2em #030303; +} + +.bb-bb10-slider-lowres .bb-bb10-slider-indicator-light +{ + color: #f9f9f9; + background: -webkit-linear-gradient(top, #F9F9F9 0%, #DDDDDD 100%); + border: 1px solid #BFBFBF; + box-shadow: 0px 0px 0.2em #030303; +} + +.bb-bb10-slider-lowres .indicator-hover-dark { + border-top: 2px solid #555; + border-left: 2px solid #454545; + border-right: 2px solid #454545; + border-bottom: 2px solid #353535; + border: 0px; +} + +.bb-bb10-slider-lowres .indicator-hover-light { + border: 1px solid #BFBFBF; +} + +.bb-bb10-slider-lowres .fill { + position: absolute; + height: 100%; + width: 0px; + border-radius: 0.2em; +} + +.bb-bb10-slider-lowres .inner { + top: -1.9em; + left: -1.9em; + position: absolute; + width: 4em; + height: 4em; + display: inline-block; +} + +.bb-bb10-slider-hires +{ + margin: 1.8em; +} + +.bb-bb10-slider-hires .outer +{ + display: inline-block; + padding: 1px; + position: relative; + padding: 0px; + height: 17px; + border-radius: 0.2em; + width:100%; +} + +.bb-bb10-slider-hires .bb-bb10-slider-outer-dark +{ + background: #070707; + border-top: 2px solid #0C0C0C; + border-right: 2px solid #191919; + border-left: 2px solid #171717; + border-bottom: 2px solid #404040; +} + +.bb-bb10-slider-hires .bb-bb10-slider-outer-light +{ + background: -webkit-linear-gradient(top, #C9C9C9 0%, #DEDEDE 100%); + border-top: 2px solid #9B9B9B; + border-right: 2px solid #9B9B9B; + border-left: 2px solid #9B9B9B; + border-bottom: 2px solid #C8C8C8; +} + +.bb-bb10-slider-hires .halo { + margin: 32px; + border-radius: 50px; + width: 100px; + height: 100px; + position: absolute; + display: inline-block; + -webkit-animation-duration: 0.3s; + -webkit-animation-iteration-count: 1; + -webkit-animation-timing-function: linear; + -webkit-scale-origin: center center; + -webkit-transform: scale(0); +} + +.bb-bb10-slider-hires .indicator +{ + display: inline-block; + padding: 0.5em 1.8em; + cursor: pointer; + position: absolute; + margin: 53px; + width: 56px; + height: 56px; + border-radius: 29px; + padding: 1px; + border: 0px; +} + + +.bb-bb10-slider-hires .bb-bb10-slider-indicator-dark +{ + background: -webkit-linear-gradient(top, #3F3F3F 0%, #252525 100%); + border: 1px solid #595959; + box-shadow: 0px 0px 0.2em #030303; +} + +.bb-bb10-slider-hires .bb-bb10-slider-indicator-light +{ + background: -webkit-linear-gradient(top, #F9F9F9 0%, #DFDFDF 100%); + border: 1px solid #BFBFBF; + box-shadow: 0px 0px 0.2em #030303; +} + +.bb-bb10-slider-hires .indicator-hover-dark { + border-top: 2px solid #555; + border-left: 2px solid #454545; + border-right: 2px solid #454545; + border-bottom: 2px solid #353535; + border: 0px; +} + +.bb-bb10-slider-hires .indicator-hover-light { + border: 2px solid #BFBFBF; +} + +.bb-bb10-slider-hires .fill { + position: absolute; + height: 100%; + width: 0px; + border-radius: 0.2em; +} + +.bb-bb10-slider-hires .inner { + top: -1.9em; + left: -1.9em; + position: absolute; + width: 4em; + height: 4em; + display: inline-block; +} + +/* ================================================= + BB10 Toggle + =================================================*/ +.bb-bb10-toggle-lowres +{ + padding:10px; + height: 34px; + width: 105px; +} + +.bb-bb10-toggle-lowres .outer +{ + height: 34px; + border-radius: 18px; + width:105px; +} + +.bb-bb10-toggle-lowres .bb-bb10-toggle-outer-dark +{ + background: #070707; + border: 1px solid #404040; + color:white; +} + +.bb-bb10-toggle-lowres .bb-bb10-toggle-outer-light +{ + background: -webkit-linear-gradient(top, #D7D7D7 0%, #D2D2D2 100%); + border: 1px solid #9B9B9B; + color: #262626; +} + +.bb-bb10-toggle-lowres .halo { + margin: 12px; + border-radius: 30px; + width: 60px; + height: 60px; + position: absolute; + display: inline-block; + -webkit-animation-duration: 0.3s; + -webkit-animation-iteration-count: 1; + -webkit-animation-timing-function: linear; + -webkit-scale-origin: center center; + -webkit-transform: scale(0); +} + +.bb-bb10-toggle-lowres .indicator +{ + display: inline-block; + padding: 0.5em 1.8em; + cursor: pointer; + position: absolute; + margin: 26px; + width: 28px; + height: 28px; + border-radius: 15px; + padding: 1px; + border: 0px; +} + +.bb-bb10-toggle-lowres .bb-bb10-toggle-indicator-dark +{ + background: -webkit-linear-gradient(top, #3F3F3F 0%, #252525 100%); + border: 1px solid #595959; + box-shadow: 0px 0px 0.2em #030303; +} + +.bb-bb10-toggle-lowres .bb-bb10-toggle-indicator-light +{ + background: -webkit-linear-gradient(top, #F9F9F9 0%, #DFDFDF 100%); + border: 1px solid #BFBFBF; + box-shadow: 0px 0px 0.2em #030303; +} + +.bb-bb10-toggle-lowres .indicator-hover-dark { + border-top: 1px solid #555; + border-left: 1px solid #454545; + border-right: 1px solid #454545; + border-bottom: 1px solid #353535; + border-color:transparent; +} + +.bb-bb10-toggle-lowres .indicator-hover-light { + border: 1px solid #BFBFBF; +} + +.bb-bb10-toggle-lowres .fill { + position: static; + height: 34px; + width: 105px; + overflow:hidden; + border-radius: 18px; +} + +.bb-bb10-toggle-lowres .inner { + position: relative; + width: 155px; + height: 34px; + left: -65px; +} + +.bb-bb10-toggle-lowres .yes { + height: 34px; + line-height: 44px; + vertical-align: middle; + display:table-cell; + float: right; + width: 43px; + white-space:nowrap; + overflow: hidden; + text-align:right; +} + +.bb-bb10-toggle-lowres .no { + height: 34px; + line-height: 44px; + vertical-align: middle; + display:table-cell; + float: right; + width: 43px; + white-space:nowrap; + overflow: hidden; + text-align:left; +} + +.bb-bb10-toggle-lowres .indicator-container { + margin-top: -60px; + margin-left: -23px; +} + +.bb-bb10-toggle-lowres .table { + padding: 0px; + margin:0px; + border-collapse: collapse; +} + +.bb-bb10-toggle-lowres .right { + width: 43px; + padding: 0px; + margin: 0px; +} + +.bb-bb10-toggle-lowres .left { + width: 43px; + padding: 0px; + margin: 0px; +} + +.bb-bb10-toggle-lowres .center { + width: 69px; + padding: 0px; + margin: 0px; +} + + +.bb-bb10-toggle-hires +{ + padding:20px; + height: 68px; + width: 210px; +} + +.bb-bb10-toggle-hires .outer +{ + height: 68px; + border-radius: 36px; + width:210px; +} + +.bb-bb10-toggle-hires .bb-bb10-toggle-outer-dark +{ + background: #070707; + border: 2px solid #404040; + color:white; +} + +.bb-bb10-toggle-hires .bb-bb10-toggle-outer-light +{ + background: -webkit-linear-gradient(top, #D7D7D7 0%, #D2D2D2 100%); + border: 2px solid #9B9B9B; + color: #262626; +} + +.bb-bb10-toggle-hires .halo { + margin: 34px; + border-radius: 50px; + width: 100px; + height: 100px; + position: absolute; + display: inline-block; + -webkit-animation-duration: 0.3s; + -webkit-animation-iteration-count: 1; + -webkit-animation-timing-function: linear; + -webkit-scale-origin: center center; + -webkit-transform: scale(0); +} + +.bb-bb10-toggle-hires .indicator +{ + display: inline-block; + padding: 0.5em 1.8em; + cursor: pointer; + position: absolute; + margin: 53px; + width: 56px; + height: 56px; + border-radius: 29px; + padding: 1px; + border: 0px; +} + +.bb-bb10-toggle-hires .bb-bb10-toggle-indicator-dark +{ + background: -webkit-linear-gradient(top, #3F3F3F 0%, #252525 100%); + border: 1px solid #595959; + box-shadow: 0px 0px 0.2em #030303; +} + +.bb-bb10-toggle-hires .bb-bb10-toggle-indicator-light +{ + background: -webkit-linear-gradient(top, #F9F9F9 0%, #DFDFDF 100%); + border: 1px solid #BFBFBF; + box-shadow: 0px 0px 0.2em #030303; +} + +.bb-bb10-toggle-hires .indicator-hover-dark { + border-top: 2px solid #555; + border-left: 2px solid #454545; + border-right: 2px solid #454545; + border-bottom: 2px solid #353535; + border-color:transparent; +} + +.bb-bb10-toggle-hires .indicator-hover-light { + border: 2px solid #BFBFBF; +} + +.bb-bb10-toggle-hires .fill { + position: static; + height: 68px; + width: 210px; + overflow:hidden; + border-radius: 36px; +} + +.bb-bb10-toggle-hires .inner { + position: relative; + width: 310px; + height: 68px; + left: -130px; +} + +.bb-bb10-toggle-hires .yes { + height: 68px; + line-height: 65px; + vertical-align: middle; + display:table-cell; + float: right; + width: 86px; + white-space:nowrap; + overflow: hidden; + text-align:right; +} + +.bb-bb10-toggle-hires .no { + height: 68px; + line-height: 65px; + vertical-align: middle; + display:table-cell; + float: left; + width: 86px; + white-space:nowrap; + overflow: hidden; + text-align:left; +} + +.bb-bb10-toggle-hires .indicator-container { + margin-top: -119px; + margin-left: -47px; +} + +.bb-bb10-toggle-hires .table { + padding: 0px; + margin:0px; + border-collapse: collapse; +} + +.bb-bb10-toggle-hires .right { + width: 86px; + padding: 0px; + margin: 0px; +} + +.bb-bb10-toggle-hires .left { + width: 86px; + padding: 0px; + margin: 0px; +} + +.bb-bb10-toggle-hires .center { + width: 138px; + padding: 0px; + margin: 0px; +} + +/* ================================================= + Progress Bar + =================================================*/ + +.bb-progress +{ + /*margin: 1.8em;*/ +} + +.bb-progress .outer +{ + display: inline-block; + padding: 0.2em; + border-radius: 0.4em; + position: relative; + padding: 0px; + height: 0.4em; + text-align: left; + border-radius: 0.2em; + width:100%; +} + +.bb-progress-outer-dark +{ + background: #070707; + border-top: 1px solid rgba(255,255,255,0.05); + border-right: 1px solid rgba(255,255,255,0.1); + border-left: 1px solid rgba(255,255,255,0.05); + border-bottom: 1px solid rgba(255,255,255,0.4); +} + +.bb-progress-outer-idle-background-dark +{ + background-image:url(""); + background-repeat: repeat-x; +} + +.bb-progress-outer-idle-background-light +{ + background-image:url(""); + background-repeat: repeat-x; +} + +.bb-progress-outer-light +{ + background-color: #DEDEDE; + border-top: 1px solid #9B9B9B; + border-right: 1px solid #9B9B9B; + border-left: 1px solid #9B9B9B; + border-bottom: 1px solid #C8C8C8; +} + +.bb-progress-fill { + position: absolute; + height: 100%; + width: 0px; + border-radius: 0.2em; + background-repeat: repeat-x; + background-image:url(""); +} + +.bb-progress .inner { + top: -1.9em; + left: -1.9em; + position: absolute; + width: 4em; + height: 4em; + display: inline-block; +} + +/* ================================================= + BB10 Swipe Menu + =================================================*/ +.bb-bb10-menu-bar-lowres { + position: fixed; + left: 0px; + width: 100%; + clear: both; + margin: 0; + padding: 0; + border: 0; + top: -103px; + font-size: 100%; + z-index:1002; + height: 100px; + border-bottom-style: solid; + border-bottom-width: 1px; +} + +.bb-bb10-menu-bar-hires { + position: fixed; + left: 0px; + width: 100%; + clear: both; + margin: 0; + padding: 0; + border: 0; + top: -143px; + font-size: 100%; + z-index:1002; + height: 140px; + border-bottom-style: solid; + border-bottom-width: 2px; +} + +.bb-bb10-menu-bar-dark +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#323232), to(#272727)); + border-bottom-color: #626262; + color: white; +} + +.bb-bb10-menu-bar-light +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#FAFAFA), to(#E0E0E0)); + border-bottom-color: #CFCFCF; + color: black; +} + +.bb-bb10-menu-bar-item-lowres +{ + text-align: center; + cursor: pointer; + float: left; + height: 88px; +} + +.bb-bb10-menu-bar-item-hires +{ + text-align: center; + cursor: pointer; + float: left; + height: 88px; +} + +.bb-bb10-menu-bar-item-lowres img +{ + height: 40px; + width: 40px; + margin-top: 15px; +} + +.bb-bb10-menu-bar-item-hires img +{ + height: 80px; + width: 80px; + margin-top: 10px; +} + +.bb-bb10-menu-bar-item-caption-lowres +{ + font-size: 16pt; + padding-top: 10px; +} + +.bb-bb10-menu-bar-item-caption-hires +{ + font-size: 20pt; + padding-top: 10px; +} + + +/* ================================================= + BB7 Screen Title + =================================================*/ +.bb-hires-screen-title { + position:relative; + top:0px; + left:0px; + right:0px; + background-color:black; + color:white; + padding:4px; + height: 25px; + /*z-index: 100;*/ +} + +.bb-lowres-screen-title { + position:relative; + top:0px; + left:0px; + right:0px; + background-color:black; + color:white; + padding:4px; + height: 20px; +} + +/* ================================================= + BB7 Input Box + =================================================*/ + +.bb-bb7-input { + border-width: 1px; + border-style: solid; + border-color: #C6C6C6; + height:41px; + background-color:#FAFAFA; + width: 100%; +} + +.bb-bb7-input-hires { + height:41px; +} + +.bb-bb7-input-lowres { + height:33px; +} + +/* ================================================= + BB10 Input Box + =================================================*/ + +.bb-bb10-input { + color: black; + border-style: solid; + background-color:#F9F9F9; + width: 100%; + border-top-color: #ACACAC; + border-left-color: #BEBEBE; + border-right-color: #BDBDBD; + border-bottom-color:#C7C7C7; +} + +.bb-bb10-input::-webkit-input-placeholder +{ + color:#4A4A4A; + font-style:italic; +} + +.bb-bb10-input-focused +{ + color: black; + border-style: solid; + background-color:#F9F9F9; + width: 100%; + background-repeat: no-repeat; + background-position: center right; + outline-width: 0; +} + +.bb-bb10-input-focused-hires +{ + border-width: 4px; + background-image:url(""); +} + +.bb-bb10-input-focused-lowres +{ + border-width: 4px; + background-image:url(""); +} + +.bb-bb10-input-hires { + height:79px; + border-radius:4px; + border-width: 2px; + font-size: 27pt; +} + +.bb-bb10-input-lowres { + height:30px; + border-radius:4px; + border-width: 1px; + font-size: 14pt; +} + +/* ================================================= + PlayBook Input Box + =================================================*/ + +.bb-pb-input { + color: black; + border-style: solid; + background-color:white; + width: 100%; + border-top-color: #A7A7A7; + border-left-color: #BBBBBB; + border-right-color: #BBBBBB; + border-bottom-color:#CACACA; + height:35px; + border-radius:4px; + border-width: 1px; + font-size: 14pt; +} + +.bb-pb-input::-webkit-input-placeholder +{ + color:#4A4A4A; + font-style:italic; +} + +.bb-pb-input-focused +{ + color: black; + width: 100%; + background-repeat: no-repeat; + border-top-color: #A7A7A7; + border-left-color: #BBBBBB; + border-right-color: #BBBBBB; + border-bottom-color:#CACACA; + outline-width: 0; + background-position: center right; + background-image:url(""); +} + + +/* ================================================= + BB7 Round panels + =================================================*/ +.bb-playbook-round-panel { + border-radius:3px; + border-width: 1px; + border-style: solid; + border-color: #C6C6C6; + box-shadow:1px 0px 2px #D7D7D7; + background-color: white; + margin-left: 5px; + margin-right: 5px; + margin-bottom: 3px; + margin-top: 3px; + padding: 5px; +} + +/* ================================================= + BB10 Round panels + =================================================*/ +.bb-bb10-round-panel-lowres { + border-radius:5px; + border-width: 1px; + border-style: solid; + margin-left: 5px; + margin-right: 5px; + margin-bottom: 3px; + margin-top: 3px; + padding: 5px; +} + +.bb-bb10-round-panel-hires { + border-radius:10px; + border-width: 2px; + border-style: solid; + margin-left: 10px; + margin-right: 10px; + margin-bottom: 8px; + margin-top: 8px; + padding: 10px; +} + +.bb-bb10-round-panel-light { + border-color: #C6C6C6; + color: Black; + background-color: white; +} + +.bb-bb10-panel-header-lowres +{ + padding-top:5px; + margin-bottom: 5px; + padding-bottom: 3px; + font-size: 14pt; + font-weight: bold; +} + +.bb-bb10-panel-header-hires +{ + padding-top:0px; + margin-bottom: 10px; + padding-bottom: 6px; + font-size: 24pt; + font-weight: bold; +} + +.bb-bb10-panel-header-lowres-light { + border-bottom: solid 1px #DCDBDB; + color: #7C7E80; +} + +.bb-bb10-panel-header-hires-light { + border-bottom: solid 2px #DCDBDB; + color: #7C7E80; +} + + +/* ================================================= + BB7 Buttons + =================================================*/ + +.bb-bb7-button { + border-width:1px; + border-color:#BCBEC2; + border-style: solid; + color: black; + text-align:center; + white-space:nowrap; + vertical-align: middle; + padding-left: 15px; + padding-right: 15px; + display: table-cell; + border-radius:5px; + box-shadow:1px 1px 1px #DCDCDC; + background-clip: padding-box; + background-image: -webkit-gradient(linear, center top, center bottom, from(#F9F9F9), to(#D0D2D4)); +} + +.bb-bb7-button-disabled { + border-width:1px; + border-color:#BDBEBD; + border-style: solid; + color: #636563; + text-align:center; + white-space:nowrap; + vertical-align: middle; + padding-left: 15px; + padding-right: 15px; + display: table-cell; + border-radius:5px; + background-color: #BDBEBD; +} + +.bb-bb7-button-hires { + line-height:54px; + height:54px; +} + +.bb-bb7-button-lowres { + line-height:40px; + height:40px; +} + +.bb-bb7-button-highlight{ + border-width:1px; + border-color:#0060E6; + border-style: solid; + color: White; + text-align:center; + white-space:nowrap; + vertical-align: middle; + padding-left: 15px; + padding-right: 15px; + display: table-cell; + border-radius:5px; + box-shadow:2px 2px 2px #DCDCDC; + background-clip: padding-box; + background-image: -webkit-gradient(linear, center top, center bottom, from(#098CEE), to(#1766DB)); +} + +.button-stretch{ + display:block; +} + + +/* ================================================= + Activity Indicator + =================================================*/ +@-webkit-keyframes activity-rotate { + from { + -webkit-transform: rotate(0deg); + } + to { + -webkit-transform: rotate(360deg); + } +} + +.bb-activity-dark +{ + background-image:url(""); +} + +.bb-activity-light +{ + background-image:url(""); +} + +/* ================================================= + BB10 Activity Indicator + =================================================*/ +.bb-bb10-activity-margin-hires +{ + margin: 10px; +} + +.bb-bb10-activity-margin-lowres +{ + margin: 5px; +} + +.bb-bb10-activity-large-hires +{ + height: 184px; + width: 184px; + background-size: 184px 184px; +} + +.bb-bb10-activity-large-lowres +{ + height: 93px; + width: 93px; + background-size: 93px 93px; +} + +.bb-bb10-activity-medium-hires +{ + height: 93px; + width: 93px; + background-size: 93px 93px; +} + +.bb-bb10-activity-medium-lowres +{ + height: 46px; + width: 46px; + background-size: 46px 46px; +} + +.bb-bb10-activity-small-hires +{ + height: 41px; + width: 41px; + background-size: 41px 41px; +} + +.bb-bb10-activity-small-lowres +{ + height: 21px; + width: 21px; + background-size: 21px 21px; +} + +/* ================================================= + PlayBook Activity Indicator + =================================================*/ + +.bb-pb-activity-margin +{ + margin: 5px; +} + +.bb-pb-activity-large +{ + height: 93px; + width: 93px; + background-size: 93px 93px; +} + +.bb-pb-activity-medium +{ + height: 46px; + width: 46px; + background-size: 46px 46px; +} + +.bb-pb-activity-small +{ + height: 21px; + width: 21px; + background-size: 21px 21px; +} + + +/* ================================================= + BB10 Checkboxes + =================================================*/ +.bb-bb10-checkbox-target-hires +{ + padding: 20px; + height: 54px; + width: 54px; +} + +.bb-bb10-checkbox-target-lowres +{ + padding: 10px; + height: 27px; + width: 27px; +} + +.bb-bb10-checkbox-outer-hires +{ + height: 50px; + width: 50px; + border-width: 2px; + border-radius: 6px; + border-style: solid; +} + +.bb-bb10-checkbox-outer-lowres +{ + height: 26px; + width: 26px; + border-width: 1px; + border-radius: 3px; + border-style: solid; +} + +.bb-bb10-checkbox-inner-hires +{ + height: 40px; + width: 40px; + border-width: 1px; + border-style: solid; + margin: 4px; + border-radius: 2px; +} + +.bb-bb10-checkbox-inner-lowres +{ + height: 20px; + width: 20px; + border-width: 1px; + border-style: solid; + margin: 2px; + border-radius: 1px; +} + +.bb-bb10-checkbox-check-hidden-hires +{ + height: 15px; + width: 18px; + margin-left: 11px; + margin-top: 10px; + opacity: 0.0; +} + +.bb-bb10-checkbox-check-hidden-lowres +{ + height: 7px; + width: 9px; + margin-left: 5px; + margin-top: 5px; + opacity: 0.0; +} + +.bb-bb10-checkbox-check-display-hires +{ + height: 30px; + width: 36px; + margin-left: 2px; + margin-top: 4px; + opacity: 1.0; +} + +.bb-bb10-checkbox-check-display-lowres +{ + height: 15px; + width: 18px; + margin-left: 1px; + margin-top: 2px; + opacity: 1.0; +} + +.bb-bb10-checkbox-check-image +{ + background-image:url(""); + background-repeat: no-repeat; + background-position: center center; + background-size: cover; +} + +.bb-bb10-checkbox-outer-dark +{ + border-top-color: #333333; + border-left-color: #333333; + border-right-color: #333333; + border-bottom-color: #4B4B4B; + background-color: #000000; +} + +.bb-bb10-checkbox-outer-light +{ + border-color: #F3F3F3; + background-image: -webkit-gradient(linear, center top, center bottom, from(#A3A3A3), to(#BFBFBF)); +} + +.bb-bb10-checkbox-inner-dark +{ + border-color: #5F5F5F; + background-image: -webkit-gradient(linear, center top, center bottom, from(#404040), to(#272727)); +} + +.bb-bb10-checkbox-inner-light +{ + border-color: #B2B2B2; + background-image: -webkit-gradient(linear, center top, center bottom, from(#F9F9F9), to(#DDDDDD)); +} + +.bb-bb10-checkbox-outer-disabled-dark +{ + border-color: #333333; + background-image: -webkit-gradient(linear, center top, center bottom, from(#E3E3E3), to(#E3E3E3)); +} + +.bb-bb10-checkbox-outer-disabled-light +{ + border-color: #a1a1a1; + background-image: -webkit-gradient(linear, center top, center bottom, from(#E3E3E3), to(#E3E3E3)); +} + +.bb-bb10-checkbox-inner-disabled-dark +{ + border-color: #d3d3d3; + background-image: -webkit-gradient(linear, center top, center bottom, from(#262626), to(#262626)); +} + +.bb-bb10-checkbox-inner-disabled-light +{ + border-color: #d3d3d3; + background-image: -webkit-gradient(linear, center top, center bottom, from(#c0c0c0), to(#c0c0c0)); +} + + +/* ================================================= + File Input buttons + =================================================*/ + +.bb-bb10-file-button-hires { + position : relative; + width : 100%; + height : 87px; + display :block; + z-index : 100; + margin-top : -86px; + opacity: 0.0; +} + +.bb-bb10-file-button-lowres { + position : relative; + width : 100%; + height : 51px; + display :block; + z-index : 100; + margin-top : -50px; + opacity: 0.0; +} + + +/* ================================================= + BB10 Buttons + =================================================*/ + +.bb-bb10-button-container-light +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#BDBDBD), to(#D4D4D4)); + color: black; + border-top-color: #A3A3A3; + border-bottom-color: #CECECE; + border-left-color: #C3C3C3; + border-right-color: #C4C4C4; +} + +.bb-bb10-button-container-dark +{ + background-color: #0B0B0B; + color: white; + border-color: #333333; + display:inline-block; +} + +.bb-bb10-button-caption-with-image-hires +{ + float:left; + text-align:left; + margin-left: 14px; +} + +.bb-bb10-button-caption-with-image-lowres +{ + float:left; + text-align:left; + margin-left: 7px; +} + +.bb-bb10-button-image-hires +{ + height: 71px; + width: 71px; + float: left; + margin-left: -27px; + margin-top: -4px; + background-position: center center; + background-size: cover; +} + +.bb-bb10-button-image-lowres +{ + height: 29px; + width: 29px; + float: left; + margin-left: -12px; + margin-top: -2px; + background-position: center center; + background-size: cover; +} + +.bb-bb10-button-caption-with-image-only-hires +{ + height:71px; + width:71px; + background-position: center center; + background-size: cover; + margin-top: -4px; + margin-left: -27px; +} + +.bb-bb10-button-caption-with-image-only-lowres +{ + height:29px; + width:29px; + background-position: center center; + background-size: cover; + margin-top: -2px; + margin-left: -12px; +} + +.bb-bb10-button-container-image-only-hires +{ + width: 89px; +} + +.bb-bb10-button-container-image-only-lowres +{ + width: 37px; +} + +.bb-bb10-button-container-hires +{ + border-width:4px; + border-style: solid; + border-radius:10px; + padding: 2px; + margin: 20px; +} + +.bb-bb10-button-container-lowres +{ + border-width:2px; + border-style: solid; + border-radius:4px; + padding: 1px; + margin: 16px; +} + +.bb-bb10-button { + border-style: solid; + text-align:center; + white-space:nowrap; + vertical-align: middle; + display: block; + background-clip: padding-box; +} + +.bb-bb10-button-light { + border-top-color: #B4B4B4; + border-left-color: #C2C2C2; + border-bottom-color: #B4B4B4; + border-right-color: #C8C8C8; + background-image: -webkit-gradient(linear, center top, center bottom, from(#F9F9F9), to(#DDDDDD)); +} + +.bb-bb10-button-dark { + border-color:#5C5C5C; + background-image: -webkit-gradient(linear, center top, center bottom, from(#3F3F3F), to(#262626)); +} + +.bb-bb10-button-disabled-dark { + border-color:#262626; + background-color: #262626; + color: #666666; +} + +.bb-bb10-button-disabled-light { + border-color: #D4D4D4; + background-color: #C1C1C1; + color: #838383; +} + +.bb-bb10-button-hires { + border-width:1px; + border-radius:5px; + line-height:60px; + height:75px; + padding-top:12px; + padding-left: 35px; + padding-right: 35px; + font-size:28pt; +} + +.bb-bb10-button-lowres { + border-width:1px; + border-radius:2px; + line-height:30px; + height:30px; + padding-top:5px; + padding-left: 15px; + padding-right: 15px; + font-size:14pt; +} + + +.bb-bb10-button-stretch{ + display:block; +} + +/* ================================================= + PlayBook Buttons + =================================================*/ + +.bb-pb-button-container-light +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#E2E2E2), to(#D1D1D1)); + border-top-color: #A5A5A5; + border-bottom-color: #BABABA; + border-left-color: #B4B4B4; + border-right-color: #B4B4B4; +} + +.bb-pb-button-font-light { + color: black; +} + +.bb-pb-button-container-dark +{ + background-color: #0B0B0B; + border-color: #333333; + display:inline-block; +} + +.bb-pb-button-font-dark { + color: white; +} + +.bb-pb-button-caption-with-image +{ + float:left; + text-align:left; + margin-left: 7px; +} + +.bb-pb-button-image +{ + height: 29px; + width: 29px; + float: left; + margin-left: -14px; + margin-top: -4px; + background-position: center center; + background-size: cover; +} + +.bb-pb-button-caption-with-image-only +{ + height:29px; + width:29px; + background-position: center center; + background-size: cover; + margin-top: -4px; + margin-left: -14px; +} + +.bb-pb-button-container-image-only +{ + width: 33px; +} + +.bb-pb-button-container +{ + border-width:1px; + border-style: solid; + border-radius:3px; + padding: 2px; + margin: 10px; +} + +.bb-pb-button { + border-style: solid; + text-align:center; + white-space:nowrap; + vertical-align: middle; + display: block; + background-clip: padding-box; + border-width:1px; + border-radius:2px; + line-height:26px; + height:26px; + padding-top:5px; + padding-left: 15px; + padding-right: 15px; + font-size:14pt; +} + +.bb-pb-button-light { + border-top-color: #BCBCBC; + border-left-color: #A7A7A7; + border-bottom-color: #878787; + border-right-color: #A7A7A7; + background-image: -webkit-gradient(linear, center top, center bottom, from(#DCDCDC), to(#FFFFFF)); +} + +.bb-pb-button-dark { + border-color:#5C5C5C; + background-image: -webkit-gradient(linear, center top, center bottom, from(#3F3F3F), to(#262626)); +} + +.bb-pb-button-disabled-dark { + border-color:#262626; + background-color: #262626; + color: #666666; +} + +.bb-pb-button-disabled-light { + border-color: #D4D4D4; + background-color: #C1C1C1; + color: #838383; +} + +.bb-pb-button-stretch{ + display:block; +} + +/* ================================================= + BB10 Title Bar + =================================================*/ +.bb-bb10-title-bar-hires { + position:absolute; + top:0px; + left:0px; + right:0px; + border-bottom-width: 2px; + border-bottom-style: solid; + font-size: 39pt; + z-index:1000; +} + +.bb-bb10-title-bar-portrait-hires { + height:110px; +} + +.bb-bb10-title-bar-landscape-hires { + height:99px; +} + +.bb-bb10-title-bar-caption-hires { + text-align:center; + height:100%; + padding:0px; + margin:0px; + overflow: hidden; + white-space:nowrap; + text-overflow: ellipsis; + text-overflow: -blackberry-fade; +} + +.bb-bb10-title-bar-caption-portrait-hires { + line-height:110px; +} + +.bb-bb10-title-bar-caption-landscape-hires { + line-height:110px; +} + +.bb-bb10-title-bar-caption-details-img-hires { + margin-left: 130px; +} + +.bb-bb10-title-bar-caption-left-hires { + text-align:left; + line-height:110px; + height:100%; + padding:0px; + padding-left: 10px; + margin:0px; + overflow: hidden; + white-space:nowrap; + text-overflow: ellipsis; + text-overflow: -blackberry-fade; +} +.bb-bb10-title-bar-accent-text-hires { + color:#606060; + text-align:left; + padding-top:2px; + padding-left: 10px; + margin-top:-12px; + font-size: 29pt; + overflow: hidden; + white-space:nowrap; + text-overflow: ellipsis; + text-overflow: -blackberry-fade; +} + +.bb-bb10-title-bar-hires img +{ + position:relative; + float:left; + margin-top: -2px; + height:112px; + width:112px; +} + +.bb-bb10-title-bar-lowres { + position:absolute; + top:0px; + left:0px; + right:0px; + font-size: 20pt; + z-index:1000; + border-bottom-width: 1px; + border-bottom-style: solid; +} + +.bb-bb10-title-bar-portrait-lowres { + height:64px; +} + +.bb-bb10-title-bar-landscape-lowres { + height:64px; +} + +.bb-bb10-title-bar-caption-lowres { + text-align:center; + height:100%; + padding:0px; + margin:0px; + width: 100%; + overflow: hidden; + white-space:nowrap; + text-overflow: ellipsis; +} + +.bb-bb10-title-bar-caption-portrait-lowres { + line-height:76px; +} + +.bb-bb10-title-bar-caption-landscape-lowres { + line-height:76px; +} + +.bb-bb10-title-bar-caption-details-img-lowres { + margin-left: 75px; +} + +.bb-bb10-title-bar-caption-left-lowres { + text-align:left; + line-height:76px; + height:100%; + padding:0px; + padding-left: 5px; + margin:0px; + overflow: hidden; + white-space:nowrap; + text-overflow: ellipsis; +} +.bb-bb10-title-bar-accent-text-lowres { + color:#606060; + text-align:left; + margin:0px; + padding-left: 5px; + font-size: 16pt; + overflow: hidden; + white-space:nowrap; + text-overflow: ellipsis; +} + +.bb-bb10-title-bar-lowres img +{ + position:relative; + float:left; + height:64px; + width:64px; +} + + +.bb-bb10-title-bar-dark +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#414141), to(#131313)); + border-bottom-color:#272727; + color:white; + text-shadow: 0px 2px black; +} + +.bb-bb10-title-bar-light +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#FAFAFA), to(#D5D5D5)); + border-bottom-color: #AAAAAA; + color:#262626; + text-shadow: 0px 2px white; +} + +.bb-bb10-titlebar-button-container-light +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#D3D3D3), to(#ACACAC)); + border-color: #B0B0B0; +} + +.bb-bb10-titlebar-button-container-dark +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#2D2D2D), to(#131313)); + border-color: #4E4D4E; +} + +.bb-bb10-titlebar-button-container-hires +{ + position: absolute; + top: 0px; + border-width:2px; + border-style: solid; + border-radius:10px; + padding: 4px; + margin: 15px; +} + +.bb-bb10-titlebar-button-container-lowres +{ + position: absolute; + top: 0px; + border-width:2px; + border-style: solid; + border-radius:4px; + padding: 1px; + margin: 9px; +} + +.bb-bb10-titlebar-button { + border-style: solid; + text-align:center; + white-space:nowrap; + vertical-align: middle; + display: block; + background-clip: padding-box; +} + +.bb-bb10-titlebar-button-light { + border-color: #898989; + background-image: -webkit-gradient(linear, center top, center bottom, from(#FAFAFA), to(#E1E1E1)); +} + +.bb-bb10-titlebar-button-dark { + border-color:#828282; + background-image: -webkit-gradient(linear, center top, center bottom, from(#5C5C5C), to(#363636)); +} + +.bb-bb10-titlebar-button-disabled-dark { + border-color:#262626; + background-color: #262626; + color: #666666; + +} + +.bb-bb10-titlebar-button-disabled-light { + border-color: #D4D4D4; + background-color: #C1C1C1; + color: #838383; +} + +.bb-bb10-titlebar-button-hires { + border-width:1px; + border-radius:5px; + line-height:40px; + height:55px; + padding-top:12px; + padding-left: 35px; + padding-right: 35px; + font-size:28pt; +} + +.bb-bb10-titlebar-button-lowres { + border-width:1px; + border-radius:2px; + line-height:34px; + height:34px; + padding-top:5px; + padding-left: 15px; + padding-right: 15px; + font-size:14pt; +} + +.bb-bb10-titlebar-button-highlight-light { + border-color: #5A5A5A; + background-image: -webkit-gradient(linear, center top, center bottom, from(#636363), to(#878787)); + color: white; + text-shadow: 0px 2px black; +} + +.bb-bb10-titlebar-button-highlight-dark { + border-color:#181818; + background-image: -webkit-gradient(linear, center top, center bottom, from(#252525), to(#171717)); +} + +/* ================================================= + PlayBook Title Bar + =================================================*/ +.pb-title-bar { + height:54px; + border-bottom:solid #626262 1px; + position:absolute; + top:0px; + left:0px; + right:0px; + background-color:#181818; + text-align:center; + color:#626262; + line-height:54px; + font-size: 14pt; + z-index:1000; +} + +.pb-title-bar-back { + position: absolute; + border:solid black 1px; + top:8px; + left:11px; + height:37px; + line-height:35px; + font-size: 14pt; + box-shadow: 0px 2px 0px #2E2E2E; + border-radius:4px; + color:white; + z-index:1001; +} + +.pb-title-bar-back-inner { + border-top: 2px solid #2E2E2E; + padding-left:35px; + padding-right:12px; + padding-top: 3px; + border-radius:4px; + background-image:url(""); + background-repeat: no-repeat; + background-position: 13px 8px; +} + +/* ================================================= + BB10 DropDown Buttons + =================================================*/ + +.bb-bb10-dropdown-container-light +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#C0C0C0), to(#D9D9D9)); + color: black; + border-top-color: #B2B2B2; + border-bottom-color: #B2B2B2; + border-left-color: #BFBEBF; + border-right-color: #BFBFBF; + margin:20px; +} + +.bb-bb10-dropdown-container-dark +{ + color: white; + border-top-color: #232323; + border-left-color: #2A2A2A; + border-right-color: #292929; + border-bottom-color: #5A5A5A; + background-image: -webkit-gradient(linear, center top, center bottom, from(#050505), to(#161616)); + margin:20px; +} + +.bb-bb10-dropdown-container-inner-dark +{ + border-color: #070707; +} + +.bb-bb10-dropdown-container-inner-light +{ + border-color: #CECECE; +} + + +.bb-bb10-dropdown-disabled-dark { + border-color:#262626; + background-color: #262626; + color: #666666; +} + +.bb-bb10-dropdown-disabled-light { + border-color: #D4D4D4; + background-color: #C1C1C1; + color: #838383; +} + +.bb-bb10-dropdown-items +{ + margin-top: 5px; + color:#606060; +} + +.bb-bb10-dropdown-item-lowres +{ + height: 40px; + line-height: 48px; + border-bottom-width: 1px; + border-bottom-style: solid; + font-size: 14pt; + padding-left: 12px; + padding-right: 10px; + vertical-align: center; +} + +.bb-bb10-dropdown-item-hires +{ + height: 97px; + line-height: 100px; + border-bottom-width: 2px; + border-bottom-style: solid; + font-size: 29pt; + padding-left: 18px; + padding-right: 10px; + vertical-align: center; +} + +.bb-bb10-dropdown-selected-image-lowres-dark +{ + float:right; + height:17px; + width:20px; + background-image: url(""); + background-repeat: no-repeat; + background-position: center center; + visibility:hidden; + margin-top:10px; +} + +.bb-bb10-dropdown-selected-image-hires-dark +{ + float:right; + height:31px; + width:36px; + background-image: url(""); + background-repeat: no-repeat; + background-position: center center; + visibility:hidden; + margin-top:35px; + margin-right: 15px; +} + +.bb-bb10-dropdown-selected-image-lowres-light +{ + float:right; + height:17px; + width:20px; + background-image: url(""); + background-repeat: no-repeat; + background-position: center center; + visibility:hidden; + margin-top:10px; +} + +.bb-bb10-dropdown-selected-image-hires-light +{ + float:right; + height:31px; + width:36px; + background-image: url(""); + background-repeat: no-repeat; + background-position: center center; + visibility:hidden; + margin-top:35px; + margin-right: 15px; +} + +.bb-bb10-dropdown-item-dark +{ + border-bottom-color: #373737; +} + +.bb-bb10-dropdown-item-light +{ + border-bottom-color: #B4B4B4; +} + +.bb-bb10-dropdown-item-selected-dark +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#3F3F3F), to(#252525)); + color: white; +} + +.bb-bb10-dropdown-item-selected-light +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#EAEAEA), to(#EDEDED)); + color: black; +} + +.bb-bb10-dropdown-container-hires +{ + border-width:2px; + border-style: solid; + border-radius:4px; + padding: 0px; + height: 95px; + overflow:hidden; +} + +.bb-bb10-dropdown-container-lowres +{ + border-width:1px; + border-style: solid; + border-radius:4px; + padding: 0px; + height: 43px; + overflow:hidden; +} + +.bb-bb10-dropdown-container-inner-lowres +{ + z-index: 10; + border-style: solid; + border-width: 1px; + border-radius: 4px; + padding: 1px; +} + +.bb-bb10-dropdown-container-inner-hires +{ + z-index: 10; + border-style: solid; + border-width: 2px; + border-radius: 4px; + padding: 2px; +} + +.bb-bb10-dropdown-caption-lowres { + position:relative; + display:block; + float: right; + z-index:1; + margin-right:-22px; +} + +.bb-bb10-dropdown-caption-hires { + position:relative; + display:block; + float: right; + font-size: 29pt; + z-index:1; + margin-right:-38px; +} + +.bb-bb10-dropdown-label-hires { + display:table-cell; + float: left; + font-size: 29pt; + margin-left: -20px; +} + +.bb-bb10-dropdown-label-lowres { + display:table-cell; + float: left; + margin-left: -5px; +} + +.bb-bb10-dropdown { + border-style: solid; + white-space:nowrap; + vertical-align: middle; + display: block; + background-clip: padding-box; +} + +.bb-bb10-dropdown-light { + border-top-color: #B1B1B1; + border-left-color: #BFBFBF; + border-bottom-color: #B4B4B4; + border-right-color: #949494; + background-image: -webkit-gradient(linear, center top, center bottom, from(#F9F9F9), to(#E1E1E1)); +} + +.bb-bb10-dropdown-dark { + border-color:#040404; + background-image: -webkit-gradient(linear, center top, center bottom, from(#3F3F3F), to(#252525)); +} + +.bb-bb10-dropdown-inner-light { + border-top-color: #FFFFFF; + border-left-color: #DBDBDB; + border-right-color: #EFEFEF; + border-bottom-color: #E0E0E0; +} + +.bb-bb10-dropdown-inner-dark { + border-top-color: #5D5D5D; + border-left-color: #575757; + border-right-color: #545454; + border-bottom-color: #474747; +} + +.bb-bb10-dropdown-arrow-lowres-dark +{ + position:relative; + float:right; + z-index:2; + display:block; + top: 1px; + height:22px; + width:22px; + background-image: url(""); + background-repeat: no-repeat; + background-position: center center; + opacity:0.0; +} + +.bb-bb10-dropdown-arrow-hires-dark +{ + position:relative; + float:right; + z-index:2; + display:block; + top:11px; + float:right; + height:37px; + width:37px; + background-image: url(""); + background-repeat: no-repeat; + background-position: center center; + opacity:0.0; +} + +.bb-bb10-dropdown-arrow-lowres-light +{ + position:relative; + float:right; + z-index:2; + display:block; + top: 1px; + height:22px; + width:22px; + background-image: url(""); + background-repeat: no-repeat; + background-position: center center; + opacity:0.0; +} + +.bb-bb10-dropdown-arrow-hires-light +{ + position:relative; + float:right; + z-index:2; + display:block; + top:11px; + float:right; + height:37px; + width:37px; + background-image: url(""); + background-repeat: no-repeat; + background-position: center center; + opacity:0.0; +} + +.bb-bb10-dropdown-hires { + border-width:2px; + border-radius:5px; + padding:0px; + border-style:solid; +} + +.bb-bb10-dropdown-inner-hires { + border-width:2px; + border-radius:5px; + line-height:62px; + height:71px; + padding-top:12px; + padding-left: 35px; + padding-right: 35px; + font-size:28pt; +} + +.bb-bb10-dropdown-lowres { + border-width:1px; + border-radius:2px; + padding:0px; + border-style: solid; +} + +.bb-bb10-dropdown-inner-lowres { + border-width:1px; + border-radius:2px; + line-height:30px; + height:30px; + padding-top:5px; + padding-left: 15px; + padding-right: 15px; + font-size:14pt; + border-style:solid; +} + +.bb-bb10-dropdown-stretch{ + display:block; +} + +.bb-bb10-dropdown-highlight-light { + border-top-color: #B1B1B1; + border-left-color: #BFBFBF; + border-bottom-color: #B4B4B4; + border-right-color: #949494; +} + +.bb-bb10-dropdown-highlight-dark { + border-color: #040404; +} + + +/* ================================================= + BB7 DropDown Buttons + =================================================*/ + +.bb-bb7-dropdown { + border-width:1px; + border-color:#BCBEC2; + border-style: solid; + color: black; + text-align:center; + white-space:nowrap; + vertical-align: middle; + padding-left: 15px; + padding-right: 15px; + display: table-cell; + border-radius:5px; + box-shadow:1px 1px 1px #DCDCDC; + background-clip: padding-box; + background-image: -webkit-gradient(linear, center top, center bottom, from(#F9F9F9), to(#D0D2D4)); +} + +.bb-bb7-dropdown-disabled { + border-color:#BDBEBD; + color: #636563; + background-color: #BDBEBD; + background-image: none; +} + +.bb-bb7-dropdown.dropdown-stretch div[data-bb-type="caption"] span { + overflow: hidden; + padding-right:40px; + display: block; +} + +.bb-bb7-dropdown div { + padding-right: 25px; + background-image: url(""); + background-repeat: no-repeat; + background-position: center right; +} + +.bb-bb7-dropdown-hires { + line-height:54px; + height:54px; +} + +.bb-bb7-dropdown-lowres { + line-height:40px; + height:40px; +} + +.bb-bb7-dropdown-highlight{ + border-width:1px; + border-color:#0060E6; + border-style: solid; + color: White; + text-align:center; + white-space:nowrap; + vertical-align: middle; + padding-left: 15px; + padding-right: 15px; + display: table-cell; + border-radius:5px; + box-shadow:2px 2px 2px #DCDCDC; + background-clip: padding-box; + background-image: -webkit-gradient(linear, center top, center bottom, from(#098CEE), to(#1766DB)); +} + +.bb-bb7-dropdown-highlight div { + padding-right: 25px; + background-image: url(""); + background-repeat: no-repeat; + background-position: center right; +} + +.bb-bb7-dropdown-highlight.dropdown-stretch div[data-bb-type="caption"] span { + overflow: hidden; + padding-right:40px; + display: block; + } + +.dropdown-stretch{ + display:block; + +} + + +/* ================================================= + BB5 Buttons + =================================================*/ + +.bb-bb5-button { + display: table-cell; +} + +a.bb5-button { + background: transparent url("") no-repeat scroll top right; + color: White; + display: block; + float: left; + height: 39px; + margin-right: 6px; + padding-right: 10px; /* sliding doors padding */ + text-decoration: none; +} + +a.bb5-button span { + background: transparent url("") no-repeat; + display: block; + line-height: 29px; + padding: 5px 0px 5px 10px; + +} + +a.bb5-button-highlight { + background: transparent url("") no-repeat scroll top right; + background-position: right -39px; + color: White; + display: block; + float: left; + height: 39px; + margin-right: 6px; + padding-right: 10px; /* sliding doors padding */ + text-decoration: none; +} + +a.bb5-button-highlight span { + background: transparent url("") no-repeat; + background-position: left -39px; + display: block; + line-height: 29px; + padding: 5px 0px 5px 10px; + +} + +/* ================================================= + Round Panel + =================================================*/ +.bb-round-panel +{ + margin: 8px; + position:relative; +} + +.bb-round-panel-background { + background-image: url(""); +} + +.bb-round-panel-top-left { + margin-right: 9px; + height: 9px; +} + +.bb-round-panel-top-right { + margin-top: -9px; + margin-left: 9px; + background-position: 100% 0; + height: 9px; + font-size: 2px; +} + +.bb-round-panel-bottom-left { + margin-right: 9px; + background-position: 0 -7px; + height: 9px; + font-size: 2px; +} + +.bb-round-panel-bottom-right { + margin-top: -9px; + margin-left: 9px; + background-position: 100% -7px; + height: 9px; + font-size: 2px; +} + +.bb-round-panel-inside { + border-left: 2px solid #D6D3D6; + border-right: 2px solid #D6D3D6; + background: White; + padding-left: 3px; + padding-right: 3px; + overflow:auto; +} + +/* ================================================= + Label Control Row + =================================================*/ + +.bb-label { + margin-top: 5px; + margin-bottom: 5px; +} +.bb-label-control-horizontal-row .bb-label { + float:left; + position:relative; + top:10px; +} + +.bb-label-control-horizontal-row { + height:56px; + /*border:1px solid black;*/ + margin-bottom:4px; +} + +.bb-label-control-horizontal-row .bb-bb7-button { + float:right; +} + +.bb-label-control-horizontal-row .bb-bb7-button-highlight { + float:right; +} + +.bb-label-control-horizontal-row .bb-bb5-button { + float:right; +} + + +/* ================================================= + Label Control Rows + =================================================*/ + +.bb-bb7-label-control-rows { + margin:0px; + padding:0px; + width:100%; +} + +/* ================================================= + BB10 Label Control Rows + =================================================*/ + +.bb-bb10-label-control-rows { + margin:0px; + padding:0px; + width:100%; +} + +.bb-bb10-label-control-label-row-hires +{ + vertical-align: text-bottom; + height:38px; +} + +.bb-bb10-label-control-label-row-lowres +{ + vertical-align: text-bottom; + height:22px; +} + +.bb-bb10-label-control-label-lowres +{ + position:relative; + top: 7px; + bottom:0px; + left:0px; + font-size: 12pt; + height:15px; + vertical-align: text-bottom; +} + +.bb-bb10-label-control-label-hires +{ + position:relative; + top: 10px; + bottom:0px; + left:0px; + font-size: 21pt; + height:30px; + vertical-align: text-bottom; +} + + +/* ================================================= + Radio button BB10 + =================================================*/ + +.bb-bb10-radio-container-hires-dark +{ + height: 76px; + width: 76px; + margin:0px; + background-image: url(""); + background-position: 10px 10px; + background-repeat:no-repeat; +} + + +.bb-bb10-radio-container-hires-light +{ + height: 76px; + width: 76px; + margin:0px; + background-image: url(""); + background-position: 10px 10px; + background-repeat:no-repeat; +} + + +.bb-bb10-radio-dot-hires +{ + height: 40px; + width: 40px; + border-radius: 20px; + z-index:0; + top: 19px; + left: 19px; + position:relative; + display:block; +} + +.bb-bb10-radio-dot-hires-disabled +{ + background-image: -webkit-linear-gradient(top, rgba(89,89,89,0.5) 0%, rgba(89,89,89,0.5) 100%) !important; + background: rgba(89,89,89,0.5); + height: 40px; + width: 40px; + border-radius: 20px; + z-index:0; + top: 19px; + left: 19px; + position:relative; + display:block; +} + +.bb-bb10-radio-dot-center-hires +{ + height: 18px; + width: 18px; + border-radius: 9px; + background-color: white; + top: 11px; + left: 11px; + position:relative; + display:block; +} + +.bb-bb10-radio-container-lowres-dark +{ + height: 38px; + width: 38px; + margin:0px; + background-image: url(""); + background-position: 5px 5px; + background-repeat:no-repeat; +} + + +.bb-bb10-radio-container-lowres-light +{ + height: 38px; + width: 38px; + margin:0px; + background-image: url(""); + background-position: 5px 5px; + background-repeat:no-repeat; +} + + +.bb-bb10-radio-dot-lowres +{ + height: 20px; + width: 20px; + border-radius: 10px; + z-index:0; + top: 10px; + left: 9px; + position:relative; + display:block; +} + +.bb-bb10-radio-dot-center-lowres +{ + height: 10px; + width: 10px; + border-radius: 5px; + background-color: white; + top: 5px; + left: 5px; + position:relative; + display:block; +} + + + + +/* ================================================= + Image List BB10 + =================================================*/ + +.bb-bb10-image-list +{ + margin:0px; + padding:0px; +} + +.bb-bb10-image-list-header +{ + vertical-align:middle; + font-weight: bold; +} + +.bb-bb10-image-list-header-normal-light { + background: -webkit-gradient(linear, center top, center bottom, from(#F9F9F9), to(#DDDDDD)); + font-weight: normal; + color: black; +} + +.bb-bb10-image-list-header-normal-dark { + background: -webkit-gradient(linear, center top, center bottom, from(#3F3F3F), to(#262626)); + font-weight: normal; + color: white; +} + +.bb-bb10-image-list-header-hires +{ + height:44px; + line-height:44px; + font-size: 28pt; + border-bottom-width: 3px; + border-bottom-style: solid; + margin-bottom: 1px; +} + +.bb-bb10-image-list-header-lowres +{ + height:28px; + line-height:30px; + font-size: 16pt; + border-bottom-width: 2px; + border-bottom-style: solid; + margin-bottom: 1px; +} + +.bb-bb10-image-list-header p +{ + margin:0px; + padding:0px; + padding-top:0px; +} + +.bb-bb10-image-list-header-left-lowres +{ + text-align:left; + padding-left: 10px; +} + +.bb-bb10-image-list-header-right-lowres +{ + text-align:right; + padding-right: 10px; +} + +.bb-bb10-image-list-header-left-hires +{ + text-align:left; + padding-left: 20px; +} + +.bb-bb10-image-list-header-right-hires +{ + text-align:right; + padding-right: 20px; +} + +.bb-bb10-image-list-header-center +{ + text-align:center; +} + +.bb-bb10-image-list-item +{ + padding-bottom: 0px; + overflow:hidden; +} + +.bb-bb10-image-list-item-lowres +{ + padding-top: 3px; + padding-left: 5px; + height: 54px; + border-top-width: 0px; + border-bottom-width: 1px; + border-bottom-style: solid; +} + +.bb-bb10-image-list-item-hires +{ + padding-top: 6px; + padding-left: 5px; + height: 103px; + border-top-width: 0px; + border-bottom-width: 2px; + border-bottom-style: solid; +} + +.bb-bb10-image-list-item-overlay-hires { + position:relative; + border-width: 4px; + border-style: solid; + border-color: transparent; + background-color: transparent; + z-index: 100; + margin-top: -98px; + margin-left: -5px; + height: 101px; +} + +.bb-bb10-image-list-item-overlay-lowres { + position:relative; + border-width: 2px; + border-style: solid; + border-color: transparent; + background-color: transparent; + z-index: 100; + margin-top: -61px; + margin-left: -5px; + height: 53px; +} + +.bb-bb10-image-list-item-details-lowres +{ + position:relative; + margin-left:70px; + margin-bottom: 0px; + margin-top:5px; +} + +.bb-bb10-image-list-item-noimage-lowres +{ + margin-left:5px; +} + +.bb-bb10-image-list-item-details-hires +{ + position:relative; + margin-left:130px; + margin-bottom: 0px; + margin-top:17px; +} + +.bb-bb10-image-list-item-noimage-hires +{ + margin-left:10px; +} + +.bb-bb10-image-list-item-dark +{ + color:White; + border-bottom-color: #3A3A3A; +} + +.bb-bb10-image-list-item-light +{ + color:Black; + border-bottom-color: #D9DCDE; +} + +.bb-bb10-image-list-item-lowres .title +{ + overflow: hidden; + white-space: nowrap; + text-overflow: ellipsis; + font-size: 20pt; + line-height:20px; + padding-top:5px; +} + +.bb-bb10-image-list-item-hires .title +{ + overflow: hidden; + white-space: nowrap; + font-size: 35pt; + line-height:59px; + text-overflow: -blackberry-fade; + padding-top:5px; + margin-top: -30px; +} + +.bb-bb10-image-list-item-hover +{ + /*placeholder to signify hover*/ +} + +.bb-bb10-image-list-item-hover .title +{ + color:White; +} + +.bb-bb10-image-list-item-lowres img +{ + position:relative; + left: -5px; + float:left; + height:64px; + width:64px; + top:-8px; +} + +.bb-bb10-image-list-item-hires img +{ + position:relative; + left: -5px; + top: -6px; + float:left; + height:109px; + width:109px; +} + +.bb-bb10-image-list-item-lowres .description +{ + color:#606060; + overflow: hidden; + white-space:nowrap; + font-size: 14pt; + margin-bottom: 0px; + margin-top: 2px; + text-overflow: ellipsis; +} + +.bb-bb10-image-list-item-hires .description +{ + color:#606060; + overflow: hidden; + white-space:nowrap; + font-size: 26pt; + margin-bottom: 0px; + margin-top:-1px; + text-overflow: -blackberry-fade; +} + +.bb-bb10-image-list-item-hover .description +{ + color: White; +} + +.bb-bb10-image-list-item-lowres .accent-text +{ + position:relative; + float:right; + color:#606060; + font-size:14pt; + margin-right: 5px; + margin-top:-50px; +} + +.bb-bb10-image-list-item-hires .accent-text +{ + position:relative; + float:right; + color:#606060; + font-size:22pt; + margin-right: 10px; + margin-top:-79px; +} + +.bb-bb10-image-list-item-hover .accent-text +{ + color:White; +} + +.bb-bb10-image-list-item-hires .button +{ + position:relative; + float:right; + width:68px; + height:108px; + margin-top: -105px; + padding-left: 20px; + z-index: 100; +} + +.bb-bb10-image-list-item-lowres .button +{ + position:relative; + float:right; + width:34px; + height:59px; + margin-top: -59px; + padding-left: 10px; + z-index: 100; +} + +.bb-bb10-image-list-item-button-border-hires +{ + width: 46px; + height: 46px; + border-width: 1px; + border-style: solid; + border-radius: 24px; + margin-top: 26px; +} + +.bb-bb10-image-list-item-button-border-lowres +{ + width: 23px; + height: 23px; + border-width: 1px; + border-style: solid; + border-radius: 12px; + margin-top: 17px; +} + +.bb-bb10-image-list-item-button-inner-hires +{ + width: 46px; + height: 46px; + background-position: center center; + background-size: cover; +} + +.bb-bb10-image-list-item-button-inner-lowres +{ + width: 23px; + height: 23px; + background-position: center center; + background-size: cover; +} + +.bb-bb10-image-list-item-hires .details-button-margin +{ + margin-right: 68px; +} + +.bb-bb10-image-list-item-lowres .details-button-margin +{ + margin-right: 34px; +} + +.bb-bb10-image-list-item-button-dark +{ + border-color: #606060; + background-image: -webkit-gradient(linear, center top, center bottom, from(#404040), to(#272727)); +} + +.bb-bb10-image-list-item-button-light +{ + border-color: #CACACA; + background-image: -webkit-gradient(linear, center top, center bottom, from(#FBFBFB), to(#DFDFDF)); +} + +.bb-image-list-item-chevron-light +{ + background-image: url(""); +} + +.bb-image-list-item-chevron-dark +{ + background-image: url(""); +} + +.bb-image-list-item-add-light +{ + background-image: url(""); +} + +.bb-image-list-item-add-dark +{ + background-image: url(""); +} + +.bb-image-list-item-remove-light +{ + background-image: url(""); +} + +.bb-image-list-item-remove-dark +{ + background-image: url(""); +} + +/* ================================================= + PlayBook Image List + =================================================*/ + +.bb-pb-image-list +{ + margin:0px; + padding:0px; +} + +.bb-pb-image-list-item +{ + border-bottom: solid 1px #D9DCDE; + padding-top: 3px; + padding-left: 5px; + padding-bottom: 0px; + overflow:hidden; + height: 60px; +} + +.bb-pb-image-list-item-hover +{ + border-bottom: solid 1px #D9DCDE; + padding-top: 3px; + padding-left: 5px; + padding-bottom: 0px; + overflow:hidden; + height: 60px; + color: white; +} + +.bb-pb-image-list-details +{ + position:relative; + margin-left:74px; + margin-bottom: 0px; +} + +.bb-pb-image-list-noimage +{ + margin-left: 10px; +} + + +.bb-pb-image-list-item .title +{ + color:Black; + overflow: hidden; + white-space:nowrap; + text-overflow: ellipsis; + font-size:18pt; + line-height:26px; + margin-top:8px; +} + +.bb-pb-image-list-item-hover .title +{ + color:White; + overflow: hidden; + white-space:nowrap; + text-overflow: ellipsis; + font-size:18pt; + line-height:26px; + margin-top:8px; +} + +.bb-pb-image-list img +{ + position:relative; + left: -5px; + float:left; + height:70px; + width:70px; + top:-10px; +} + +.bb-pb-image-list-item .description +{ + color:#737173; + overflow: hidden; + white-space:nowrap; + font-size: 14pt; + margin-bottom: 0px; + text-overflow: ellipsis; + margin-left:0px; + padding-top:0px; + margin-top: -3px; +} + +.bb-pb-image-list-item-hover .description +{ + color:white; + overflow: hidden; + white-space:nowrap; + font-size: 14pt; + margin-bottom: 0px; + text-overflow: ellipsis; + margin-left:0px; + padding-top:0px; + margin-top: -3px; +} + +.bb-pb-image-list-item .accent-text +{ + position:relative; + float:right; + font-size:12pt; + margin-right: 5px; + margin-top: -20px; + color: Black; +} + +.bb-pb-image-list-item-hover .accent-text +{ + position:relative; + float:right; + font-size:12pt; + margin-right: 5px; + margin-top: -20px; + color: White; +} + + +.bb-pb-image-list-header +{ + height:30px; + vertical-align:middle; +} + +.bb-pb-image-list-header-default +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#D5D6D7), to(#9E9F9F)); + color: black; +} + +.bb-pb-image-list-header-solid +{ + color: white; +} + +.bb-pb-image-list-header-right +{ + text-align:right; + padding-right: 10px; +} + +.bb-pb-image-list-header-left +{ + text-align:left; + padding-left: 10px; +} + +.bb-pb-image-list-header-center +{ + text-align:center; +} + +.bb-pb-image-list-header-hover +{ + height:30px; + vertical-align:middle; +} + +.bb-pb-image-list-header-hover p +{ + color:White; + line-height:36px; + margin:0px; + padding:0px; +} + +.bb-pb-image-list-header p +{ + line-height:36px; + margin:0px; + padding:0px; +} + +.bb-pb-image-list-item .button +{ + position:relative; + float:right; + width:34px; + height:59px; + margin-top: -59px; + padding-left: 10px; +} + +.bb-pb-image-list-item-button-border +{ + width: 23px; + height: 23px; + margin-top: 17px; +} + +.bb-pb-image-list-item-button-inner +{ + width: 23px; + height: 23px; + background-position: center center; + background-size: cover; +} + +.bb-pb-image-list-item .details-button-margin +{ + margin-right: 44px; +} + + +/* ================================================= + Image List High-Resolution + =================================================*/ + + +.bb-hires-image-list +{ + margin:0px; + padding:0px; +} + +.bb-hires-image-list-item +{ + border-bottom: solid 1px #D9DCDE; + padding-top: 3px; + padding-left: 5px; + padding-bottom: 0px; + overflow:hidden; + height: 60px; +} + +.bb-hires-image-list-item-hover +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#0dacff), to(#0f75ff)); + border-bottom: solid 1px #D9DCDE; + padding-top: 3px; + padding-left: 5px; + padding-bottom: 0px; + overflow:hidden; + height: 60px; + color: white; +} + +.bb-hires-image-list-details +{ + position:relative; + margin-left:74px; + margin-bottom: 0px; +} + +.bb-hires-image-list-noimage +{ + margin-left: 10px; +} + + +.bb-hires-image-list-item .title +{ + color:Black; + overflow: hidden; + white-space:nowrap; + text-overflow: ellipsis; + font-size:20pt; + line-height:36px; +} + +.bb-hires-image-list-item-hover .title +{ + color:White; + overflow: hidden; + white-space:nowrap; + text-overflow: ellipsis; + font-size:20pt; + line-height:36px; +} + + +.bb-hires-image-list img +{ + position:relative; + left: -5px; + float:left; + height:70px; + width:70px; + top:-10px; +} + +.bb-hires-image-list-item .description +{ + color:#737173; + overflow: hidden; + white-space:nowrap; + font-size: 14pt; + margin-bottom: 0px; + text-overflow: ellipsis; + margin-left:0px; + padding-top:0px; + margin-top: -3px; +} + +.bb-hires-image-list-item-hover .description +{ + color:white; + overflow: hidden; + white-space:nowrap; + font-size: 14pt; + margin-bottom: 0px; + text-overflow: ellipsis; + margin-left:0px; + padding-top:0px; + margin-top: -3px; +} + +.bb-hires-image-list-item .accent-text +{ + position:relative; + float:right; + font-size:14pt; + margin-right: 5px; + margin-top: -30px; + color: Black; +} + +.bb-hires-image-list-item-hover .accent-text +{ + position:relative; + float:right; + font-size:14pt; + margin-right: 5px; + margin-top: -30px; + color: White; +} + +.bb-hires-image-list-header +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#D5D6D7), to(#9E9F9F)); + height:56px; + vertical-align:middle; + border-bottom: solid 1px #D9DCDE; +} + +.bb-hires-image-list-header-right +{ + text-align:right; + padding-right: 10px; +} + +.bb-hires-image-list-header-left +{ + text-align:left; + padding-left: 10px; +} + +.bb-hires-image-list-header-center +{ + text-align:center; +} + +.bb-hires-image-list-header-hover +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#088FF0), to(#1666DC)); + height:56px; + vertical-align:middle; + border-bottom: solid 1px #D9DCDE; +} + +.bb-hires-image-list-header-hover p +{ + color:White; + line-height:56px; + margin:0px; + padding:0px; +} + +.bb-hires-image-list-header p +{ + color: Black; + line-height:56px; + margin:0px; + padding:0px; +} + +.bb-hires-image-list-item .button +{ + position:relative; + float:right; + width:34px; + height:59px; + margin-top: -59px; + padding-left: 10px; +} + +.bb-hires-image-list-item-button-border +{ + width: 23px; + height: 23px; + margin-top: 17px; +} + +.bb-hires-image-list-item-button-inner +{ + width: 23px; + height: 23px; + background-position: center center; + background-size: cover; +} + +.bb-hires-image-list-item .details-button-margin +{ + margin-right: 44px; +} + + + +/* ================================================= + Image List Low-Resolution + =================================================*/ + + +.bb-lowres-image-list +{ + margin:0px; + padding:0px; +} + +.bb-lowres-image-list-item +{ + border-bottom: solid 1px #D9DCDE; + padding-bottom: 0px; + overflow:hidden; + height:60px; +} + +.bb-lowres-image-list-item-hover +{ + background-color:#2175F7; + border-bottom: solid 1px #D9DCDE; + padding-bottom: 0px; + overflow:hidden; + height: 60px; +} + +.bb-lowres-image-list-details +{ + position:relative; + margin-left:68px; + margin-bottom: 0px; + margin-top:8px; + margin-top: 5px; +} + +.bb-lowres-image-list-noimage +{ + margin-left: 5px; +} + +.bb-lowres-image-list-item .title +{ + color:Black; + overflow: hidden; + white-space:nowrap; + text-overflow: ellipsis; + font-size:14pt; +} + +.bb-lowres-image-list-item-hover .title +{ + color:White; + overflow: hidden; + white-space:nowrap; + text-overflow: ellipsis; + font-size:14pt; +} + +.bb-lowres-image-list img +{ + position:relative; + left:0px; + float:left; + height:60px; + width:60px; +} + +.bb-lowres-image-list .description +{ + color:#737173; + overflow: hidden; + white-space:nowrap; + text-overflow: ellipsis; + font-size: 12pt; + margin-bottom: 0px; +} + +.bb-lowres-image-list-item-hover .description +{ + color: White; + overflow: hidden; + white-space:nowrap; + text-overflow: ellipsis; + font-size: 12pt; + margin-bottom: 0px; +} + +.bb-lowres-image-list-item .accent-text +{ + position:relative; + float:right; + font-size:10pt; + margin-right: 5px; + color:#696969; + margin-top:5px; + margin-top:-20px; +} + +.bb-lowres-image-list-item-hover .accent-text +{ + position:relative; + float:right; + font-size:10pt; + margin-right: 5px; + color:White; + margin-top:-20px; +} + +.bb-lowres-image-list-header +{ + background-image:url(''); + + height:27px; + background-color:silver; +} + +.bb-lowres-image-list-header-right +{ + text-align:right; + padding-right: 10px; +} + +.bb-lowres-image-list-header-left +{ + text-align:left; + padding-left: 10px; +} + +.bb-lowres-image-list-header-center +{ + text-align:center; +} + +.bb-lowres-image-list-header-hover +{ + height:27px; + background-image: none; + background-color: #2175F7; +} + +.bb-lowres-image-list-header-hover p +{ + color:White; + line-height:27px; + margin:0px; + padding:0px; +} + +.bb-lowres-image-list-header p +{ + color: Black; + line-height:27px; + margin:0px; + padding:0px; +} + +.bb-lowres-image-list-item .button +{ + position:relative; + float:right; + width:34px; + height:59px; + margin-top: -59px; + padding-left: 10px; +} + +.bb-lowres-image-list-item-button-border +{ + width: 23px; + height: 23px; + margin-top: 23px; +} + +.bb-lowres-image-list-item-button-inner +{ + width: 23px; + height: 23px; + background-position: center center; + background-size: cover; +} + +.bb-lowres-image-list-item .details-button-margin +{ + margin-right: 44px; +} + + +/* ================================================= + BBM Bubbles + =================================================*/ + +.bb-bbm-bubble-left +{ + margin-left: 8px; + margin-right:20px; + position:relative; + margin-top: 10px; +} + +.bb-bbm-bubble-left img +{ + position:relative; + float:left; +} + +.bb-bbm-bubble-left .details +{ + position:relative; + margin-left:25px; +} + +.bb-bbm-bubble-left .image { + background-image: url(""); +} + +.bb-bbm-bubble-left .top-left { + margin-right: 9px; + height: 9px; +} + +.bb-bbm-bubble-left .top-right { + margin-top: -9px; + margin-left: 9px; + background-position: 100% 0; + height: 9px; + font-size: 2px; +} +.bb-bbm-bubble-left .bottom-left { + margin-right: 18px; + background-position: 0 -11px; + height: 18px; + font-size: 2px; +} +.bb-bbm-bubble-left .bottom-right { + margin-top: -18px; + margin-left: 18px; + background-position: 100% -11px; + height: 18px; + font-size: 2px; +} +.bb-bbm-bubble-left .inside { + border-left: 1px solid #A5A2A5; + border-right: 1px solid #A5A2A5; + background-color: #DEDBDE; + padding-left: 3px; + padding-right: 3px; + overflow:auto; +} +.bb-bbm-bubble-left .nogap { + margin-top: -3; + margin-bottom: -3; + padding-left: 10px; + padding-right: 10px; +} + +.bb-bbm-bubble-right +{ + margin-top: 10px; + margin-right: 8px; + margin-left: 20px; + position:relative; +} + + +.bb-bbm-bubble-right .image { + background-image: url(""); +} + +.bb-bbm-bubble-right .details +{ + position:relative; + margin-left:25px; +} + +.bb-bbm-bubble-right img +{ + position:relative; + float:left; +} + +.bb-bbm-bubble-right .top-left { + margin-right: 9px; + height: 9px; +} +.bb-bbm-bubble-right .top-right { + margin-top: -9px; + margin-left: 9px; + background-position: 100% 0; + height: 9px; + font-size: 2px; +} +.bb-bbm-bubble-right .bottom-left { + margin-right: 18px; + background-position: 0 -11px; + height: 18px; + font-size: 2px; +} +.bb-bbm-bubble-right .bottom-right { + margin-top: -18px; + margin-left: 18px; + background-position: 100% -11px; + height: 18px; + font-size: 2px; +} +.bb-bbm-bubble-right .inside { + border-left: 1px solid #A5A2A5; + border-right: 1px solid #A5A2A5; + background: #D6EBF7; + padding-left: 3px; + padding-right: 3px; + overflow:auto; +} +.bb-bbm-bubble-right .nogap { + margin-top: -3; + margin-bottom: -3; + padding-left: 10px; + padding-right: 10px; +} + + + + +/* ================================================= + Panel Header - High Resolution + =================================================*/ + +.bb-hires-panel-header { + border-bottom: solid 1px #DCDBDB; + margin-bottom: 5px; + padding-bottom: 3px; + font-size: 14pt; + color: #7C7E80; + font-weight: bold; +} + +/* ================================================= + Panel Header - Low Resolution + =================================================*/ + +.bb-lowres-panel-header { + border-bottom: solid 1px #DCDBDB; + margin-bottom: 5px; + padding-bottom: 3px; + font-size: 12pt; + color: #7C7E80; + font-weight: bold; +} + +/* ================================================= + Pill Buttons + =================================================*/ + +.bb-pill-buttons +{ + margin: 8px; + margin-bottom: 0px; + text-align:center; + /*position:relative;*/ + +} + +.bb-pill-buttons .buttonLeft { + background: transparent url('../images/button/pillButtonRight.png') no-repeat scroll top right; + color: White; + display: block; + float: left; + height: 39px; + margin-right: 0px; + padding-right: 10px; + text-decoration: none; + width: 30%; +} + +.bb-pill-buttons .buttonLeft span { + background: transparent url('../images/button/button.png') no-repeat; + display: block; + line-height: 39px; + padding: 0px 0px 0px 10px; + text-align:center; +} + +.bb-pill-buttons .buttonRight { + background: transparent url('../images/button/btnRight.png') no-repeat scroll top right; + color: White; + display: block; + float: left; + height: 39px; + margin-right: 0px; + padding-right: 10px; + text-decoration: none; + width: 30%; +} + +.bb-pill-buttons .buttonRight span { + background: transparent url('../images/button/button.png') no-repeat; + background-position: -10px 0px; + display: block; + line-height: 39px; + padding: 0px 0px 0px 10px; + text-align:center; +} + +.bb-pill-buttons .buttonMiddle { + background: transparent url('../images/button/pillButtonRight.png') no-repeat scroll top right; + color: White; + display: block; + float: left; + height: 39px; + margin-right: 0px; + padding-right: 10px; + text-decoration: none; + width: 30%; +} + +.bb-pill-buttons .buttonMiddle span { + background: transparent url('../images/button/button.png') no-repeat; + display: block; + line-height: 39px; + padding: 0px 0px 0px 10px; + text-align:center; + background-position: -10px 0px; +} + +/* ================================================= + BB7 Pill Buttons + =================================================*/ + +.bb-bb7-pill-buttons { + padding-top: 5px; +} + +.bb-bb7-pill-buttons-hires { + height:59px; +} + +.bb-bb7-pill-buttons-lowres { + height:45px; +} + +.bb-bb7-pill-button { + float: left; + border-width:1px; + border-color:#BCBEC2; + border-style: solid; + color: black; + text-align:center; + white-space:nowrap; + vertical-align: middle; + padding-left: 0px; + padding-right: 0px; + display: table-cell; + box-shadow:1px 1px 1px #DCDCDC; + background-clip: padding-box; + background-image: -webkit-gradient(linear, center top, center bottom, from(#F9F9F9), to(#D0D2D4)); +} + +.bb-bb7-pill-button-highlight{ + float: left; + border-width:1px; + border-color:#0060E6; + border-style: solid; + color: White; + text-align:center; + white-space:nowrap; + vertical-align: middle; + padding-left: 0px; + padding-right: 0px; + display: table-cell; + box-shadow:2px 2px 2px #DCDCDC; + background-clip: padding-box; + background-image: -webkit-gradient(linear, center top, center bottom, from(#098CEE), to(#1766DB)); +} + +.bb-bb7-pill-button-lowres { + height:40px; + line-height:40px; +} + +.bb-bb7-pill-button-hires { + height:54px; + line-height:54px; +} + +.bb-bb7-pill-button-left{ + border-top-left-radius:5px; + border-bottom-left-radius:5px; +} + +.bb-bb7-pill-button-right{ + border-top-right-radius:5px; + border-bottom-right-radius:5px; +} + +/* ================================================= + BB10 Pill Buttons + =================================================*/ + +.bb-bb10-pill-buttons-lowres { + padding-top:5px; +} + +.bb-bb10-pill-buttons-hires { + padding-top:10px; +} + +.bb-bb10-pill-buttons-container-lowres { + border-width:1px; + border-style: solid; + border-radius:3px; + padding: 2px; + font-size: 14pt; + height:37px; +} + +.bb-bb10-pill-buttons-container-hires { + border-width:2px; + border-style: solid; + border-radius:5px; + padding: 2px; + font-size: 27pt; + height:89px; +} + +.bb-bb10-pill-buttons-container-light +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#BDBDBD), to(#D4D4D4)); + color: #5D5D5D; + border-top-color: #A3A3A3; + border-bottom-color: #CECECE; + border-left-color: #C3C3C3; + border-right-color: #C4C4C4; +} + +.bb-bb10-pill-buttons-container-dark +{ + color: #8D8D8D; + border-top-color: #262626; + border-left-color: #2A2A2A; + border-right-color: #2A2A2A; + border-bottom-color: #2E2E2E; + background-image: -webkit-gradient(linear, center top, center bottom, from(#292929), to(#333333)); +} + +.bb-bb10-pill-button-lowres { + float: left; + text-align:center; + white-space:nowrap; + vertical-align: middle; + padding-left: 0px; + padding-right: 0px; + border-width: 1px; + border-style: solid; + border-color: transparent; + display: table-cell; + background-clip: padding-box; + height:35px; + border-radius: 3px; +} + +.bb-bb10-pill-button-hires { + float: left; + text-align:center; + white-space:nowrap; + vertical-align: middle; + padding-left: 0px; + padding-right: 0px; + border-width: 2px; + border-style: solid; + border-color: transparent; + display: table-cell; + background-clip: padding-box; + height:85px; + border-radius: 5px; +} + +.bb-bb10-pill-button-inner-lowres +{ + margin:0px; + border-width:1px; + border-style: solid; + border-radius: 3px; + height:28px; + line-height:28px; + z-index:10; + border-color: transparent; + padding-top: 5px; +} + +.bb-bb10-pill-button-inner-hires +{ + margin:0px; + border-width:2px; + border-style: solid; + border-radius: 5px; + height:76px; + line-height:63px; + z-index:10; + border-color: transparent; + padding-top: 5px; +} + +.bb-bb10-pill-button-inner-selected-lowres-dark +{ + border-color: #4F4F4F; +} + +.bb-bb10-pill-button-inner-selected-hires-dark +{ + border-color: #4F4F4F; +} + +.bb-bb10-pill-button-inner-selected-lowres-light +{ + border-color: transparent; +} + +.bb-bb10-pill-button-inner-selected-hires-light +{ + border-color: transparent; +} + +.bb-bb10-pill-button-selected-lowres-light{ + color: black; + border-width:1px; + border-style: solid; + border-top-color: #B4B4B4; + border-left-color: #C2C2C2; + border-bottom-color: #B4B4B4; + border-right-color: #C8C8C8; + background-image: -webkit-gradient(linear, center top, center bottom, from(#F9F9F9), to(#DDDDDD)); +} + +.bb-bb10-pill-button-selected-hires-light{ + color: black; + border-width:2px; + border-style: solid; + border-top-color: #B4B4B4; + border-left-color: #C2C2C2; + border-bottom-color: #B4B4B4; + border-right-color: #C8C8C8; + background-image: -webkit-gradient(linear, center top, center bottom, from(#F9F9F9), to(#DDDDDD)); +} + +.bb-bb10-pill-button-highlight-lowres-light{ + color: white; + border-width:1px; + border-style: solid; + border-top-color: #B4B4B4; + border-left-color: #C2C2C2; + border-bottom-color: #B4B4B4; + border-right-color: #C8C8C8; +} + +.bb-bb10-pill-button-highlight-hires-light{ + color: white; + border-width:1px; + border-style: solid; + border-top-color: #B4B4B4; + border-left-color: #C2C2C2; + border-bottom-color: #B4B4B4; + border-right-color: #C8C8C8; +} + +.bb-bb10-pill-button-selected-lowres-dark +{ + color: white; + border-width:1px; + border-style: solid; + border-color:#090909; + background-image: -webkit-gradient(linear, center top, center bottom, from(#3F3F3F), to(#262626)); +} + +.bb-bb10-pill-button-selected-hires-dark +{ + color: white; + border-width:2px; + border-style: solid; + border-color:#090909; + background-image: -webkit-gradient(linear, center top, center bottom, from(#3F3F3F), to(#262626)); +} + +.bb-bb10-pill-button-highlight-lowres-dark +{ + color: white; + border-width:1px; + border-style: solid; + border-color:#333333; +} + +.bb-bb10-pill-button-highlight-hires-dark +{ + color: white; + border-width:2px; + border-style: solid; + border-color:#333333; +} + + + +/* ================================================= + Ripple Drop-Down dialog + =================================================*/ + +.ripple-dropdown-dialog { + position:absolute; + background-color:black; + left:10px; + padding-top:10px; + padding-bottom:10px; + right:10px; + border-radius:10px; + padding: 15px; + overflow:auto; +} + + +.ripple-dropdown-dialog .backgroundHighlight:hover { + background-image: -webkit-gradient(linear, center top, center bottom, from(#098CEE), to(#1766DB)); +} + +.ripple-dropdown-dialog .backgroundSelected{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#098CEE), to(#1766DB)); +} + +.ripple-dropdown-dialog .item { + color:white; + padding-left:35px; + height:45px; + line-height:45px; + vertical-align:center; +} + +.ripple-dropdown-dialog .item span { + overflow: hidden; + height: 45px; + display: block; +} + +.ripple-dropdown-dialog .selected { + background-image: url(""); + background-repeat: no-repeat; + background-position: 10px center; +} + + +/* ================================================= + BB10 Grid + =================================================*/ + +.bb-bb10-grid-lowres +{ + margin:0px; + padding:0px; +} + +.bb-bb10-grid-hires +{ + margin:0px; + padding:0px; +} + + +.bb-bb10-grid-header-lowres +{ + height:28px; + line-height:30px; + vertical-align:middle; + border-bottom-width: 2px; + border-bottom-style: solid; + font-weight: bold; +} + +.bb-bb10-grid-header-hires +{ + height:44px; + line-height:44px; + vertical-align:middle; + padding-left: 10px; + border-bottom-width: 3px; + border-bottom-style: solid; + font-weight: bold; +} + +.bb-bb10-grid-header-normal-light { + background: -webkit-gradient(linear, center top, center bottom, from(#F9F9F9), to(#DDDDDD)); + font-weight: normal; + color: black; +} + +.bb-bb10-grid-header-normal-dark { + background: -webkit-gradient(linear, center top, center bottom, from(#3F3F3F), to(#262626)); + font-weight: normal; + color: white; +} + +.bb-bb10-grid-header-lowres p +{ + font-size: 16pt; + line-height:30px; + margin:0px; + padding:0px; + padding-top:4px; + margin-left: 10px; +} + +.bb-bb10-grid-header-hires p +{ + font-size: 28pt; + line-height:44px; + margin:0px; + padding:0px; + margin-left: 10px; +} + +.bb-bb10-grid-header-left-lowres +{ + text-align:left; + padding-left: 10px; +} + +.bb-bb10-grid-header-right-lowres +{ + text-align:right; + padding-right: 10px; +} + +.bb-bb10-grid-header-left-hires +{ + text-align:left; + padding-left: 20px; +} + +.bb-bb10-grid-header-right-hires +{ + text-align:right; + padding-right: 20px; +} + +.bb-bb10-grid-header-center +{ + text-align:center; +} + +.bb-bb10-grid-item-overlay-lowres +{ + position:relative; + right:0px; + left: 0px; + background-color: black; + opacity: 0.7; +} + +.bb-bb10-grid-item-overlay-two-rows-lowres +{ + height: 40px; + top:-40px; +} + +.bb-bb10-grid-item-overlay-one-row-lowres +{ + height: 24px; + top:-24px; +} + +.bb-bb10-grid-item-overlay-hires +{ + position:relative; + right:0px; + left: 0px; + background-color: black; + opacity: 0.7; +} + +.bb-bb10-grid-item-overlay-two-rows-hires +{ + height: 70px; + top:-70px; +} + +.bb-bb10-grid-item-overlay-one-row-hires +{ + height: 40px; + top:-40px; +} + +.bb-bb10-grid-item-overlay-lowres .title +{ + text-align:center; + right:0px; + left:0px; + padding:0px; + margin:0px; + padding-top: 3px; + line-height:20px; + opacity:1.0; + color:white; + font-size: 13pt; + overflow: hidden; +} + +.bb-bb10-grid-item-overlay-lowres .title-two-rows +{ + height: 37px; +} + +.bb-bb10-grid-item-overlay-lowres .title-one-row +{ + height: 21px; +} + +.bb-bb10-grid-item-overlay-hires .title +{ + text-align:center; + right:0px; + left:0px; + padding:0px; + margin:0px; + padding-top: 4px; + line-height:30px; + opacity:1.0; + color:white; + font-size: 22pt; + overflow: hidden; +} + +.bb-bb10-grid-item-overlay-hires .title-two-rows +{ + height: 66px; +} + +.bb-bb10-grid-item-overlay-hires .title-one-row +{ + height: 36px; +} + +/* ================================================= + BB10 Action Bar + =================================================*/ + +.bb-bb10-action-bar-table +{ + margin:0px; + margin-top:0px; + padding:0px; + width:100%; + border-collapse:collapse; +} + +.bb-bb10-action-bar-table tr td +{ + padding:0px; + margin:0px; + border-collapse:collapse; +} + +.bb-bb10-action-bar-lowres +{ + position: absolute; + height: 73px; + bottom:0px; + right:0px; + left:0px; + background-repeat: repeat-x; + border-top-width: 1px; + border-top-style:solid; +} + +.bb-bb10-action-bar-hires +{ + position: absolute; + height: 139px; + bottom:0px; + right:0px; + left:0px; + background-repeat: repeat-x; + border-top-width: 1px; + border-top-style: solid; +} + +.bb-bb10-action-bar-dark { + border-color: #484948; + background-image: -webkit-gradient(linear, center top, center bottom, from(#323232), to(#272727)); +} + +.bb-bb10-action-bar-light { + border-color: #D1D1D1; + background-image: -webkit-gradient(linear, center top, center bottom, from(#FBFBFB), to(#E1E1E1)); +} + +.bb-bb10-action-bar-icon-lowres +{ + height: 40px; + width: 40px; + margin-top: 3px; +} + +.bb-bb10-action-bar-icon-hires +{ + height: 80px; + width: 80px; + margin-top: 4px; +} + +.bb-bb10-action-bar-button-tab-left-lowres-dark +{ + background-position:left -4px; + background-repeat:no-repeat; + background-image: url(""); +} + +.bb-bb10-action-bar-button-tab-left-hires-dark +{ + background-position:left -4px; + background-repeat:no-repeat; + background-image: url(""); +} + +.bb-bb10-action-bar-button-tab-left-lowres-light +{ + background-position:left -4px; + background-repeat:no-repeat; + background-image: url(""); +} + +.bb-bb10-action-bar-button-tab-left-hires-light +{ + background-position:left -8px; + background-repeat:no-repeat; + background-image: url(""); +} + +.bb-bb10-action-bar-action-lowres +{ + display:table-cell; + float: left; + height:69px; + text-align:center; + border-top-width: 4px; + border-top-style: solid; +} + + +.bb-bb10-action-bar-action-hires +{ + display:table-cell; + float: left; + height:131px; + text-align:center; + border-top-width: 8px; + border-top-style: solid; +} + +.bb-bb10-action-bar-action-display-lowres +{ + font-size:12pt; + line-height:18px; + margin-top: 3px; +} + +.bb-bb10-action-bar-action-highlight +{ + position:absolute; + top: 0px; +} + +.bb-bb10-action-bar-action-display-hires +{ + font-size:20pt; + margin-top:3px; + line-height:30px; +} + +.bb-bb10-action-bar-tab-dark { + color: white; + border-top-color: #373737; + border-right-color: #141414; + border-right-width: 2px; + border-right-style: solid; +} + +.bb-bb10-action-bar-tab-light { + color: black; + border-top-color: #E0E0E0; + border-right-color: #C6C6C6; + border-right-width: 2px; + border-right-style: solid; +} + +.bb-bb10-action-bar-button-dark { + color: white; + border-top-color: transparent; + border-right-width: 0px; +} + +.bb-bb10-action-bar-button-light { + color: black; + border-top-color: transparent; + border-right-width: 0px; +} + +.bb-bb10-action-bar-tab-normal-dark +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#252525), to(#1C1C1C)); +} + +.bb-bb10-action-bar-tab-selected-dark +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#47494A), to(#3F3F3F)); +} + +.bb-bb10-action-bar-tab-normal-light +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#F9F9F9), to(#DFDFDF)); +} + +.bb-bb10-action-bar-tab-selected-light +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#FBFBFB), to(#E6E6E6)); +} + + +.bb-bb10-action-bar-back-button-lowres +{ + display:table-cell; + float: left; + height:71px; + font-size:12pt; + width:77px; + background-repeat: no-repeat; + text-align:center; + line-height:20px; +} + +.bb-bb10-action-bar-back-button-hires +{ + display:table-cell; + float: left; + height:138px; + font-size:20pt; + width:154px; + background-repeat: no-repeat; + text-align:center; + line-height:12px; +} + +.bb-bb10-action-bar-back-text-hires +{ + position:relative; + height: 25px; + top: 61px; +} + +.bb-bb10-action-bar-back-text-lowres +{ + position:relative; + height: 20px; + top: 25px; +} + +.bb-bb10-action-bar-back-button-hires-dark +{ + color: white; + background-image: url(""); + background-repeat: repeat-x; +} + +.bb-bb10-action-bar-back-button-lowres-dark +{ + color: white; + background-image: url(""); + background-repeat: repeat-x; +} + +.bb-bb10-action-bar-back-button-hires-light +{ + color: #242424; + background-image: url(""); + background-repeat: repeat-x; +} + +.bb-bb10-action-bar-back-button-lowres-light +{ + color: #242424; + background-image: url(""); + background-repeat: repeat-x; +} + +.bb-bb10-action-bar-back-chevron-hires-dark +{ + position:relative; + background-image: url(""); + width:27px; + height:43px; + margin: 0px auto 0px auto; + top: 31px; +} + +.bb-bb10-action-bar-back-chevron-lowres-dark +{ + position:relative; + background-image: url(""); + width:14px; + height:22px; + margin: 0px auto 0px auto; + top: 15px; +} + +.bb-bb10-action-bar-back-chevron-hires-light +{ + position:relative; + background-image: url(""); + width:27px; + height:43px; + margin: 0px auto 0px auto; + top: 31px; +} + +.bb-bb10-action-bar-back-chevron-lowres-light +{ + position:relative; + background-image: url(""); + width:14px; + height:22px; + margin: 0px auto 0px auto; + top: 15px; +} + +.bb-bb10-action-bar-back-slash-hires-dark +{ + position:relative; + display:table-cell; + float: left; + background-image: url(""); + background-position: -1px -1px; + width:33px; + height: 138px; +} + +.bb-bb10-action-bar-back-slash-lowres-dark +{ + position:relative; + display:table-cell; + float: left; + background-image: url(""); + background-position: -1px -1px; + width:16px; + height: 71px; +} + +.bb-bb10-action-bar-back-slash-hires-light +{ + position:relative; + display:table-cell; + float: left; + background-image: url(""); + background-position: -1px -1px; + width:33px; + height: 138px; +} + +.bb-bb10-action-bar-back-slash-lowres-light +{ + position:relative; + display:table-cell; + float: left; + background-image: url(""); + background-position: -1px -1px; + width:16px; + height: 71px; +} + +.bb-bb10-action-bar-tab-overflow-hires-dark +{ + background-repeat: no-repeat; + background-position: center center; + background-image: url(""); +} + +.bb-bb10-action-bar-tab-overflow-lowres-dark +{ + background-repeat: no-repeat; + background-position: center center; + background-image: url(""); +} + +.bb-bb10-action-bar-tab-overflow-hires-light +{ + background-repeat: no-repeat; + background-position: center center; + background-image: url(""); +} + +.bb-bb10-action-bar-tab-overflow-lowres-light +{ + background-repeat: no-repeat; + background-position: center center; + background-image: url(""); +} + +.bb-bb10-action-bar-tab-overflow-highlight-hires +{ + background-repeat: no-repeat; + background-position: -56px center; + height: 86px; + width: 16px; + margin-top: -117px; + display:none; +} + +.bb-bb10-action-bar-tab-overflow-highlight-lowres +{ + background-repeat: no-repeat; + background-position: -28px center; + height: 43px; + width: 8px; + margin-top: -63px; + display:none; +} + +.bb-bb10-action-bar-overflow-button-lowres-dark +{ + background-repeat: no-repeat; + background-position: center center; + background-image: url(""); +} + +.bb-bb10-action-bar-overflow-button-hires-dark +{ + background-repeat: no-repeat; + background-position: center center; + background-image: url(""); +} + +.bb-bb10-action-bar-overflow-button-lowres-light +{ + background-repeat: no-repeat; + background-position: center center; + background-image: url(""); +} + +.bb-bb10-action-bar-overflow-button-hires-light +{ + background-repeat: no-repeat; + background-position: center center; + background-image: url(""); +} + +/* ================================================= + BB10 Tab Overflow Menu +=================================================*/ +.bb-bb10-tab-overflow-menu-overlay +{ + z-index: 1000; + position: fixed; + top: 0px; + right:0px; + bottom:0px; + left:0px; + display:none; + background-color:black; + opacity:0.25; +} + +.bb-bb10-tab-overflow-menu +{ + position:absolute; + top: 0px; + bottom: 0px; + width: 0px; + left: 0px; + z-index:1001; + white-space:nowrap; + overflow-y : scroll; + overflow-x : hidden; + -webkit-overflow-scrolling : -blackberry-touch; +} + +.bb-bb10-tab-overflow-menu-dark +{ + background-color: #121212; +} + +.bb-bb10-tab-overflow-menu-light +{ + background-color: #F9F9F9; +} + +.bb-bb10-tab-overflow-menu-item-lowres +{ + padding-left: 5px; + vertical-align: center; + font-size:20pt; +} + +.bb-bb10-tab-overflow-menu-item-single-lowres { + padding-top: 7px; + padding-bottom: 3px; + height: 52px; + line-height: 52px; +} + +.bb-bb10-tab-overflow-menu-item-double-lowres { + padding-top: 5px; + padding-bottom: 0px; + height: 27px; + line-height: 27px; +} + +.bb-bb10-tab-overflow-menu-item-hires +{ + vertical-align: center; + font-size:39pt; + padding-left: 10px; +} + +.bb-bb10-tab-overflow-menu-item-inner-lowres +{ + padding-left: 5px; +} + +.bb-bb10-tab-overflow-menu-item-lowres .tab-accent-text +{ + padding-left: 5px; + font-size: 16pt; + height: 25px; + color:#606060; +} + +.bb-bb10-tab-overflow-menu-item-single-hires { + padding-top: 14px; + padding-bottom: 3px; + height: 109px; + line-height: 85px; +} + +.bb-bb10-tab-overflow-menu-item-double-hires { + padding-top: 5px; + padding-bottom: 3px; + height: 60px; + line-height: 60px; +} + +.bb-bb10-tab-overflow-menu-item-inner-hires +{ + padding-left: 15px; +} + +.bb-bb10-tab-overflow-menu-item-hires .tab-accent-text +{ + padding-left: 15px; + font-size: 30pt; + height: 49px; + color:#606060; +} + +.bb10Highlight .tab-accent-text { + color: white; +} + +.bb-bb10-tab-overflow-menu-item-lowres-light +{ + color:Black; + border-bottom: solid 1px #D9DCDE; +} + +.bb-bb10-tab-overflow-menu-item-first-lowres-light +{ + border-top: solid 1px #D9DCDE; +} + +.bb-bb10-tab-overflow-menu-item-hires-light +{ + color:Black; + border-bottom: solid 2px #D9DCDE; +} + +.bb-bb10-tab-overflow-menu-item-first-hires-light +{ + border-top: solid 2px #D9DCDE; +} + +.bb-bb10-tab-overflow-menu-item-lowres-dark +{ + color:White; + border-bottom: solid 1px #404040 +} + +.bb-bb10-tab-overflow-menu-item-first-lowres-dark +{ + border-top: solid 1px #404040 +} + +.bb-bb10-tab-overflow-menu-item-hires-dark +{ + color:White; + border-bottom: solid 2px #404040 +} + +.bb-bb10-tab-overflow-menu-item-first-hires-dark +{ + border-top: solid 2px #404040 +} + +.bb-bb10-tab-overflow-menu-item-image-lowres +{ + height: 42px; + width: 42px; + margin-top:-2px; +} + +.bb-bb10-tab-overflow-menu-item-image-hires +{ + height: 80px; + width: 80px; + margin-top: 0px; + margin-left:12px; +} + +/* ================================================= + BB10 Context Menu +=================================================*/ + +.bb-bb10-context-menu +{ + z-index: 1002; + position:fixed; + height: 100%; + width: 80%; + top: 0px; + clear: both; + visibility : hidden; +} + +.bb-bb10-context-menu-overlay +{ + z-index: 1000; + position: fixed; + top: 0px; + right:0px; + bottom:0px; + left:0px; + display:none; +} + +.bb-bb10-context-menu-scroller { + position: absolute; + left : 0px; + bottom : 0px; + right : 0px; +} + +.bb-bb10-context-menu-lowres-dark +{ + background-color: #121212; + border-left: solid 1px #161616; +} + +.bb-bb10-context-menu-hires-dark +{ + background-color: #121212; + border-left: solid 2px #161616; +} + +.bb-bb10-context-menu-lowres-light +{ + background-color: #F9F9F9; + border-left: solid 1px #D1D1D1; +} + +.bb-bb10-context-menu-hires-light +{ + background-color: #F9F9F9; + border-left: solid 1px #D1D1D1; +} + +.bb-bb10-context-menu-item-lowres +{ + padding-top: 7px; + padding-bottom: 3px; + padding-left: 0px; + border-left: solid 5px; + border-left-color: transparent; + height: 52px; + line-height: 52px; + vertical-align: center; + font-size:16pt; +} + + +.bb-bb10-context-menu-item-hires +{ + padding-top: 14px; + padding-bottom: 3px; + padding-left: 0px; + border-left: solid 10px; + border-left-color: transparent; + height: 109px; + line-height: 95px; + vertical-align: center; + font-size:30pt; +} + +.bb-bb10-context-menu-item-inner-lowres +{ + padding-left: 5px; + position:relative; + float:left; +} + +.bb-bb10-context-menu-item-inner-hires +{ + padding-left: 15px; + position:relative; + float:left; +} + +.bb-bb10-context-menu-header-dark +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#323232), to(#272727)); + border-bottom: solid 1px #404040; +} + + +.bb-bb10-context-menu-header-title-lowres +{ + font-size: 18pt; + height:30px; + line-height:30px; + padding-left: 15px; + margin:0px; + overflow:hidden; + white-space:nowrap; + text-overflow: ellipsis; +} + +.bb-bb10-context-menu-header-title-hires +{ + font-size:30pt; + height:36px; + line-height:30px; + padding-left: 18px; + margin:0px; + padding-top:15px; + overflow:hidden; + white-space:nowrap; + text-overflow: -blackberry-fade; +} + +.bb-bb10-context-menu-header-description-lowres +{ + color: #737173; + font-size: 14pt; + height:30px; + line-height:30px; + padding-left: 15px; + margin:0px; + margin-top:-10px; + overflow:hidden; + white-space:nowrap; + text-overflow: ellipsis; +} + +.bb-bb10-context-menu-header-description-hires +{ + color: #737173; + font-size: 24pt; + height:30px; + line-height:30px; + padding-left: 18px; + margin:0px; + margin-top:5px; + padding-top:0px; + overflow:hidden; + white-space:nowrap; + text-overflow: -blackberry-fade; +} + +.bb-bb10-context-menu-header-title-dark +{ + color: white; +} + +.bb-bb10-context-menu-header-title-light +{ + color: black; +} + +.bb-bb10-context-menu-header-light +{ + background-image: -webkit-gradient(linear, center top, center bottom, from(#FBFBFB), to(#E0E0E0)); + border-bottom: solid 1px #D9DCDE; +} + +.bb-bb10-context-menu-item-lowres-light +{ + color:Black; + border-bottom: solid 1px #D9DCDE; +} + +.bb-bb10-context-menu-item-first-lowres-light +{ + border-top: solid 1px #D9DCDE; +} + +.bb-bb10-context-menu-item-hires-light +{ + color:Black; + border-bottom: solid 2px #D9DCDE; +} + +.bb-bb10-context-menu-item-first-hires-light +{ + border-top: solid 2px #D9DCDE; +} + +.bb-bb10-context-menu-item-lowres-dark +{ + color:White; + border-bottom: solid 1px #404040 +} + +.bb-bb10-context-menu-item-first-lowres-dark +{ + border-top: solid 1px #404040 +} + +.bb-bb10-context-menu-item-hires-dark +{ + color:White; + border-bottom: solid 2px #404040 +} + +.bb-bb10-context-menu-item-first-hires-dark +{ + border-top: solid 2px #404040 +} + +.bb-bb10-context-menu-item-image-lowres +{ + position:relative; + float:left; + height: 42px; + width: 42px; + margin-top:3px; +} + +.bb-bb10-context-menu-item-image-hires +{ + position:relative; + float:left; + height: 80px; + width: 80px; + margin-top:10px; + margin-left:12px; +} + + +/* ================================================= + Not sure if these are needed anymore + =================================================*/ + +.panel-nogap input +{ + display:inline; + float:left; + font-family: BBAlpha Sans; + font-size: 16pt; + border: none; + padding-top: 0px; + width: 10px; +} + + + + + + + diff --git a/bbm/img/Large/White/icon_005.png b/bbm/img/Large/White/icon_005.png new file mode 100644 index 00000000..c3c57fea Binary files /dev/null and b/bbm/img/Large/White/icon_005.png differ diff --git a/bbm/img/Large/White/icon_041.png b/bbm/img/Large/White/icon_041.png new file mode 100644 index 00000000..312325f6 Binary files /dev/null and b/bbm/img/Large/White/icon_041.png differ diff --git a/bbm/img/Large/White/icon_048.png b/bbm/img/Large/White/icon_048.png new file mode 100644 index 00000000..5b8d0715 Binary files /dev/null and b/bbm/img/Large/White/icon_048.png differ diff --git a/bbm/img/Large/White/icon_086.png b/bbm/img/Large/White/icon_086.png new file mode 100644 index 00000000..d6e6d70d Binary files /dev/null and b/bbm/img/Large/White/icon_086.png differ diff --git a/bbm/img/Large/White/icon_099.png b/bbm/img/Large/White/icon_099.png new file mode 100644 index 00000000..dd0f86b5 Binary files /dev/null and b/bbm/img/Large/White/icon_099.png differ diff --git a/bbm/img/Large/White/icon_111.png b/bbm/img/Large/White/icon_111.png new file mode 100644 index 00000000..3746424a Binary files /dev/null and b/bbm/img/Large/White/icon_111.png differ diff --git a/bbm/img/Large/White/icon_127.png b/bbm/img/Large/White/icon_127.png new file mode 100644 index 00000000..c61375b1 Binary files /dev/null and b/bbm/img/Large/White/icon_127.png differ diff --git a/bbm/img/Large/White/icon_159.png b/bbm/img/Large/White/icon_159.png new file mode 100644 index 00000000..59fa2420 Binary files /dev/null and b/bbm/img/Large/White/icon_159.png differ diff --git a/bbm/img/Large/White/icon_180.png b/bbm/img/Large/White/icon_180.png new file mode 100644 index 00000000..8c559860 Binary files /dev/null and b/bbm/img/Large/White/icon_180.png differ diff --git a/bbm/img/Large/White/icon_185.png b/bbm/img/Large/White/icon_185.png new file mode 100644 index 00000000..9203f2cd Binary files /dev/null and b/bbm/img/Large/White/icon_185.png differ diff --git a/bbm/img/Large/White/icon_186.png b/bbm/img/Large/White/icon_186.png new file mode 100644 index 00000000..10ddd1bb Binary files /dev/null and b/bbm/img/Large/White/icon_186.png differ diff --git a/bbm/img/Large/White/icon_191.png b/bbm/img/Large/White/icon_191.png new file mode 100644 index 00000000..64b2f8e6 Binary files /dev/null and b/bbm/img/Large/White/icon_191.png differ diff --git a/bbm/img/Large/White/icon_194.png b/bbm/img/Large/White/icon_194.png new file mode 100644 index 00000000..29e537b6 Binary files /dev/null and b/bbm/img/Large/White/icon_194.png differ diff --git a/bbm/img/Large/White/icon_202.png b/bbm/img/Large/White/icon_202.png new file mode 100644 index 00000000..d1e30c8a Binary files /dev/null and b/bbm/img/Large/White/icon_202.png differ diff --git a/bbm/img/Large/White/icon_203.png b/bbm/img/Large/White/icon_203.png new file mode 100644 index 00000000..b8c9f20d Binary files /dev/null and b/bbm/img/Large/White/icon_203.png differ diff --git a/bbm/img/Large/White/icon_209.png b/bbm/img/Large/White/icon_209.png new file mode 100644 index 00000000..126d18ae Binary files /dev/null and b/bbm/img/Large/White/icon_209.png differ diff --git a/bbm/img/Large/White/icon_212.png b/bbm/img/Large/White/icon_212.png new file mode 100644 index 00000000..a4377f39 Binary files /dev/null and b/bbm/img/Large/White/icon_212.png differ diff --git a/bbm/img/Large/White/icon_235.png b/bbm/img/Large/White/icon_235.png new file mode 100644 index 00000000..e40ada45 Binary files /dev/null and b/bbm/img/Large/White/icon_235.png differ diff --git a/bbm/img/Large/White/icon_242.png b/bbm/img/Large/White/icon_242.png new file mode 100644 index 00000000..c19a6d56 Binary files /dev/null and b/bbm/img/Large/White/icon_242.png differ diff --git a/bbm/img/Large/White/icon_269.png b/bbm/img/Large/White/icon_269.png new file mode 100644 index 00000000..b8ea0480 Binary files /dev/null and b/bbm/img/Large/White/icon_269.png differ diff --git a/bbm/img/Large/White/icon_273.png b/bbm/img/Large/White/icon_273.png new file mode 100644 index 00000000..3af90ea5 Binary files /dev/null and b/bbm/img/Large/White/icon_273.png differ diff --git a/bbm/img/Large/White/icon_280.png b/bbm/img/Large/White/icon_280.png new file mode 100644 index 00000000..35fc6253 Binary files /dev/null and b/bbm/img/Large/White/icon_280.png differ diff --git a/bbm/img/Large/White/icon_283.png b/bbm/img/Large/White/icon_283.png new file mode 100644 index 00000000..d156092f Binary files /dev/null and b/bbm/img/Large/White/icon_283.png differ diff --git a/bbm/img/Large/White/icon_292.png b/bbm/img/Large/White/icon_292.png new file mode 100644 index 00000000..d90451c4 Binary files /dev/null and b/bbm/img/Large/White/icon_292.png differ diff --git a/bbm/img/Medium/White/icon_005.png b/bbm/img/Medium/White/icon_005.png new file mode 100644 index 00000000..489b20db Binary files /dev/null and b/bbm/img/Medium/White/icon_005.png differ diff --git a/bbm/img/Medium/White/icon_041.png b/bbm/img/Medium/White/icon_041.png new file mode 100644 index 00000000..215b30f2 Binary files /dev/null and b/bbm/img/Medium/White/icon_041.png differ diff --git a/bbm/img/Medium/White/icon_048.png b/bbm/img/Medium/White/icon_048.png new file mode 100644 index 00000000..cf8cc8b3 Binary files /dev/null and b/bbm/img/Medium/White/icon_048.png differ diff --git a/bbm/img/Medium/White/icon_086.png b/bbm/img/Medium/White/icon_086.png new file mode 100644 index 00000000..de6b1d2c Binary files /dev/null and b/bbm/img/Medium/White/icon_086.png differ diff --git a/bbm/img/Medium/White/icon_099.png b/bbm/img/Medium/White/icon_099.png new file mode 100644 index 00000000..f3662d3f Binary files /dev/null and b/bbm/img/Medium/White/icon_099.png differ diff --git a/bbm/img/Medium/White/icon_111.png b/bbm/img/Medium/White/icon_111.png new file mode 100644 index 00000000..7c29c741 Binary files /dev/null and b/bbm/img/Medium/White/icon_111.png differ diff --git a/bbm/img/Medium/White/icon_127.png b/bbm/img/Medium/White/icon_127.png new file mode 100644 index 00000000..7e61779d Binary files /dev/null and b/bbm/img/Medium/White/icon_127.png differ diff --git a/bbm/img/Medium/White/icon_159.png b/bbm/img/Medium/White/icon_159.png new file mode 100644 index 00000000..e89f29fe Binary files /dev/null and b/bbm/img/Medium/White/icon_159.png differ diff --git a/bbm/img/Medium/White/icon_180.png b/bbm/img/Medium/White/icon_180.png new file mode 100644 index 00000000..59eb5e72 Binary files /dev/null and b/bbm/img/Medium/White/icon_180.png differ diff --git a/bbm/img/Medium/White/icon_185.png b/bbm/img/Medium/White/icon_185.png new file mode 100644 index 00000000..03f957b0 Binary files /dev/null and b/bbm/img/Medium/White/icon_185.png differ diff --git a/bbm/img/Medium/White/icon_186.png b/bbm/img/Medium/White/icon_186.png new file mode 100644 index 00000000..949f612e Binary files /dev/null and b/bbm/img/Medium/White/icon_186.png differ diff --git a/bbm/img/Medium/White/icon_191.png b/bbm/img/Medium/White/icon_191.png new file mode 100644 index 00000000..857203a4 Binary files /dev/null and b/bbm/img/Medium/White/icon_191.png differ diff --git a/bbm/img/Medium/White/icon_194.png b/bbm/img/Medium/White/icon_194.png new file mode 100644 index 00000000..540a9d1b Binary files /dev/null and b/bbm/img/Medium/White/icon_194.png differ diff --git a/bbm/img/Medium/White/icon_202.png b/bbm/img/Medium/White/icon_202.png new file mode 100644 index 00000000..32838729 Binary files /dev/null and b/bbm/img/Medium/White/icon_202.png differ diff --git a/bbm/img/Medium/White/icon_203.png b/bbm/img/Medium/White/icon_203.png new file mode 100644 index 00000000..b7ec4ad0 Binary files /dev/null and b/bbm/img/Medium/White/icon_203.png differ diff --git a/bbm/img/Medium/White/icon_209.png b/bbm/img/Medium/White/icon_209.png new file mode 100644 index 00000000..597150df Binary files /dev/null and b/bbm/img/Medium/White/icon_209.png differ diff --git a/bbm/img/Medium/White/icon_212.png b/bbm/img/Medium/White/icon_212.png new file mode 100644 index 00000000..926990b7 Binary files /dev/null and b/bbm/img/Medium/White/icon_212.png differ diff --git a/bbm/img/Medium/White/icon_235.png b/bbm/img/Medium/White/icon_235.png new file mode 100644 index 00000000..5f043312 Binary files /dev/null and b/bbm/img/Medium/White/icon_235.png differ diff --git a/bbm/img/Medium/White/icon_242.png b/bbm/img/Medium/White/icon_242.png new file mode 100644 index 00000000..bcdca3e0 Binary files /dev/null and b/bbm/img/Medium/White/icon_242.png differ diff --git a/bbm/img/Medium/White/icon_269.png b/bbm/img/Medium/White/icon_269.png new file mode 100644 index 00000000..e2be51c6 Binary files /dev/null and b/bbm/img/Medium/White/icon_269.png differ diff --git a/bbm/img/Medium/White/icon_273.png b/bbm/img/Medium/White/icon_273.png new file mode 100644 index 00000000..e2374096 Binary files /dev/null and b/bbm/img/Medium/White/icon_273.png differ diff --git a/bbm/img/Medium/White/icon_280.png b/bbm/img/Medium/White/icon_280.png new file mode 100644 index 00000000..fa07aada Binary files /dev/null and b/bbm/img/Medium/White/icon_280.png differ diff --git a/bbm/img/Medium/White/icon_283.png b/bbm/img/Medium/White/icon_283.png new file mode 100644 index 00000000..52ce8527 Binary files /dev/null and b/bbm/img/Medium/White/icon_283.png differ diff --git a/bbm/img/Medium/White/icon_292.png b/bbm/img/Medium/White/icon_292.png new file mode 100644 index 00000000..c4ef609a Binary files /dev/null and b/bbm/img/Medium/White/icon_292.png differ diff --git a/bbm/img/README.md b/bbm/img/README.md new file mode 100644 index 00000000..ae5fcaf9 --- /dev/null +++ b/bbm/img/README.md @@ -0,0 +1,6 @@ +This is small Subway Icons Set released specially for RIM BB10 Dev Samples under CC BY 3.0 license. + +Included icons in three size - 81px, 71px and 61px + +Full set is available on Subway website: +http://subway.pixle.pl/rim/ \ No newline at end of file diff --git a/bbm/img/Small/White/icon_005.png b/bbm/img/Small/White/icon_005.png new file mode 100644 index 00000000..dad85349 Binary files /dev/null and b/bbm/img/Small/White/icon_005.png differ diff --git a/bbm/img/Small/White/icon_041.png b/bbm/img/Small/White/icon_041.png new file mode 100644 index 00000000..95708b9f Binary files /dev/null and b/bbm/img/Small/White/icon_041.png differ diff --git a/bbm/img/Small/White/icon_048.png b/bbm/img/Small/White/icon_048.png new file mode 100644 index 00000000..e5d80c99 Binary files /dev/null and b/bbm/img/Small/White/icon_048.png differ diff --git a/bbm/img/Small/White/icon_086.png b/bbm/img/Small/White/icon_086.png new file mode 100644 index 00000000..e9494b50 Binary files /dev/null and b/bbm/img/Small/White/icon_086.png differ diff --git a/bbm/img/Small/White/icon_099.png b/bbm/img/Small/White/icon_099.png new file mode 100644 index 00000000..d3f1be47 Binary files /dev/null and b/bbm/img/Small/White/icon_099.png differ diff --git a/bbm/img/Small/White/icon_111.png b/bbm/img/Small/White/icon_111.png new file mode 100644 index 00000000..6c6bc50e Binary files /dev/null and b/bbm/img/Small/White/icon_111.png differ diff --git a/bbm/img/Small/White/icon_127.png b/bbm/img/Small/White/icon_127.png new file mode 100644 index 00000000..2ca8d5b5 Binary files /dev/null and b/bbm/img/Small/White/icon_127.png differ diff --git a/bbm/img/Small/White/icon_159.png b/bbm/img/Small/White/icon_159.png new file mode 100644 index 00000000..8ea06f8e Binary files /dev/null and b/bbm/img/Small/White/icon_159.png differ diff --git a/bbm/img/Small/White/icon_180.png b/bbm/img/Small/White/icon_180.png new file mode 100644 index 00000000..7f55825b Binary files /dev/null and b/bbm/img/Small/White/icon_180.png differ diff --git a/bbm/img/Small/White/icon_185.png b/bbm/img/Small/White/icon_185.png new file mode 100644 index 00000000..4c2f0327 Binary files /dev/null and b/bbm/img/Small/White/icon_185.png differ diff --git a/bbm/img/Small/White/icon_186.png b/bbm/img/Small/White/icon_186.png new file mode 100644 index 00000000..3f613b4d Binary files /dev/null and b/bbm/img/Small/White/icon_186.png differ diff --git a/bbm/img/Small/White/icon_191.png b/bbm/img/Small/White/icon_191.png new file mode 100644 index 00000000..623786f4 Binary files /dev/null and b/bbm/img/Small/White/icon_191.png differ diff --git a/bbm/img/Small/White/icon_194.png b/bbm/img/Small/White/icon_194.png new file mode 100644 index 00000000..7bddf490 Binary files /dev/null and b/bbm/img/Small/White/icon_194.png differ diff --git a/bbm/img/Small/White/icon_202.png b/bbm/img/Small/White/icon_202.png new file mode 100644 index 00000000..346ffecf Binary files /dev/null and b/bbm/img/Small/White/icon_202.png differ diff --git a/bbm/img/Small/White/icon_203.png b/bbm/img/Small/White/icon_203.png new file mode 100644 index 00000000..06b36d8b Binary files /dev/null and b/bbm/img/Small/White/icon_203.png differ diff --git a/bbm/img/Small/White/icon_209.png b/bbm/img/Small/White/icon_209.png new file mode 100644 index 00000000..26f2037f Binary files /dev/null and b/bbm/img/Small/White/icon_209.png differ diff --git a/bbm/img/Small/White/icon_212.png b/bbm/img/Small/White/icon_212.png new file mode 100644 index 00000000..2d575727 Binary files /dev/null and b/bbm/img/Small/White/icon_212.png differ diff --git a/bbm/img/Small/White/icon_235.png b/bbm/img/Small/White/icon_235.png new file mode 100644 index 00000000..000019c0 Binary files /dev/null and b/bbm/img/Small/White/icon_235.png differ diff --git a/bbm/img/Small/White/icon_242.png b/bbm/img/Small/White/icon_242.png new file mode 100644 index 00000000..ea751caa Binary files /dev/null and b/bbm/img/Small/White/icon_242.png differ diff --git a/bbm/img/Small/White/icon_269.png b/bbm/img/Small/White/icon_269.png new file mode 100644 index 00000000..fa4e51b4 Binary files /dev/null and b/bbm/img/Small/White/icon_269.png differ diff --git a/bbm/img/Small/White/icon_273.png b/bbm/img/Small/White/icon_273.png new file mode 100644 index 00000000..91ea7ba5 Binary files /dev/null and b/bbm/img/Small/White/icon_273.png differ diff --git a/bbm/img/Small/White/icon_280.png b/bbm/img/Small/White/icon_280.png new file mode 100644 index 00000000..75bdfcf5 Binary files /dev/null and b/bbm/img/Small/White/icon_280.png differ diff --git a/bbm/img/Small/White/icon_283.png b/bbm/img/Small/White/icon_283.png new file mode 100644 index 00000000..285b6645 Binary files /dev/null and b/bbm/img/Small/White/icon_283.png differ diff --git a/bbm/img/Small/White/icon_292.png b/bbm/img/Small/White/icon_292.png new file mode 100644 index 00000000..32ce005b Binary files /dev/null and b/bbm/img/Small/White/icon_292.png differ diff --git a/bbm/img/avatar-128x128.png b/bbm/img/avatar-128x128.png new file mode 100644 index 00000000..32bfe3a1 Binary files /dev/null and b/bbm/img/avatar-128x128.png differ diff --git a/bbm/img/avatar-32x32.png b/bbm/img/avatar-32x32.png new file mode 100644 index 00000000..f043c339 Binary files /dev/null and b/bbm/img/avatar-32x32.png differ diff --git a/bbm/img/avatar-64x64.png b/bbm/img/avatar-64x64.png new file mode 100644 index 00000000..206c4880 Binary files /dev/null and b/bbm/img/avatar-64x64.png differ diff --git a/bbm/img/avatar.png b/bbm/img/avatar.png new file mode 100644 index 00000000..52547310 Binary files /dev/null and b/bbm/img/avatar.png differ diff --git a/bbm/index.html b/bbm/index.html index 551d77b4..a3440524 100644 --- a/bbm/index.html +++ b/bbm/index.html @@ -1,4 +1,5 @@ + - - - - - BBM Sample - - - - - - - - + + + + + + + + + + + \ No newline at end of file diff --git a/bbm/js/bbm.js b/bbm/js/bbm.js index e5e0d894..0778d02d 100644 --- a/bbm/js/bbm.js +++ b/bbm/js/bbm.js @@ -1,173 +1,134 @@ -/** - * Copyright (c) 2012 Research In Motion Limited. - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * - * You may obtain a copy of the License at: - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * - * See the License for the specific language governing permissions and - * limitations under the License. - */ +/*global blackberry */ -/*global window, document, console, alert, blackberry */ - -/* This file holds the majority of the functionality for integration with - * BlackBerry Messenger. - */ - -var _bbm = { +var bbm = { registered: false, - /* This will be called when the user clicks the 'set' button for - * status or personal message. + /** + * Registers this application with the blackberry.bbm.platform APIs. + * + * NOTE: This is NOT required for the invoke APIs. */ - setField: function (field) { - 'use strict'; - var status, message, onComplete; - - if (field === 'status') { - /* Assign the status for this update. */ - if (document.querySelector('#status').getChecked() === true) { - status = 'available'; - } else { - status = 'busy'; + register: function () { + blackberry.event.addEventListener('onaccesschanged', function (accessible, status) { + if (status === 'unregistered') { + blackberry.bbm.platform.register({ + uuid: '33490f91-ad95-4ba9-82c4-33f6ad69fbbc' + }); + } else if (status === 'allowed') { + bbm.registered = accessible; } - - /* Assign the status message for this update. */ - message = document.querySelector('#statusMessage').value; - - /* Assign the onComplete function for this update. */ - onComplete = function (accepted) { - if (accepted === true) { - alert('Status update was accepted.'); - } else { - alert('Status update was not accepted.'); - } - }; - - /* Call setStatus with our defined arguments. */ - blackberry.bbm.platform.self.setStatus(status, message, onComplete); - } else if (field === 'personalMessage') { - /* Assign the personal message for this update. */ - message = document.querySelector('#personalMessage').value; - - /* Assign the onComplete function for this update. */ - onComplete = function (accepted) { - if (accepted === true) { - alert('Status update was accepted.'); - } else { - alert('Status update was not accepted.'); - } - }; - - /* Call setPersonalMessage with our defined arguments. */ - blackberry.bbm.platform.self.setPersonalMessage(message, onComplete); - } + }, false); }, - fieldChanged: function (element) { - 'use strict'; - - /* Reset all of our fields to invisible. */ - document.querySelector('#_status').style.display = 'none'; - document.querySelector('#_personalMessage').style.display = 'none'; - document.querySelector('#_ppid').style.display = 'none'; - document.querySelector('#_handle').style.display = 'none'; - document.querySelector('#_appVersion').style.display = 'none'; - document.querySelector('#_bbmsdkVersion').style.display = 'none'; - - /* Show the chosen field. */ - document.querySelector("#_" + element.value).style.display = 'inline'; + /** + * setDisplayPicture: Sets the BBM profile display picture. + */ + setDisplayPicture: function () { + blackberry.bbm.platform.self.setDisplayPicture('local:///img/avatar-32x32.png'); }, - populate: function () { - 'use strict'; - - /* Only allow functionality if we've registered with BBM. */ - if (_bbm.registered === true) { - /* Set the Display Name from the BBM profile. */ - document.querySelector('#displayName').innerHTML = blackberry.bbm.platform.self.displayName; + /** + * inviteToDownload: Displays a BBM list of existing users that can be + * contacted to also download this application. + */ + inviteToDownload: function () { + blackberry.bbm.platform.users.inviteToDownload(); + }, - /* Set the Status from the BBM profile. */ - if (blackberry.bbm.platform.self.status === 'available') { - document.querySelector('#status').setChecked(true); - } else { - document.querySelector('#status').setChecked(false); - } + /** + * inviteToBBM: Invokes the invite to BBM functionality to add BBM contacts. + */ + inviteToBBM: function () { + blackberry.invoke.invoke({ + action: 'bb.action.INVITEBBM', + uri: 'pin:2100000A' + }); + }, - /* The remaining fields are direct assignments. */ - document.querySelector('#statusMessage').value = blackberry.bbm.platform.self.statusMessage; - document.querySelector('#personalMessage').value = blackberry.bbm.platform.self.personalMessage; - document.querySelector('#ppid').innerHTML = blackberry.bbm.platform.self.ppid; - document.querySelector('#handle').innerHTML = blackberry.bbm.platform.self.handle; - document.querySelector('#appVersion').innerHTML = blackberry.bbm.platform.self.appVersion; - document.querySelector('#bbmsdkVersion').innerHTML = blackberry.bbm.platform.self.bbmsdkVersion; - } else { - alert('You must register with BBM first.'); - } + /** + * setAvatar: Invokes the avatar selector on the specified image. + */ + setAvatar: function () { + blackberry.invoke.invoke({ + target: 'sys.bbm.imagehandler', + action: 'bb.action.SET', + uri: 'local:///img/avatar.png' + }); }, - /* Will be called when the user clicks the Register button. */ - register: function () { - 'use strict'; - var options; + /** + * startChat: Invokes a BBM chat with an existing BBM contact. + * + * Specifying a PIN that is not already in the user's contacts will result in the Invite To BBM screen. + * + * Specifying a PIN that is in the user's contacts will immediately start a chat with that person. + * + * Specifying no PIN should invoke the Contact Picker, but currently does not. However, shareText with empty data string should do the job. + */ + startChat: function () { + blackberry.invoke.invoke({ + action: 'bb.action.BBMCHAT' + }); + }, - /* Only invoke this functionality if we have not yet registered. */ - if (_bbm.registered === false) { - blackberry.event.addEventListener('onaccesschanged', function (allowed, reason) { - /* If we haven't registered yet, kick off our attempt. */ - if (reason === 'unregistered') { - /* A valid, unique, 36-character UUID is being used. */ - options = { - uuid: "33490f91-ad95-4ba9-82c4-33f6ad69fbbc" - }; + /** + * shareText: Starts a chat session with pre-populated text. + */ + shareText: function () { + blackberry.invoke.invoke({ + target: 'sys.bbm.sharehandler', + action: 'bb.action.SHARE', + data: 'This is some text.', + mimeType: 'text/plain' + }); + }, - /* Call the register function with our UUID. */ - blackberry.bbm.platform.register(options); - } else if (allowed === true) { - /* Access allowed. */ - _bbm.registered = true; + /** + * shareImage: Starts a chat session with attached image. + */ + shareImage: function () { + blackberry.invoke.invoke({ + target: 'sys.bbm.sharehandler', + action: 'bb.action.SHARE', + uri: 'local:///img/avatar.png' + }); + }, - /* Show our BBM Fields panel. */ - document.querySelector('#profile').style.display = 'inline'; - } else if (reason === 'user') { - /* Access blocked by user. */ - alert('Access is blocked by the user.'); - } else if (reason === 'rim') { - /* Access blocked by RIM. */ - alert('Access is blocked by RIM.'); - } else { - /* Remaining error codes have been implemented. */ - if (reason === 'itpolicy') { - alert('Access is blocked by IT Policy.'); - } else if (reason === 'resetrequired') { - alert('Access is blocked because a device reset is required to use the BBM Social Platform.'); - } else if (reason === 'nodata') { - alert('Access is blocked because the device is out of data coverage. A data connection is required to register the application.'); - } else if (reason === 'temperror') { - alert('Access is blocked because of a temporary error. The application should try to call blackberry.bbm.platform.register in 30 minutes, or the next time the application starts.'); - } else if (reason === 'nonuiapp') { - alert('Access is blocked because blackberry.bbm.platform.register was called from a non-UI application.'); - } - } - }); - } + /** + * populate: Retrieve BBM profile information and populate a BBUI screen. + */ + populate: function (element) { + element.querySelector('#displayname').setCaption(blackberry.bbm.platform.self.displayName); + + element.querySelector('#available').setChecked( + blackberry.bbm.platform.self.status === 'available' ? true : false + ); + + element.querySelector('#statusmessage').value = blackberry.bbm.platform.self.statusMessage; + element.querySelector('#personalmessage').value = blackberry.bbm.platform.self.personalMessage; + element.querySelector('#ppid').value = blackberry.bbm.platform.self.ppid; + element.querySelector('#handle').value = blackberry.bbm.platform.self.handle; + element.querySelector('#applicationversion').value = blackberry.bbm.platform.self.appVersion; + element.querySelector('#bbmsdkversion').value = blackberry.bbm.platform.self.bbmsdkVersion; }, - invite: function () { - 'use strict'; + /** + * save: Updates the user's BBM profile based on the current information. + */ + save: function () { + /* Update status. */ + blackberry.bbm.platform.self.setStatus( + document.querySelector('#available').getChecked() === true ? 'available' : 'busy', + document.querySelector('#statusmessage').value, + function (accepted) { + } + ); - /* Only allow functionality if we've registered with BBM. */ - if (_bbm.registered === true) { - blackberry.bbm.platform.users.inviteToDownload(); - } else { - alert('You must register with BBM first.'); - } + /* Update personal message. */ + blackberry.bbm.platform.self.setPersonalMessage( + document.querySelector('#personalmessage').value, + function (accepted) { + } + ); } }; \ No newline at end of file diff --git a/bbm/js/bbui-0.9.5.js b/bbm/js/bbui-0.9.5.js new file mode 100644 index 00000000..80a6c922 --- /dev/null +++ b/bbm/js/bbui-0.9.5.js @@ -0,0 +1,8972 @@ +/* +* Copyright 2010-2012 Research In Motion Limited. +* +* Licensed under the Apache License, Version 2.0 (the "License"); +* you may not use this file except in compliance with the License. +* You may obtain a copy of the License at +* +* http://www.apache.org/licenses/LICENSE-2.0 +* +* Unless required by applicable law or agreed to in writing, software +* distributed under the License is distributed on an "AS IS" BASIS, +* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +* See the License for the specific language governing permissions and +* limitations under the License. +*/ + + +bb = { + scroller: null, + screens: [], + dropdownScrollers: [], + transparentPixel: '', + + // Core control variables + imageList : null, + activityIndicator : null, + fileInput : null, + button : null, + scrollPanel : null, + bbmBubble : null, + dropdown : null, + textInput : null, + roundPanel : null, + grid : null, + pillButtons : null, + labelControlContainers : null, + slider : null, + radio : null, + progress : null, + checkbox : null, + toggle : null, + + // Initialize the the options of bbUI + init : function (options) { + if (options) { + for (var i in options) bb.options[i] = options[i]; + } + + // Assign our back handler if provided otherwise assign the default + if (window.blackberry && blackberry.system && blackberry.system.event && blackberry.system.event.onHardwareKey) { + if (bb.options.onbackkey) { + blackberry.system.event.onHardwareKey(blackberry.system.event.KEY_BACK, bb.options.onbackkey); + } else { // Use the default + blackberry.system.event.onHardwareKey(blackberry.system.event.KEY_BACK, bb.popScreen); + } + } + + // Initialize our flags once so that we don't have to run logic in-line for decision making + bb.device.isRipple = (navigator.userAgent.indexOf('Ripple') >= 0) || window.tinyHippos; + bb.device.isPlayBook = (navigator.userAgent.indexOf('PlayBook') >= 0) || ((window.innerWidth == 1024 && window.innerHeight == 600) || (window.innerWidth == 600 && window.innerHeight == 1024)); + if (bb.device.isPlayBook && bb.options.bb10ForPlayBook) { + bb.device.isBB10 = true; + } else { + bb.device.isBB10 = (navigator.userAgent.indexOf('Version/10.0') >= 0); + } + bb.device.isBB7 = (navigator.userAgent.indexOf('7.0.0') >= 0) || (navigator.userAgent.indexOf('7.1.0') >= 0); + bb.device.isBB6 = navigator.userAgent.indexOf('6.0.0') >= 0; + bb.device.isBB5 = navigator.userAgent.indexOf('5.0.0') >= 0; + + // Determine HiRes + if (bb.device.isRipple) { + bb.device.isHiRes = window.innerHeight > 480 || window.innerWidth > 480; + } else { + bb.device.isHiRes = screen.width > 480 || screen.height > 480; + } + + // Check if a viewport tags exist and remove them, We'll add the bbUI friendly one + var viewports = document.head.querySelectorAll('meta[name=viewport]'), + i; + for (i = 0; i < viewports.length; i++) { + try { + document.head.removeChild(viewports[i]); + } catch (ex) { + // Throw away the error + } + } + + // Set our meta tags for content scaling + var meta = document.createElement('meta'); + meta.setAttribute('name','viewport'); + if (bb.device.isBB10 && !bb.device.isPlayBook) { + meta.setAttribute('content','initial-scale='+ (1/window.devicePixelRatio) +',user-scalable=no'); + } else { + meta.setAttribute('content','initial-scale=1.0,width=device-width,user-scalable=no,target-densitydpi=device-dpi'); + } + document.head.appendChild(meta); + + // Create our shades of colors + var R = parseInt((bb.cutHex(bb.options.highlightColor)).substring(0,2),16), + G = parseInt((bb.cutHex(bb.options.highlightColor)).substring(2,4),16), + B = parseInt((bb.cutHex(bb.options.highlightColor)).substring(4,6),16); + bb.options.shades = { + R : R, + G : G, + B : B, + darkHighlight: 'rgb('+ (R - 120) +', '+ (G - 120) +', '+ (B - 120) +')', + mediumHighlight: 'rgb('+ (R - 60) +', '+ (G - 60) +', '+ (B - 60) +')', + darkOutline: 'rgb('+ (R - 32) +', '+ (G - 32) +', '+ (B - 32) +')', + darkDarkHighlight: 'rgb('+ (R - 140) +', '+ (G - 140) +', '+ (B - 140) +')' + }; + + // Create our coloring + if (document.styleSheets && document.styleSheets.length) { + try { + document.styleSheets[0].insertRule('.bb10Highlight {background-color:'+ bb.options.highlightColor +';background-image:none;}', 0); + document.styleSheets[0].insertRule('.bbProgressHighlight {background-color:#92B43B;background-image:none;}', 0); + document.styleSheets[0].insertRule('.bb10-button-highlight {color:White;background-image: -webkit-gradient(linear, center top, center bottom, from('+bb.options.shades.darkHighlight+'), to('+bb.options.highlightColor+'));border-color:#53514F;}', 0); + document.styleSheets[0].insertRule('.pb-button-light-highlight {color:'+bb.options.shades.darkHighlight+';background-image: -webkit-gradient(linear, center top, center bottom, from('+bb.options.highlightColor+'), to('+bb.options.shades.darkHighlight+'));}', 0); + document.styleSheets[0].insertRule('.pb-button-dark-highlight {color:'+bb.options.highlightColor+';background-image: -webkit-gradient(linear, center top, center bottom, from('+bb.options.highlightColor+'), to('+bb.options.shades.darkHighlight+'));}', 0); + document.styleSheets[0].insertRule('.bb10Accent {background-color:'+ bb.options.shades.darkHighlight +';}', 0); + document.styleSheets[0].insertRule('.bb10-title-colored {color:white;text-shadow: 0px 2px black;background-image: -webkit-gradient(linear, center top, center bottom, from('+bb.options.highlightColor+'), to('+bb.options.shades.darkHighlight+'));}', 0); + document.styleSheets[0].insertRule('.bb10-title-button-container-colored {color:white;text-shadow: 0px 2px black;border-color: ' + bb.options.shades.darkDarkHighlight +';background-color: '+bb.options.shades.darkHighlight+';}', 0); + document.styleSheets[0].insertRule('.bb10-title-button-colored {border-color: ' + bb.options.shades.darkDarkHighlight +';background-image: -webkit-gradient(linear, center top, center bottom, from('+bb.options.highlightColor+'), to('+bb.options.shades.mediumHighlight+'));}', 0); + document.styleSheets[0].insertRule('.bb10-title-button-colored-highlight {border-color: ' + bb.options.shades.darkDarkHighlight +';background-color: '+bb.options.shades.darkHighlight+';}', 0); + } + catch (ex) { + console.log(ex.message); + } + } + // Set our coloring + bb.actionBar.color = (bb.options.actionBarDark) ? 'dark' : 'light'; + bb.screen.controlColor = (bb.options.controlsDark) ? 'dark' : 'light'; + bb.screen.listColor = (bb.options.listsDark) ? 'dark' : 'light'; + + // Set up our pointers to objects for each OS version + if (bb.device.isBB10) { + bb.imageList = _bb10_imageList + bb.activityIndicator = _bb10_activityIndicator; + bb.fileInput = _bb10_fileInput; + bb.button = _bb10_button; + bb.scrollPanel = _bb_PlayBook_10_scrollPanel; + bb.bbmBubble = _bb_bbmBubble; + bb.dropdown = _bb10_dropdown; + bb.textInput = _bb10_textInput; + bb.roundPanel = _bb10_roundPanel; + bb.grid = _bb10_grid; + bb.pillButtons = _bb10_pillButtons; + bb.labelControlContainers = _bb10_labelControlContainers; + bb.slider = _bb10_slider; + bb.radio = _bb10_radio; + bb.progress = _bb_progress; + bb.checkbox = _bb10_checkbox; + bb.toggle = _bb10_toggle; + } else if (bb.device.isBB5) { + bb.imageList = _bb_5_6_7_imageList; + bb.button = _bb5_button; + bb.bbmBubble = _bb_bbmBubble; + bb.roundPanel = _bb_5_6_7_roundPanel; + bb.pillButtons = _bb5_pillButtons; + bb.labelControlContainers = _bb5_labelControlContainers; + bb.progress = _bb_progress; + } else if (bb.device.isPlayBook) { + bb.imageList = _bbPlayBook_imageList; + bb.button = _bbPlayBook_button; + bb.bbmBubble = _bb_bbmBubble; + bb.dropdown = _bb_6_7_PlayBook_dropdown; + bb.textInput = _bbPlayBook_textInput; + bb.pillButtons = _bb_6_7_PlayBook_pillButtons; + bb.labelControlContainers = _bb_6_7_PlayBook_labelControlContainers; + bb.progress = _bb_progress; + bb.scrollPanel = _bb_PlayBook_10_scrollPanel; + bb.roundPanel = _bbPlayBook_roundPanel; + bb.activityIndicator = _bbPlayBook_activityIndicator; + } else { //BB6 & BB7 + bb.imageList = _bb_5_6_7_imageList; + bb.button = _bb_6_7_button; + bb.bbmBubble = _bb_bbmBubble; + bb.dropdown = _bb_6_7_PlayBook_dropdown; + bb.textInput = _bb_6_7_textInput; + bb.pillButtons = _bb_6_7_PlayBook_pillButtons; + bb.labelControlContainers = _bb_6_7_PlayBook_labelControlContainers; + bb.progress = _bb_progress; + bb.roundPanel = _bb_5_6_7_roundPanel; + } + }, + + doLoad: function(element) { + // Apply our styling + var root = element || document.body; + bb.screen.apply(root.querySelectorAll('[data-bb-type=screen]')); + if (bb.scrollPanel) bb.scrollPanel.apply(root.querySelectorAll('[data-bb-type=scroll-panel]')); + if (bb.textInput) bb.textInput.apply(root.querySelectorAll('input[type=text], [type=password], [type=tel], [type=url], [type=email], [type=number], [type=date], [type=time], [type=datetime], [type=month], [type=datetime-local], [type=color], [type=search]')); + if (bb.dropdown) bb.dropdown.apply(root.querySelectorAll('select')); + if (bb.roundPanel) bb.roundPanel.apply(root.querySelectorAll('[data-bb-type=round-panel]')); + if (bb.imageList) bb.imageList.apply(root.querySelectorAll('[data-bb-type=image-list]')); + if (bb.grid) bb.grid.apply(root.querySelectorAll('[data-bb-type=grid-layout]')); + if (bb.bbmBubble) bb.bbmBubble.apply(root.querySelectorAll('[data-bb-type=bbm-bubble]')); + if (bb.pillButtons) bb.pillButtons.apply(root.querySelectorAll('[data-bb-type=pill-buttons]')); + if (bb.labelControlContainers) bb.labelControlContainers.apply(root.querySelectorAll('[data-bb-type=label-control-container]')); + if(bb.button) bb.button.apply(root.querySelectorAll('[data-bb-type=button]')); + if (bb.fileInput) bb.fileInput.apply(root.querySelectorAll('input[type=file]')); + if (bb.slider) bb.slider.apply(root.querySelectorAll('input[type=range]')); + if (bb.progress) bb.progress.apply(root.querySelectorAll('progress')); + if (bb.radio) bb.radio.apply(root.querySelectorAll('input[type=radio]')); + if (bb.activityIndicator) bb.activityIndicator.apply(root.querySelectorAll('[data-bb-type=activity-indicator]')); + if (bb.checkbox) bb.checkbox.apply(root.querySelectorAll('input[type=checkbox]')); + if (bb.toggle) bb.toggle.apply(root.querySelectorAll('[data-bb-type=toggle]')); + // perform device specific formatting + bb.screen.reAdjustHeight(); + }, + + device: { + isHiRes: false, + isBB5: false, + isBB6: false, + isBB7: false, + isBB10: false, + isPlayBook: false, + isRipple: false + }, + + // Options for rendering + options: { + onbackkey: null, + onscreenready: null, + ondomready: null, + actionBarDark: true, + controlsDark: false, + coloredTitleBar: false, + listsDark: false, + highlightColor: '#00A8DF', + bb10ForPlayBook: false + }, + + loadScreen: function(url, id, popping, guid, params, screenRecord) { + var xhr = new XMLHttpRequest(), + container = document.createElement('div'), + _reduce = function (nl, func, start) { + var result = start; + + Array.prototype.forEach.apply(nl, [function (v) { + result = func(result, v); + }]); + + return result; + }, + whereScript = function (result, el) { + if (el.nodeName === "SCRIPT") { + result.push(el); + } + + return _reduce(el.childNodes, whereScript, result); + }, + i, + scripts = [], + newScriptTags = []; + + xhr.open("GET", url, false); + xhr.send(); + + container.setAttribute('id', guid); + container.innerHTML = xhr.responseText; + + // Add any Java Script files that need to be included + scripts = _reduce(container.childNodes, whereScript, []), + container.scriptIds = []; + + // Clear out old script id references if we are reloading a screen that was in the stack + if (screenRecord) { + screenRecord.scripts = []; + } + + scripts.forEach(function (script) { + var scriptTag = document.createElement('script'); + + if (script.text) { + //if there is text, just eval it since they probably don't have a src. + eval(script.text); + return; + } + var scriptGuid = bb.guidGenerator(); + // Either update the old screen in the stack record or add to the new one + if (screenRecord) { + screenRecord.scripts.push({'id' : scriptGuid, 'onunload': script.getAttribute('onunload')}); + } else { + container.scriptIds.push({'id' : scriptGuid, 'onunload': script.getAttribute('onunload')}); + } + scriptTag.setAttribute('type','text/javascript'); + scriptTag.setAttribute('src', script.getAttribute('src')); + scriptTag.setAttribute('id', scriptGuid); + newScriptTags.push(scriptTag); + // Remove script tag from container because we are going to add it to + script.parentNode.removeChild(script); + }); + + // Add getElementById for the container so that it can be used in the onscreenready event + container.getElementById = function(id, node) { + var result = null; + if (!node) { + node = this; + } + if ( node.getAttribute('id') == id ) + return node; + + for ( var i = 0; i < node.childNodes.length; i++ ) { + var child = node.childNodes[i]; + if ( child.nodeType == 1 ) { + result = this.getElementById( id, child ); + if (result) + break; + } + } + return result; + }; + + // Special handling for inserting script tags + bb.screen.scriptCounter = 0; + bb.screen.totalScripts = newScriptTags.length; + for (var i = 0; i < newScriptTags.length; i++) { + document.body.appendChild(newScriptTags[i]); + newScriptTags[i].onload = function() { + bb.screen.scriptCounter++; + if(bb.screen.scriptCounter == bb.screen.totalScripts) { + bb.initContainer(container, id, popping, params); + } + }; + } + + // In case there are no scripts at all we simply doLoad(). We do this in + // a setTimeout() so that it is asynchronous just like if you were loading referenced + // script tags. If we don't call this asynchronous, then the screen stack is in different + // states depending on if you have scripts or not + if(bb.screen.totalScripts === 0) { + setTimeout(function() { bb.initContainer(container, id, popping, params) }, 0); + } + return container; + }, + + // Initialize the container + initContainer : function(container, id, popping, params) { + // Fire the onscreenready and then apply our changes in doLoad() + if (bb.options.onscreenready) { + bb.options.onscreenready(container, id, params); + } + bb.doLoad(container); + // Load in the new content + document.body.appendChild(container); + + var screen = container.querySelectorAll('[data-bb-type=screen]'), + animationScreen, + effect, + effectToApply = null, + overlay; + + if (screen.length > 0 ) { + screen = screen[0]; + // Swap the screen with the animation + if (popping) { + var previousContainer = bb.screens[bb.screens.length - 1].container, + previousEffect; + animationScreen = previousContainer.querySelectorAll('[data-bb-type=screen]')[0]; + previousEffect = animationScreen.hasAttribute('data-bb-effect') ? animationScreen.getAttribute('data-bb-effect') : undefined; + // Reverse the animation + if (previousEffect) { + screen.style['z-index'] = '-100'; + if (previousEffect.toLowerCase() == 'fade'){ + animationScreen.setAttribute('data-bb-effect','fade-out'); + }else if (previousEffect.toLowerCase() == 'slide-left'){ + animationScreen.setAttribute('data-bb-effect','slide-out-right'); + } else if (previousEffect.toLowerCase() == 'slide-right') { + animationScreen.setAttribute('data-bb-effect','slide-out-left'); + } else if (previousEffect.toLowerCase() == 'slide-up') { + animationScreen.setAttribute('data-bb-effect','slide-out-down'); + } else if (previousEffect.toLowerCase() == 'slide-down') { + animationScreen.setAttribute('data-bb-effect','slide-out-up'); + } + } + } else { + animationScreen = screen; + } + animationScreen.popping = popping; + if (animationScreen.hasAttribute('data-bb-effect')) { + // see if there is a display effect + if (!bb.device.isBB5 && !bb.device.isBB6) { + effect = animationScreen.getAttribute('data-bb-effect'); + if (effect) { + effect = effect.toLowerCase(); + + if (effect == 'fade') { + effectToApply = bb.screen.fadeIn; + } else if (effect == 'fade-out') { + effectToApply = bb.screen.fadeOut; + } else if (!bb.device.isBB7) { + switch (effect) { + case 'slide-left': + effectToApply = bb.screen.slideLeft; + break; + case 'slide-out-left': + effectToApply = bb.screen.slideOutLeft; + break; + case 'slide-right': + effectToApply = bb.screen.slideRight; + break; + case 'slide-out-right': + effectToApply = bb.screen.slideOutRight; + break; + case 'slide-up': + effectToApply = bb.screen.slideUp; + break; + case 'slide-out-up': + effectToApply = bb.screen.slideOutUp; + break; + case 'slide-down': + effectToApply = bb.screen.slideDown; + break; + case 'slide-out-down': + effectToApply = bb.screen.slideOutDown; + break; + } + } + + animationScreen.style.display = 'inline'; // This is a wierd hack + + // Listen for when the animation ends so that we can clear the previous screen + if (effectToApply) { + // Create our overlay + overlay = document.createElement('div'); + animationScreen.overlay = overlay; + overlay.setAttribute('class','bb-transition-overlay'); + document.body.appendChild(overlay); + // Add our listener and animation state + bb.screen.animating = true; + animationScreen.doEndAnimation = function() { + var s = this.style; + bb.screen.animating = false; + // Remove our overlay + document.body.removeChild(this.overlay); + this.overlay = null; + // Only remove the screen at the end of animation "IF" it isn't the only screen left + if (bb.screens.length > 1) { + if (!this.popping) { + bb.removePreviousScreenFromDom(); + // Clear style changes that may have been made for the animation + s.left = ''; + s.right = ''; + s.top = ''; + s.bottom = ''; + s.width = ''; + s.height = ''; + s['-webkit-animation-name'] = ''; + s['-webkit-animation-duration'] = ''; + s['-webkit-animation-timing-function'] = ''; + s['-webkit-transform'] = ''; + } else { + this.style.display = 'none'; + this.parentNode.parentNode.removeChild(this.parentNode); + // Pop it from the stack + bb.screens.pop(); + screen.style['z-index'] = ''; + // The container of bb.screens might be destroyed because every time re-creating even when the pop-up screen. + bb.screens[bb.screens.length-1].container = container; + } + } else if (bb.screens.length <= 1) { + // Clear style changes that may have been made for the animation + s.left = ''; + s.right = ''; + s.top = ''; + s.bottom = ''; + s.width = ''; + s.height = ''; + s['-webkit-animation-name'] = ''; + s['-webkit-animation-duration'] = ''; + s['-webkit-animation-timing-function'] = ''; + s['-webkit-transform'] = ''; + } + + this.removeEventListener('webkitAnimationEnd',this.doEndAnimation); + bb.createScreenScroller(screen); + }; + animationScreen.doEndAnimation = animationScreen.doEndAnimation.bind(animationScreen); + animationScreen.addEventListener('webkitAnimationEnd',animationScreen.doEndAnimation); + + effectToApply.call(this, animationScreen); + } + } + } + } + } + + // Fire the ondomready after the element is added to the DOM and we've set our animation flags + if (bb.options.ondomready) { + bb.domready.container = container; + bb.domready.id = id; + bb.domready.params = params; + setTimeout(bb.domready.fire, 1); + } + + // If an effect was applied then the popping will be handled at the end of the animation + if (!effectToApply) { + if (!popping) { + if ((bb.device.isBB5 || bb.device.isBB6 || bb.device.isBB7) && (bb.screens.length > 0)) { + bb.removePreviousScreenFromDom(); + } else if (bb.screens.length > 1) { + bb.removePreviousScreenFromDom(); + } + } else if (popping) { + screen.style['z-index'] = ''; + + var currentScreen = bb.screens[bb.screens.length-1].container; + currentScreen.parentNode.removeChild(currentScreen); + // Pop it from the stack + bb.screens.pop(); + // The container of bb.screens might be destroyed because every time re-creating even when the pop-up screen. + bb.screens[bb.screens.length-1].container = container; + } + bb.createScreenScroller(screen); + } + }, + + // Function pointer to allow us to asynchronously fire ondomready + domready : { + + container : null, + id : null, + params : null, + + fire : function() { + if (bb.screen.animating) { + setTimeout(bb.domready.fire, 250); + return; + } + bb.options.ondomready(bb.domready.container, bb.domready.id, bb.domready.params); + bb.domready.container = null; + bb.domready.id = null; + bb.domready.params = null; + } + + }, + + // Creates the scroller for the screen + createScreenScroller : function(screen) { + var scrollWrapper = screen.bbUIscrollWrapper; + if (scrollWrapper) { + // Only apply iScroll if it is the PlayBook + if (bb.device.isPlayBook) { + var scrollerOptions = {hideScrollbar:true,fadeScrollbar:true, onBeforeScrollStart: function (e) { + var target = e.target; + + // Don't scroll the screen when touching in our drop downs for BB10 + if (target.parentNode && target.parentNode.getAttribute('class') == 'bb-bb10-dropdown-items') { + return; + } + + while (target.nodeType != 1) target = target.parentNode; + + if (target.tagName != 'SELECT' && target.tagName != 'INPUT' && target.tagName != 'TEXTAREA' && target.tagName != 'AUDIO' && target.tagName != 'VIDEO') { + e.preventDefault(); + // ensure we remove focus from a control if they touch outside the control in order to make the virtual keyboard disappear + var activeElement = document.activeElement; + if (activeElement) { + if (activeElement.tagName == 'SELECT' || activeElement.tagName == 'INPUT' || activeElement.tagName == 'TEXTAREA' || activeElement.tagName == 'AUDIO' || activeElement.tagName == 'VIDEO') { + activeElement.blur(); + } + } + } + // LEAVING THESE HERE INCASE WE NEED TO FALL BACK TO ISCROLL OVERRIDES + /*if (bb.options.screen && bb.options.screen.onBeforeScrollStart) { + bb.options.screen.onBeforeScrollStart(e); + }*/ + }, + onScrollMove: function(e) { + if (screen.onscroll) { + screen.onscroll(e); + } + }}; + // LEAVING THESE HERE INCASE WE NEED TO FALL BACK TO ISCROLL OVERRIDES + /*if (bb.options.screen) { + var excluded = ['onBeforeScrollStart','hideScrollbar','fadeScrollbar']; + for (var i in bb.options.screen) { + if (excluded.indexOf(i) === -1) { + scrollerOptions[i] = bb.options.screen[i]; + } + } + }*/ + bb.scroller = new iScroll(scrollWrapper, scrollerOptions); + } else if (bb.device.isBB10) { + // Use the built in inertial scrolling with elastic ends + bb.scroller = null; + scrollWrapper.style['-webkit-overflow-scrolling'] = '-blackberry-touch'; + scrollWrapper.onscroll = function(e) { + if (screen.onscroll) { + screen.onscroll(e); + } + }; + } + } + }, + + // Clear the scroller objects + clearScrollers: function() { + // first clear our dropdown scrollers + var scroller; + for (var i = bb.dropdownScrollers -1; i > -1; i--) { + scroller = bb.dropdownScrollers[i]; + scroller.destroy(); + scroller = null; + bb.dropdownScrollers.pop(); + } + }, + + // Remove the topmost screen from the dom + removeTopMostScreenFromDom: function() { + var numItems = bb.screens.length, + oldScreen = document.getElementById(bb.screens[numItems -1].guid); + document.body.removeChild(oldScreen); + }, + + // Remove the previous screen from the dom + removePreviousScreenFromDom: function() { + var numItems = bb.screens.length, + oldScreen, + stepBack; + if (numItems == 1) return; // There is only one screen on the stack + stepBack = (numItems > 1) ? 2 : 1; + oldScreen = document.getElementById(bb.screens[numItems - stepBack].guid); + if (oldScreen) { + document.body.removeChild(oldScreen); + } + }, + + // Add a new screen to the stack + pushScreen: function (url, id, params) { + // Remove our old screen + bb.removeLoadedScripts(); + bb.menuBar.clearMenu(); + var numItems = bb.screens.length, + currentScreen; + if (numItems > 0) { + bb.screen.overlay = null; + bb.screen.tabOverlay = null; + bb.clearScrollers(); + // Quirk with displaying with animations + if (bb.device.isBB5 || bb.device.isBB6 || bb.device.isBB7) { + currentScreen = document.getElementById(bb.screens[numItems -1].guid); + currentScreen.style.display = 'none'; + window.scroll(0,0); + } + } + + // Add our screen to the stack + var guid = bb.guidGenerator(), + container = bb.loadScreen(url, id, false, guid, params); + bb.screens.push({'id' : id, 'url' : url, 'scripts' : container.scriptIds, 'container' : container, 'guid': guid, 'params' : params}); + }, + + // Pop a screen from the stack + popScreen: function() { + var numItems = bb.screens.length; + if (numItems > 1) { + bb.removeLoadedScripts(); + bb.clearScrollers(); + bb.menuBar.clearMenu(); + bb.screen.overlay = null; + bb.screen.tabOverlay = null; + + // Retrieve our new screen + var display = bb.screens[numItems-2], + newScreen = bb.loadScreen(display.url, display.id, true, display.guid, display.params, display); + + // Quirky BrowserField2 bug on BBOS + if (bb.device.isBB5 || bb.device.isBB6 || bb.device.isBB7) { + window.scroll(0,0); + } + } else { + if (blackberry) { + blackberry.app.exit(); + } + } + }, + + removeLoadedScripts: function() { + // pop the old item + var numItems = bb.screens.length; + if (numItems > 0) { + var currentStackItem = bb.screens[numItems-1], + current = document.getElementById(currentStackItem.guid); + + // Remove any JavaScript files + for (var i = 0; i < currentStackItem.scripts.length; i++) { + var bbScript = currentStackItem.scripts[i], + scriptTag = document.getElementById(bbScript.id); + + // Call the unload function if any is defined + if (bbScript.onunload) { + eval(bbScript.onunload); + } + if (scriptTag) { + document.body.removeChild(scriptTag); + } + } + } + }, + + innerHeight: function() { + // Orientation is backwards between playbook and BB10 smartphones + if (bb.device.isPlayBook) { + // Hack for ripple + if (!window.orientation) { + return window.innerHeight; + } else if (window.orientation == 0 || window.orientation == 180) { + return 600; + } else if (window.orientation == -90 || window.orientation == 90) { + return 1024; + } + } else { + if (!window.orientation) { + return window.innerHeight; + } else if (window.orientation == 0 || window.orientation == 180) { + return 1280; + } else if (window.orientation == -90 || window.orientation == 90) { + return 768; + } + } + }, + + innerWidth: function() { + // Orientation is backwards between playbook and BB10 smartphones + if (bb.device.isPlayBook) { + // Hack for ripple + if (!window.orientation) { + return window.innerWidth; + } else if (window.orientation == 0 || window.orientation == 180) { + return 1024; + } else if (window.orientation == -90 || window.orientation == 90) { + return 600; + } + } else { + if (!window.orientation) { + return window.innerWidth; + } else if (window.orientation == 0 || window.orientation == 180) { + return 768; + } else if (window.orientation == -90 || window.orientation == 90) { + return 1280; + } + } + }, + + getOrientation: function() { + // Orientation is backwards between playbook and BB10 smartphones + if (bb.device.isPlayBook) { + // Hack for ripple + if (!window.orientation) { + return (window.innerWidth == 1024) ? 'landscape' : 'portrait'; + } else if (window.orientation == 0 || window.orientation == 180) { + return 'landscape'; + } else if (window.orientation == -90 || window.orientation == 90) { + return 'portrait'; + } + } else { + if (!window.orientation) { + return (window.innerWidth == 1280) ? 'landscape' : 'portrait'; + } else if (window.orientation == 0 || window.orientation == 180) { + return 'portrait'; + } else if (window.orientation == -90 || window.orientation == 90) { + return 'landscape'; + } + } + }, + + cutHex : function(h) { + return (h.charAt(0)=="#") ? h.substring(1,7):h + }, + + guidGenerator : function() { + var S4 = function() { + return (((1+Math.random())*0x10000)|0).toString(16).substring(1); + }; + return (S4()+S4()+S4()+S4()+S4()+S4()+S4()+S4()); + }, + + refresh : function() { + if (bb.scroller) { + bb.scroller.refresh(); + } + } +}; + +Function.prototype.bind = function(object){ + var fn = this; + return function(){ + return fn.apply(object, arguments); + }; +}; +// Apply styling to an action bar +bb.actionBar = { + + color: '', + + apply: function(actionBar, screen) { + + var actions = actionBar.querySelectorAll('[data-bb-type=action]'), + visibleButtons = [], + overflowButtons = [], + visibleTabs = [], + overflowTabs = [], + shownActions = [], + action, + target, + caption, + style, + lastStyle, + tabRightShading, + backBtn, + actionContainer = actionBar, + btnWidth, + res = (bb.device.isPlayBook) ? 'lowres' : 'hires', + icon, + color = bb.actionBar.color, + j; + + actionBar.backBtnWidth = 0; + actionBar.actionOverflowBtnWidth = 0; + actionBar.tabOverflowBtnWidth = 0; + actionBar.setAttribute('class','bb-bb10-action-bar-'+res+' bb-bb10-action-bar-' + bb.actionBar.color); + actionBar.visibleTabs = visibleTabs; + actionBar.visibleButtons = visibleButtons; + actionBar.overflowButtons = overflowButtons; + actionBar.shownActions = shownActions; + actionBar.overflowTabs = overflowTabs; + + // Gather our visible and overflow tabs and buttons + for (j = 0; j < actions.length; j++) { + action = actions[j]; + if (action.hasAttribute('data-bb-style')) { + style = action.getAttribute('data-bb-style').toLowerCase(); + if (style == 'button') { + if (action.hasAttribute('data-bb-overflow') && (action.getAttribute('data-bb-overflow').toLowerCase() == 'true')) { + overflowButtons.push(action); + } else { + visibleButtons.push(action); + } + } else { + if (action.hasAttribute('data-bb-overflow') && (action.getAttribute('data-bb-overflow').toLowerCase() == 'true')) { + overflowTabs.push(action); + } else { + visibleTabs.push(action); + } + } + } + } + + // Create the back button if it has one and there are no tabs in the action bar + if (actionBar.hasAttribute('data-bb-back-caption') && actionBar.querySelectorAll('[data-bb-style=tab]').length == 0) { + var chevron, + backCaption, + backslash, + backHighlight; + backBtn = document.createElement('div'); + backBtn.setAttribute('class','bb-bb10-action-bar-back-button-'+res+' bb-bb10-action-bar-back-button-'+res+'-' + color); + backBtn.onclick = bb.popScreen; + actionBar.backBtn = backBtn; + // Create and add the chevron to the back button + chevron = document.createElement('div'); + chevron.setAttribute('class','bb-bb10-action-bar-back-chevron-'+res+'-'+color); + backBtn.appendChild(chevron); + // Create and add our back caption to the back button + backCaption = document.createElement('div'); + backCaption.setAttribute('class','bb-bb10-action-bar-back-text-'+res); + backCaption.innerHTML = actionBar.getAttribute('data-bb-back-caption'); + backBtn.appendChild(backCaption); + // Create our highlight for touch + backHighlight = document.createElement('div'); + backHighlight.setAttribute('class','bb-bb10-action-bar-back-button-highlight'); + backHighlight.style['position'] = 'absolute'; + backHighlight.style['height'] = bb.device.isPlayBook ? '57px' : '110px'; + backHighlight.style['width'] = bb.device.isPlayBook ? '4px' : '8px'; + backHighlight.style['background-color'] = 'transparent'; + backHighlight.style['top'] = bb.device.isPlayBook ? '8px' : '15px'; + backBtn.backHighlight = backHighlight; + backBtn.appendChild(backHighlight); + backBtn.ontouchstart = function() { + this.backHighlight.style['background-color'] = bb.options.highlightColor; + } + backBtn.ontouchend = function() { + this.backHighlight.style['background-color'] = 'transparent'; + } + + // Create our backslash + backslash = document.createElement('div'); + backslash.setAttribute('class','bb-bb10-action-bar-back-slash-'+res+'-'+color); + + // Create a table to hold the back button and our actions + var table = document.createElement('table'), + tr = document.createElement('tr'), + td = document.createElement('td'); + actionBar.appendChild(table); + table.appendChild(tr); + table.setAttribute('class','bb-bb10-action-bar-table'); + // Set Back Button widths + if (bb.device.isPlayBook) { + actionBar.backBtnWidth = 93; + td.style.width = 77+'px'; + } else { + actionBar.backBtnWidth = 187; + td.style.width = 154+'px'; + } + tr.appendChild(td); + td.appendChild(backBtn); + // Create the container for our backslash + td = document.createElement('td'); + // Set backslash widths + td.style.width = bb.device.isPlayBook ? 16 + 'px' : 33+'px'; + backslash.style['background-color'] = bb.options.shades.darkOutline; + tr.appendChild(td); + td.appendChild(backslash); + // Create the container for the rest of the actions + td = document.createElement('td'); + td.style.width = '100%'; + tr.appendChild(td); + actionContainer = td; + // Add the rest of the actions to the second column + for (j = 0; j < actions.length; j++) { + action = actions[j]; + td.appendChild(action); + } + } + + // If we have "tab" actions marked as overflow we need to show the more tab button + if (overflowTabs.length > 0) { + actionBar.tabOverflowBtnWidth = (bb.device.isPlayBook) ? 77: 154; + actionBar.tabOverflowMenu = bb.tabOverflow.create(screen); + actionBar.tabOverflowMenu.actionBar = actionBar; + // Create our action bar overflow button + action = document.createElement('div'); + action.actionBar = actionBar; + action.tabOverflowMenu = actionBar.tabOverflowMenu; + action.setAttribute('data-bb-type','action'); + action.setAttribute('data-bb-style','tab'); + action.setAttribute('data-bb-img','overflow'); + action.onclick = function() { + this.tabOverflowMenu.show(); + } + actionBar.tabOverflowBtn = action; + // Insert our more button + actionContainer.insertBefore(action, actionContainer.firstChild); + visibleTabs.push(action); + } + + // If we have "button" actions marked as overflow we need to show the more menu button + if (overflowButtons.length > 0) { + actionBar.actionOverflowBtnWidth = (bb.device.isPlayBook) ? 77: 154; + actionBar.menu = bb.contextMenu.create(screen); + actionBar.appendChild(actionBar.menu); + // Create our action bar overflow button + action = document.createElement('div'); + action.menu = actionBar.menu; + actionBar.moreBtn = action; + action.setAttribute('data-bb-type','action'); + action.setAttribute('data-bb-style','button'); + action.setAttribute('data-bb-img','overflow'); + action.onclick = function() { + this.menu.show(); + } + // Insert our action overflow button + actionContainer.appendChild(action); + visibleButtons.push(action); + } + + // Determines how much width there is to use not including built in system buttons on the bar + actionBar.getUsableWidth = function() { + return bb.innerWidth() - this.backBtnWidth - this.actionOverflowBtnWidth - this.tabOverflowBtnWidth; + } + actionBar.getUsableWidth = actionBar.getUsableWidth.bind(actionBar); + + // Create our function to calculate the widths of the inner action items + actionBar.calculateActionWidths = function() { + var result, + numUserActions, + numSystemActions = 0, + totalWidth = this.getUsableWidth(), + visibleActions = this.visibleButtons.length + this.visibleTabs.length; + + // Get our non system actions + numUserActions = (this.moreBtn) ? visibleActions - 1 : visibleActions; // Remove the more button from the equation + numUserActions = (this.tabOverflowBtn) ? numUserActions - 1 : numUserActions; // Remove the tab overflow button from the equation + + // Count our visible system actions + numSystemActions = (this.moreBtn) ? numSystemActions + 1 : numSystemActions; + numSystemActions = (this.tabOverflowBtn) ? numSystemActions + 1 : numSystemActions; + numSystemActions = (this.backBtn) ? numSystemActions + 1 : numSystemActions; + + if ((numSystemActions + numUserActions) < 5) { + result = Math.floor(totalWidth/numUserActions); + } else { + result = Math.floor(totalWidth/(5-numSystemActions)); + } + + return result; + }; + actionBar.calculateActionWidths = actionBar.calculateActionWidths.bind(actionBar); + // Get our button width + btnWidth = actionBar.calculateActionWidths(); + + // Make sure we move when the orientation of the device changes + actionBar.orientationChanged = function(event) { + var actionWidth = actionBar.calculateActionWidths(), + i, + action, + actionType, + length = this.shownActions.length, + margins = 2; + + for (i = 0; i < length; i++) { + action = this.shownActions[i]; + actionType = (action.hasAttribute('data-bb-style')) ? action.getAttribute('data-bb-style').toLowerCase() : 'button'; + // Compute margins + margins = (actionType == 'tab') ? 2 : 0; + action.style.width = (actionWidth - margins) + 'px'; + if (action.highlight && (actionType != 'tab') && (action.getAttribute('data-bb-img') != 'overflow')) { + action.highlight.style['width'] = (actionWidth * 0.6) + 'px'; + action.highlight.style['margin-left'] = (actionWidth * 0.2) + 'px'; + } + } + + // Adjust our more button + if (this.moreBtn && (this.shownActions.length > 0)) { + if (actionType == 'tab') { + // Stretch the last button if all tabs are before the overflow button + this.moreBtn.style.width = (bb.innerWidth() - (this.shownActions.length * actionWidth)) + 'px'; + } else { + this.moreBtn.style.width = this.actionOverflowBtnWidth + 'px'; + } + } + }; + actionBar.orientationChanged = actionBar.orientationChanged.bind(actionBar); + window.addEventListener('orientationchange', actionBar.orientationChanged,false); + + // Add setBackCaption function + actionBar.setBackCaption = function(value) { + this.setAttribute('data-bb-back-caption',value); + backCaption.innerHTML = value; + }; + actionBar.setBackCaption = actionBar.setBackCaption.bind(actionBar); + + // Add setSelectedTab function + actionBar.setSelectedTab = function(tab) { + if (tab.getAttribute('data-bb-style') != 'tab') return; + bb.actionBar.highlightAction(tab); + if (tab.onclick) { + tab.onclick(); + } + }; + actionBar.setSelectedTab = actionBar.setSelectedTab.bind(actionBar); + + // Add all our overflow tab actions + if (overflowTabs.length > 0 ) { + var clone; + // Add all our visible tabs if any so they are at the top of the list + for (j = 0; j < visibleTabs.length; j++) { + action = visibleTabs[j]; + // Don't add the visible overflow tab + if (action.getAttribute('data-bb-img') != 'overflow') { + clone = action.cloneNode(true); + clone.visibleTab = action; + clone.res = res; + clone.actionBar = actionBar; + actionBar.tabOverflowMenu.add(clone); + } + } + // Now add all our tabs marked as overflow + for (j = 0; j < overflowTabs.length; j++) { + action = overflowTabs[j]; + action.res = res; + action.actionBar = actionBar; + actionBar.tabOverflowMenu.add(action); + } + } + + // Add all of our overflow button actions + for (j = 0; j < overflowButtons.length; j++) { + action = overflowButtons[j]; + action.res = res; + actionBar.menu.add(action); + } + + // Apply all our tab styling + var tabMargins = 2, + numVisibleTabs = visibleTabs.length, + display; + for (j = 0; j < numVisibleTabs; j++) { + action = visibleTabs[j]; + // Don't add any more than 5 items on the action bar + if (j > 4) { + action.style.display = 'none'; + continue; + } + action.res = res; + caption = action.innerHTML; + // Size our last visible tab differently + if ((j == visibleTabs.length -1) && (j == 4)) { + // Stretch the last tab if actionbar only has tabs in case of any kind of rounding errors based on division + action.style.width = (actionBar.getUsableWidth() - (4 * btnWidth) - tabMargins) + 'px'; + } else { + action.style.width = (btnWidth - tabMargins) + 'px'; + } + action.actionBar = actionBar; + action.innerHTML = ''; + action.normal = 'bb-bb10-action-bar-action-'+res+' bb-bb10-action-bar-tab-'+color+' bb-bb10-action-bar-tab-normal-'+color; + action.highlight = action.normal + ' bb-bb10-action-bar-tab-selected-'+color; + action.setAttribute('class',action.normal); + + // Add the icon + icon = document.createElement('img'); + icon.setAttribute('class','bb-bb10-action-bar-icon-'+res); + action.appendChild(icon); + // Set our caption + display = document.createElement('div'); + display.setAttribute('class','bb-bb10-action-bar-action-display-'+res); + display.innerHTML = caption; + action.display = display; + action.appendChild(display); + + // See if it is our overflow tab + if (action.getAttribute('data-bb-img') == 'overflow') { + action.style.width = actionBar.tabOverflowBtnWidth + 'px'; + action.icon = icon; + display.innerHTML = ' '; + action.display = display; + // Set our transparent pixel + icon.setAttribute('src',bb.transparentPixel); + icon.normal = 'bb-bb10-action-bar-icon-'+res+' bb-bb10-action-bar-tab-overflow-'+res+'-'+color; + icon.highlight = 'bb-bb10-action-bar-icon-'+res; + icon.setAttribute('class',icon.normal); + // Crete our tab highlight div + action.tabHighlight = document.createElement('div'); + action.tabHighlight.setAttribute('class','bb-bb10-action-bar-tab-overflow-'+res+'-'+color+' bb-bb10-action-bar-tab-overflow-highlight-'+res); + action.appendChild(action.tabHighlight); + action.style.width = (actionBar.tabOverflowBtnWidth - 1) + 'px'; + // Set our reset function + action.reset = function() { + this.icon.setAttribute('src',bb.transparentPixel); + this.icon.setAttribute('class',this.icon.normal); + this.tabHighlight.style.display = 'none'; + this.display.innerHTML = ' '; + }; + action.reset = action.reset.bind(action); + } // See if it was a selected tab + else { + shownActions.push(action); + // Set our image + icon.setAttribute('src',action.getAttribute('data-bb-img')); + action.icon = icon; + + if (action.hasAttribute('data-bb-selected') && (action.getAttribute('data-bb-selected').toLowerCase() == 'true')) { + bb.actionBar.highlightAction(action); + } + // Add our click listener + action.addEventListener('click',function (e) { + bb.actionBar.highlightAction(this); + },false); + + // Assign the setCaption function + action.setCaption = function(value) { + this.display.innerHTML = value; + // Change the associated overflow item if one exists + if (this.actionBar.tabOverflowMenu) { + var tabs = this.actionBar.tabOverflowMenu.actions, + i, + target; + for (i = 0; i < tabs.length; i++) { + target = tabs[i]; + if (target.visibleTab == this) { + target.setCaption(value); + } + } + } + }; + action.setCaption = action.setCaption.bind(action); + + // Assign the getCaption function + action.getCaption = function() { + return this.display.innerHTML; + }; + action.getCaption = action.getCaption.bind(action); + + // Assign the setImage function + action.setImage = function(value) { + this.icon.setAttribute('src', value); + + // Change the associated overflow item if one exists + if (this.actionBar.tabOverflowMenu) { + var tabs = this.actionBar.tabOverflowMenu.actions, + i, + target; + for (i = 0; i < tabs.length; i++) { + target = tabs[i]; + if (target.visibleTab == this) { + target.setImage(value); + } + } + } + }; + action.setImage = action.setImage.bind(action); + + // Assign the getImage function + action.getImage = function() { + return this.icon.getAttribute('src'); + }; + action.getImage = action.getImage.bind(action); + } + + // Make the last tab have a smaller border and insert the shading + if ((j == visibleTabs.length-1) && (j < 4)) { + action.style['border-right-width'] = '1px'; + } + } + + // Apply all our button styling + lastStyle = (visibleTabs.length > 0) ? 'tab' : 'button'; + var actionWidth; + for (j = 0; j < visibleButtons.length; j++) { + actionWidth = btnWidth; + action = visibleButtons[j]; + action.res = res; + caption = action.innerHTML; + // Don't add any more than 5 items on the action bar + if ((((numVisibleTabs + j) > 4)) || (actionBar.backBtn && (j > 3))) { + action.style.display = 'none'; + continue; + } + + // Add the icon + icon = document.createElement('img'); + if (action.getAttribute('data-bb-img') == 'overflow') { + // Set our transparent pixel + icon.setAttribute('src',bb.transparentPixel); + icon.setAttribute('class','bb-bb10-action-bar-icon-'+res+' bb-bb10-action-bar-overflow-button-'+res+'-'+color); + // Stretch to the last tab as long as the only tab isn't the tab overflow + var stretchToTab = false; + if ((lastStyle == 'tab') && actionBar.tabOverflowMenu && (visibleTabs.length == 1) && (visibleButtons.length == 1)) { + stretchToTab = false; + } else if (lastStyle == 'tab') { + stretchToTab = true; + } + // If it is next to a tab, stretch it so that the right shading lines up + if (stretchToTab) { + // Stretch the last button if all tabs are before the overflow button + actionWidth = (actionBar.tabOverflowMenu) ? (bb.innerWidth() - ((numVisibleTabs-1) * btnWidth) - actionBar.tabOverflowBtnWidth) : (bb.innerWidth() - (numVisibleTabs * btnWidth) - actionBar.tabOverflowBtnWidth); + action.style.width = actionWidth + 'px'; + action.normal = 'bb-bb10-action-bar-action-'+res+' bb-bb10-action-bar-button-'+color+' bb-bb10-action-bar-button-tab-left-'+res+'-'+color; + } else { + actionWidth = (actionBar.actionOverflowBtnWidth - 1); + action.style.width = actionWidth + 'px'; + action.style.float = 'right'; + action.normal = 'bb-bb10-action-bar-action-'+res+' bb-bb10-action-bar-button-'+color; + } + } else { + shownActions.push(action); + icon.setAttribute('src',action.getAttribute('data-bb-img')); + icon.setAttribute('class','bb-bb10-action-bar-icon-'+res); + action.icon = icon; + action.style.width = btnWidth + 'px'; + + // set our shading if needed + if (lastStyle == 'tab') { + action.normal = 'bb-bb10-action-bar-action-'+res+' bb-bb10-action-bar-button-'+color+' bb-bb10-action-bar-button-tab-left-'+res+'-'+color; + } else { + action.normal = 'bb-bb10-action-bar-action-'+res+' bb-bb10-action-bar-button-'+color; + } + + // Assign the setCaption function + action.setCaption = function(value) { + this.display.innerHTML = value; + }; + action.setCaption = action.setCaption.bind(action); + + // Assign the getCaption function + action.getCaption = function() { + return this.display.innerHTML; + }; + action.getCaption = action.getCaption.bind(action); + + // Assign the setImage function + action.setImage = function(value) { + this.icon.setAttribute('src',value); + }; + action.setImage = action.setImage.bind(action); + + // Assign the setImage function + action.getImage = function() { + return this.icon.getAttribute('src'); + }; + action.getImage = action.getImage.bind(action); + } + + // Default settings + action.innerHTML = ''; + action.setAttribute('class',action.normal); + action.appendChild(icon); + lastStyle = 'button'; + + // Set our caption + var display = document.createElement('div'); + display.setAttribute('class','bb-bb10-action-bar-action-display-'+res); + display.innerHTML = caption; + action.display = display; + action.appendChild(display); + + // Set our highlight + action.highlight = document.createElement('div'); + action.highlight.setAttribute('class','bb-bb10-action-bar-action-highlight'); + action.highlight.style['height'] = bb.device.isPlayBook ? '4px' : '8px'; + action.highlight.style['width'] = (actionWidth * 0.6) + 'px'; + action.highlight.style['margin-left'] = (actionWidth * 0.2) + 'px'; + action.highlight.style['background-color'] = 'transparent'; + action.appendChild(action.highlight); + + // Highlight on touch + action.ontouchstart = function() { + this.highlight.style['background-color'] = bb.options.highlightColor; + } + // Remove highlight when touch ends + action.ontouchend = function() { + this.highlight.style['background-color'] = 'transparent'; + } + } + // Center the action overflow items + if (actionBar.menu) { + actionBar.menu.centerMenuItems(); + } + // Initialize the Tab Overflow + if (actionBar.tabOverflowMenu) { + actionBar.tabOverflowMenu.centerMenuItems(); + actionBar.tabOverflowMenu.initSelected(); + } + }, + + // Apply the proper highlighting for the action + highlightAction: function (action, overflowAction) { + var i, + target, + tabs = action.actionBar.visibleTabs; + + // First un-highlight the rest + for (i = 0; i < tabs.length; i++) { + target = tabs[i]; + if (target != action) { + bb.actionBar.unhighlightAction(target); + } + } + // Un-highlight the overflow menu items + if (action.actionBar.tabOverlowMenu) { + tabs = action.actionBar.tabOverflowMenu.actions; + for (i = 0; i < tabs.length; i++) { + target = tabs[i]; + if (target != overflowAction) { + bb.actionBar.unhighlightAction(target); + } + } + } + + // Now highlight this action + action.style['border-top-color'] = bb.options.highlightColor; + action.setAttribute('class',action.highlight); + + if (overflowAction) { + overflowAction.setAttribute('class', overflowAction.normal + ' bb10Highlight'); + } + + // See if there was a tab overflow + if (action.actionBar.tabOverflowMenu && !overflowAction) { + if (action.actionBar.tabOverflowBtn && (action == action.actionBar.tabOverflowBtn)) { + overflowAction.setAttribute('class', overflowAction.normal + ' bb10Highlight'); + } else { + tabs = action.actionBar.tabOverflowMenu.actions; + for (i = 0; i < tabs.length; i++) { + target = tabs[i]; + if (target.visibleTab == action) { + target.setAttribute('class', target.normal + ' bb10Highlight'); + } + } + } + } + + // Reset the tab overflow + if (action.actionBar.tabOverflowBtn && action.actionBar.tabOverflowBtn.reset) { + action.actionBar.tabOverflowBtn.reset(); + } + }, + + // Apply the proper styling for an action that is no longer highlighted + unhighlightAction: function(action) { + var target; + action.style['border-top-color'] = ''; + action.setAttribute('class',action.normal); + // See if there was a tab overflow + if (action.actionBar && action.actionBar.tabOverflowMenu) { + tabs = action.actionBar.tabOverflowMenu.actions; + for (i = 0; i < tabs.length; i++) { + target = tabs[i]; + target.setAttribute('class', target.normal); + } + } + } +}; +_bb_bbmBubble = { + // Apply our transforms to all BBM Bubbles + apply: function(elements) { + for (var i = 0; i < elements.length; i++) { + var outerElement = elements[i]; + + if (outerElement.hasAttribute('data-bb-style')) { + var style = outerElement.getAttribute('data-bb-style').toLowerCase(); + if (style == 'left') + outerElement.setAttribute('class','bb-bbm-bubble-left'); + else + outerElement.setAttribute('class','bb-bbm-bubble-right'); + + var innerElements = outerElement.querySelectorAll('[data-bb-type=item]'); + for (var j = 0; j > innerElements.length; j++) { + outerElement.removeChild(innerElements[j]); + } + + // Create our new
's + var placeholder = document.createElement('div'); + placeholder.setAttribute('class','top-left image'); + outerElement.appendChild(placeholder); + placeholder = document.createElement('div'); + placeholder.setAttribute('class','top-right image'); + outerElement.appendChild(placeholder); + + placeholder = document.createElement('div'); + placeholder.setAttribute('class','inside'); + outerElement.appendChild(placeholder); + + var insidePanel = document.createElement('div'); + insidePanel.setAttribute('class','nogap'); + placeholder.appendChild(insidePanel); + + placeholder = document.createElement('div'); + placeholder.setAttribute('class','bottom-left image'); + outerElement.appendChild(placeholder); + placeholder = document.createElement('div'); + placeholder.setAttribute('class','bottom-right image'); + outerElement.appendChild(placeholder); + // Add our previous children back to the insidePanel + for (var j = 0; j < innerElements.length; j++) { + var innerChildNode = innerElements[j], + description = innerChildNode.innerHTML; + innerChildNode.innerHTML = '\n' + + '
'+ description +'
\n'; + insidePanel.appendChild(innerChildNode); + } + + } + + // Add our get Style function + outerElement.getStyle = function() { + return this.getAttribute('data-bb-style'); + }; + outerElement.getStyle = outerElement.getStyle.bind(outerElement); + + // Add setStyle function (left or right) + outerElement.setStyle = function(value) { + if (value == 'left'){ + this.setAttribute('data-bb-style', value); + this.setAttribute('class','bb-bbm-bubble-left'); + } + else if (value == 'right'){ + this.setAttribute('data-bb-style', value); + this.setAttribute('class','bb-bbm-bubble-right'); + } + bb.refresh(); + }; + outerElement.setStyle = outerElement.setStyle.bind(outerElement); + + // Add show function + outerElement.show = function() { + this.style.display = 'block'; + bb.refresh(); + }; + outerElement.show = outerElement.show.bind(outerElement); + + // Add hide function + outerElement.hide = function() { + this.style.display = 'none'; + bb.refresh(); + }; + outerElement.hide = outerElement.hide.bind(outerElement); + + // Add remove function + outerElement.remove = function() { + this.parentNode.removeChild(this); + bb.refresh(); + }; + outerElement.remove = outerElement.remove.bind(outerElement); + } + } +}; +// BlackBerry 10 Context Menu +bb.contextMenu = { + + // Create an instance of the menu and pass it back to the caller + create : function(screen) { + var res, + swipeThreshold; + if (bb.device.isPlayBook) { + res = 'lowres'; + swipeThreshold = 100; + } else { + res = 'hires'; + swipeThreshold = 300; + } + + // Create the oveflow menu container + var menu = document.createElement('div'), + title = document.createElement('div'), + description = document.createElement('div'), + header; + menu.setAttribute('class','bb-bb10-context-menu bb-bb10-context-menu-' + res + '-' + bb.actionBar.color); + + menu.actions = []; + menu.hideEvents = []; + menu.res = res; + menu.threshold = swipeThreshold; + menu.visible = false; + + // Create our overlay for touch events + menu.overlay = document.createElement('div'); + menu.overlay.threshold = swipeThreshold; + menu.overlay.setAttribute('class','bb-bb10-context-menu-overlay'); + menu.overlay.menu = menu; + screen.appendChild(menu.overlay); + + menu.overlay.ontouchmove = function(event) { + // Only care about moves if peeking + if (!this.menu.peeking) return; + var touch = event.touches[0]; + if (this.startPos && (this.startPos - touch.pageX > this.threshold)) { + this.menu.show(this.menu.selected); + this.closeMenu = false; + } + }; + menu.overlay.ontouchend = function() { + if (this.closeMenu) { + this.menu.hide(); + } + }; + menu.overlay.ontouchstart = function(event) { + this.closeMenu = true; + if (!this.menu.peeking) return; + + var touch = event.touches[0]; + this.startPos = touch.pageX; + event.preventDefault(); + }; + + // Create the menu header + header = document.createElement('div'); + header.setAttribute('class','bb-bb10-context-menu-item-'+res+' bb-bb10-context-menu-header-'+bb.actionBar.color); + menu.header = header; + menu.appendChild(header); + + // Create our title container + title.setAttribute('class','bb-bb10-context-menu-header-title-'+res+' bb-bb10-context-menu-header-title-'+bb.actionBar.color); + title.style.width = bb.contextMenu.getWidth() - 20 + 'px'; + menu.topTitle = title; + header.appendChild(title); + + // Create our description container + description.setAttribute('class','bb-bb10-context-menu-header-description-'+res); + description.style.width = bb.contextMenu.getWidth() - 20 + 'px'; + menu.description = description; + header.appendChild(description); + + // Create our scrolling container + menu.scrollContainer = document.createElement('div'); + menu.scrollContainer.setAttribute('class', 'bb-bb10-context-menu-scroller'); + menu.appendChild(menu.scrollContainer); + + // Set our first left position + menu.style.left = bb.contextMenu.getLeft(); + + // Display the menu + menu.show = function(data){ + if (data) { + this.header.style.display = ''; + this.header.style.visibility = ''; + if (data.title) { + this.topTitle.innerHTML = data.title; + } + if (data.description) { + this.description.innerHTML = data.description; + } + this.selected = data; + // Adjust our scroll container top + menu.scrollContainer.style.top = (bb.device.isPlayBook) ? '64px' : '130px'; + } else { + this.header.style.display = 'none'; + this.selected = undefined; + // Adjust our scroll container top + menu.scrollContainer.style.top = '0px'; + } + // Set our scroller + menu.scrollContainer.style['overflow-y'] = 'scroll'; + menu.scrollContainer.style['overflow-x'] = 'hidden' + menu.scrollContainer.style['-webkit-overflow-scrolling'] = '-blackberry-touch'; + + this.peeking = false; + this.overlay.style.display = 'inline'; + this.style['-webkit-transition'] = 'all 0.3s ease-in-out'; + this.style['-webkit-transform'] = 'translate(-' + bb.contextMenu.getWidth() + 'px, 0)'; + this.style['-webkit-backface-visibility'] = 'hidden'; + this.style['-webkit-perspective'] = '1000'; + this.addEventListener("touchstart", this.touchHandler, false); + this.onclick = function() { this.hide();} + // Remove the header click handling while peeking + this.header.addEventListener("click", this.hide, false); + this.style.visibility = 'visible'; + this.visible = true; + }; + menu.show = menu.show.bind(menu); + // Hide the menu + menu.hide = function(){ + + this.overlay.style.display = 'none'; + this.removeEventListener("touchstart", this.touchHandler, false); + this.removeEventListener("touchmove", this.touchMoveHandler, false); + this.style['-webkit-transition'] = 'all 0.5s ease-in-out'; + this.style['-webkit-transform'] = 'translate(' + bb.contextMenu.getWidth() + 'px, 0px)'; + this.style['-webkit-backface-visibility'] = 'hidden'; + this.style['-webkit-perspective'] = '1000'; + if (!this.peeking) { + // Remove the header click handling + this.header.removeEventListener("click", this.hide, false); + } + this.peeking = false; + this.visible = false; + + // Remove our scroller + menu.scrollContainer.style['overflow-y'] = ''; + menu.scrollContainer.style['overflow-x'] = '' + menu.scrollContainer.style['-webkit-overflow-scrolling'] = ''; + + // See if there was anyone listenting for hide events and call them + // starting from the last one registered and pop them off + for (var i = menu.hideEvents.length-1; i >= 0; i--) { + menu.hideEvents[i](); + menu.hideEvents.pop(); + } + + // Hack because PlayBook doesn't seem to get all the touch end events + if (bb.device.isPlayBook) { + for (var i = 0; i < this.actions.length; i++) { + this.actions[i].ontouchend(); + } + } + }; + menu.hide = menu.hide.bind(menu); + // Peek the menu + menu.peek = function(data){ + if (data) { + this.header.style.display = ''; + if (data.title) { + this.topTitle.innerHTML = data.title; + } + if (data.description) { + this.description.innerHTML = data.description; + } + this.selected = data; + // Adjust our scroller top + menu.scrollContainer.style.top = (bb.device.isPlayBook) ? '64px' : '130px'; + } else { + // Adjust our scroller top + menu.scrollContainer.style.top = '0px'; + } + + this.header.style.visibility = 'hidden'; + this.header.style['margin-bottom'] = '-'+ Math.floor(this.header.offsetHeight/2) + 'px'; + this.peeking = true; + this.overlay.style.display = 'inline'; + this.style['-webkit-transition'] = 'all 0.3s ease-in-out'; + this.style['-webkit-transform'] = 'translate(-' + bb.contextMenu.getPeekWidth() + ', 0)'; + this.style['-webkit-backface-visibility'] = 'hidden'; + this.style['-webkit-perspective'] = '1000'; + this.addEventListener("touchstart", this.touchHandler, false); + this.addEventListener("touchmove", this.touchMoveHandler, false); + this.onclick = function() {this.show()}; + // Remove the header click handling while peeking + this.header.removeEventListener("click", this.hide, false); + this.style.visibility = 'visible'; + this.visible = true; + }; + menu.peek = menu.peek.bind(menu); + + // Trap touch start events in a way that we can add and remove the handler + menu.touchHandler = function(event) { + if (this.peeking) { + var touch = event.touches[0]; + this.startPos = touch.pageX; + if (event.target == this.scrollContainer) { + //event.stopPropagation(); + } else if (event.target.parentNode == this.scrollContainer && event.target != this.header) { + event.preventDefault(); + event.stopPropagation(); + } + } + }; + menu.touchHandler = menu.touchHandler.bind(menu); + + // Trap touch move events in a way that we can add and remove the handler + menu.touchMoveHandler = function(event) { + // Only care about moves if peeking + if (!this.peeking) return; + var touch = event.touches[0]; + if (this.startPos && (this.startPos - touch.pageX > this.threshold)) { + this.show(this.selected); + } + }; + menu.touchMoveHandler = menu.touchMoveHandler.bind(menu); + + // Handle the case of clicking the context menu while peeking + menu.onclick = function(event) { + if (this.peeking) { + this.show(this.selected); + event.stopPropagation(); + } + } + + // Center the items in the list + menu.centerMenuItems = function() { + var windowHeight = bb.innerHeight(), + itemHeight = (bb.device.isPlayBook) ? 53 : 111, + margin, + numActions; + // See how many actions to use for calculations + numActions = (this.pinnedAction) ? this.actions.length - 1 : this.actions.length; + margin = windowHeight - Math.floor(windowHeight/2) - Math.floor((numActions * itemHeight)/2) - itemHeight; //itemHeight is the header + if (margin < 0) margin = 0; + this.actions[0].style['margin-top'] = margin + 'px'; + }; + menu.centerMenuItems = menu.centerMenuItems.bind(menu); + + + // Make sure we move when the orientation of the device changes + menu.orientationChanged = function(event) { + this.style['-webkit-transition'] = ''; + this.style.left = bb.innerWidth() + 'px'; + this.style.height = bb.innerHeight() + 'px'; + this.centerMenuItems(); + }; + menu.orientationChanged = menu.orientationChanged.bind(menu); + window.addEventListener('orientationchange', menu.orientationChanged,false); + + // Listen for when the animation ends so that we can make it invisible to avoid orientation change artifacts + menu.addEventListener('webkitTransitionEnd', function() { + if (!this.visible) { + this.style.visibility = 'hidden'; + } + }); + + // Create our add item function + menu.add = function(action) { + var normal, + highlight, + caption = action.innerHTML, + pin = false; + + // set our styling + normal = 'bb-bb10-context-menu-item-'+this.res+' bb-bb10-context-menu-item-'+this.res+'-' + bb.actionBar.color; + //this.appendChild(action); + + this.actions.push(action); + // See if this item should be pinned to the bottom + pin = (action.hasAttribute('data-bb-pin') && action.getAttribute('data-bb-pin').toLowerCase() == 'true'); + if (pin && !this.pinnedAction) { + normal = normal + ' bb-bb10-context-menu-item-first-' + this.res + '-' + bb.actionBar.color; + action.style['bottom'] = '-2px'; + action.style.position = 'absolute'; + action.style.width = '100%'; + this.pinnedAction = action; + this.appendChild(action); + this.scrollContainer.style.bottom = (bb.device.isPlayBook) ? '64px' : '130px'; + } else { + this.scrollContainer.appendChild(action); + } + // If it is the top item it needs a top border + if (this.actions.length == 1) { + normal = normal + ' bb-bb10-context-menu-item-first-' + this.res + '-' + bb.actionBar.color; + } + highlight = normal + ' bb-bb10-context-menu-item-hover-'+this.res; + action.normal = normal; + action.highlight = highlight; + // Set our inner information + action.innerHTML = ''; + var inner = document.createElement('div'), + img = document.createElement('img'); + img.setAttribute('src', action.getAttribute('data-bb-img')); + img.setAttribute('class','bb-bb10-context-menu-item-image-'+this.res); + action.img = img; + action.appendChild(img); + inner.setAttribute('class','bb-bb10-context-menu-item-inner-'+this.res); + action.appendChild(inner); + inner.innerHTML = caption; + action.display = inner; + action.menu = this; + + action.setAttribute('class',normal); + action.ontouchstart = function () { + if (this.menu.peeking) { + this.style['border-left-color'] = bb.options.highlightColor; + } else { + this.style['background-color'] = bb.options.highlightColor; + } + + // Hack because PlayBook doesn't seem to get all the touch end events + if (bb.device.isPlayBook) { + var existingAction, + i; + for (i = 0; i < this.menu.actions.length; i++) { + existingAction = this.menu.actions[i]; + if (existingAction != this) { + existingAction.ontouchend(); + } + } + } + } + action.ontouchend = function () { + if (this.menu.peeking) { + this.style['border-left-color'] = 'transparent'; + } else { + this.style['background-color'] = ''; + } + } + action.addEventListener("click", this.hide, false); + + // Assign the setCaption function + action.setCaption = function(value) { + this.display.innerHTML = value; + }; + action.setCaption = action.setCaption.bind(action); + + // Assign the setImage function + action.setImage = function(value) { + this.img.setAttribute('src',value); + }; + action.setImage = action.setImage.bind(action); + }; + menu.add = menu.add.bind(menu); + return menu; + }, + + // Calculate the proper width of the context menu + getWidth : function() { + if (bb.device.isPlayBook) { + return '300'; + } else { + return '563'; + } + }, + + // Calculate the proper width of the context menu when peeking + getPeekWidth : function() { + if (bb.device.isPlayBook) { + return '55px'; + } else { + return '121px'; + } + }, + + // Calculate the proper left of the context menu + getLeft : function() { + return window.innerWidth + 3 + 'px'; + } +}; + +/*! + * iScroll v4.1.9 ~ Copyright (c) 2011 Matteo Spinelli, http://cubiq.org + * Released under MIT license, http://cubiq.org/license + */ +(function(){ +var m = Math, + mround = function (r) { return r >> 0; }, + vendor = (/webkit/i).test(navigator.appVersion) ? 'webkit' : + (/firefox/i).test(navigator.userAgent) ? 'Moz' : + (/trident/i).test(navigator.userAgent) ? 'ms' : + 'opera' in window ? 'O' : '', + + // Browser capabilities + isAndroid = (/android/gi).test(navigator.appVersion), + isIDevice = (/iphone|ipad/gi).test(navigator.appVersion), + isPlaybook = (/playbook/gi).test(navigator.appVersion), + isTouchPad = (/hp-tablet/gi).test(navigator.appVersion), + + has3d = 'WebKitCSSMatrix' in window && 'm11' in new WebKitCSSMatrix(), + hasTouch = 'ontouchstart' in window && !isTouchPad, + hasTransform = vendor + 'Transform' in document.documentElement.style, + hasTransitionEnd = isIDevice || isPlaybook, + + nextFrame = (function() { + return window.requestAnimationFrame + || window.webkitRequestAnimationFrame + || window.mozRequestAnimationFrame + || window.oRequestAnimationFrame + || window.msRequestAnimationFrame + || function(callback) { return setTimeout(callback, 1); } + })(), + cancelFrame = (function () { + return window.cancelRequestAnimationFrame + || window.webkitCancelAnimationFrame + || window.webkitCancelRequestAnimationFrame + || window.mozCancelRequestAnimationFrame + || window.oCancelRequestAnimationFrame + || window.msCancelRequestAnimationFrame + || clearTimeout + })(), + + // Events + RESIZE_EV = 'onorientationchange' in window ? 'orientationchange' : 'resize', + START_EV = hasTouch ? 'touchstart' : 'mousedown', + MOVE_EV = hasTouch ? 'touchmove' : 'mousemove', + END_EV = hasTouch ? 'touchend' : 'mouseup', + CANCEL_EV = hasTouch ? 'touchcancel' : 'mouseup', + WHEEL_EV = vendor == 'Moz' ? 'DOMMouseScroll' : 'mousewheel', + + // Helpers + trnOpen = 'translate' + (has3d ? '3d(' : '('), + trnClose = has3d ? ',0)' : ')', + + // Constructor + iScroll = function (el, options) { + var that = this, + doc = document, + i; + + that.wrapper = typeof el == 'object' ? el : doc.getElementById(el); + that.wrapper.style.overflow = 'hidden'; + that.scroller = that.wrapper.children[0]; + + // Default options + that.options = { + hScroll: true, + vScroll: true, + x: 0, + y: 0, + bounce: true, + bounceLock: false, + momentum: true, + lockDirection: true, + useTransform: true, + useTransition: false, + topOffset: 0, + checkDOMChanges: false, // Experimental + + // Scrollbar + hScrollbar: true, + vScrollbar: true, + fixedScrollbar: isAndroid, + hideScrollbar: isIDevice, + fadeScrollbar: isIDevice && has3d, + scrollbarClass: '', + + // Zoom + zoom: false, + zoomMin: 1, + zoomMax: 4, + doubleTapZoom: 2, + wheelAction: 'scroll', + + // Snap + snap: false, + snapThreshold: 1, + + // Events + onRefresh: null, + onBeforeScrollStart: function (e) { e.preventDefault(); }, + onScrollStart: null, + onBeforeScrollMove: null, + onScrollMove: null, + onBeforeScrollEnd: null, + onScrollEnd: null, + onTouchEnd: null, + onDestroy: null, + onZoomStart: null, + onZoom: null, + onZoomEnd: null + }; + + // User defined options + for (i in options) that.options[i] = options[i]; + + // Set starting position + that.x = that.options.x; + that.y = that.options.y; + + // Normalize options + that.options.useTransform = hasTransform ? that.options.useTransform : false; + that.options.hScrollbar = that.options.hScroll && that.options.hScrollbar; + that.options.vScrollbar = that.options.vScroll && that.options.vScrollbar; + that.options.zoom = that.options.useTransform && that.options.zoom; + that.options.useTransition = hasTransitionEnd && that.options.useTransition; + + // Helpers FIX ANDROID BUG! + // translate3d and scale doesn't work together! + // Ignoring 3d ONLY WHEN YOU SET that.options.zoom + if ( that.options.zoom && isAndroid ){ + trnOpen = 'translate('; + trnClose = ')'; + } + + // Set some default styles + that.scroller.style[vendor + 'TransitionProperty'] = that.options.useTransform ? '-' + vendor.toLowerCase() + '-transform' : 'top left'; + that.scroller.style[vendor + 'TransitionDuration'] = '0'; + that.scroller.style[vendor + 'TransformOrigin'] = '0 0'; + if (that.options.useTransition) that.scroller.style[vendor + 'TransitionTimingFunction'] = 'cubic-bezier(0.33,0.66,0.66,1)'; + + if (that.options.useTransform) that.scroller.style[vendor + 'Transform'] = trnOpen + that.x + 'px,' + that.y + 'px' + trnClose; + else that.scroller.style.cssText += ';position:absolute;top:' + that.y + 'px;left:' + that.x + 'px'; + + if (that.options.useTransition) that.options.fixedScrollbar = true; + + that.refresh(); + + that._bind(RESIZE_EV, window); + that._bind(START_EV); + if (!hasTouch) { + that._bind('mouseout', that.wrapper); + if (that.options.wheelAction != 'none') + that._bind(WHEEL_EV); + } + + if (that.options.checkDOMChanges) that.checkDOMTime = setInterval(function () { + that._checkDOMChanges(); + }, 500); + }; + +// Prototype +iScroll.prototype = { + enabled: true, + x: 0, + y: 0, + steps: [], + scale: 1, + currPageX: 0, currPageY: 0, + pagesX: [], pagesY: [], + aniTime: null, + wheelZoomCount: 0, + + handleEvent: function (e) { + var that = this; + switch(e.type) { + case START_EV: + if (!hasTouch && e.button !== 0) return; + that._start(e); + break; + case MOVE_EV: that._move(e); break; + case END_EV: + case CANCEL_EV: that._end(e); break; + case RESIZE_EV: that._resize(); break; + case WHEEL_EV: that._wheel(e); break; + case 'mouseout': that._mouseout(e); break; + case 'webkitTransitionEnd': that._transitionEnd(e); break; + } + }, + + _checkDOMChanges: function () { + if (this.moved || this.zoomed || this.animating || + (this.scrollerW == this.scroller.offsetWidth * this.scale && this.scrollerH == this.scroller.offsetHeight * this.scale)) return; + + this.refresh(); + }, + + _scrollbar: function (dir) { + var that = this, + doc = document, + bar; + + if (!that[dir + 'Scrollbar']) { + if (that[dir + 'ScrollbarWrapper']) { + if (hasTransform) that[dir + 'ScrollbarIndicator'].style[vendor + 'Transform'] = ''; + that[dir + 'ScrollbarWrapper'].parentNode.removeChild(that[dir + 'ScrollbarWrapper']); + that[dir + 'ScrollbarWrapper'] = null; + that[dir + 'ScrollbarIndicator'] = null; + } + + return; + } + + if (!that[dir + 'ScrollbarWrapper']) { + // Create the scrollbar wrapper + bar = doc.createElement('div'); + + if (that.options.scrollbarClass) bar.className = that.options.scrollbarClass + dir.toUpperCase(); + else bar.style.cssText = 'position:absolute;z-index:100;' + (dir == 'h' ? 'height:7px;bottom:1px;left:2px;right:' + (that.vScrollbar ? '7' : '2') + 'px' : 'width:7px;bottom:' + (that.hScrollbar ? '7' : '2') + 'px;top:2px;right:1px'); + + bar.style.cssText += ';pointer-events:none;-' + vendor + '-transition-property:opacity;-' + vendor + '-transition-duration:' + (that.options.fadeScrollbar ? '350ms' : '0') + ';overflow:hidden;opacity:' + (that.options.hideScrollbar ? '0' : '1'); + + that.wrapper.appendChild(bar); + that[dir + 'ScrollbarWrapper'] = bar; + + // Create the scrollbar indicator + bar = doc.createElement('div'); + if (!that.options.scrollbarClass) { + bar.style.cssText = 'position:absolute;z-index:100;background:rgba(0,0,0,0.3);border:1px solid rgba(255,255,255,0.9);-' + vendor + '-background-clip:padding-box;-' + vendor + '-box-sizing:border-box;' + (dir == 'h' ? 'height:100%' : 'width:100%') + ';-' + vendor + '-border-radius:3px;border-radius:3px'; + } + bar.style.cssText += ';pointer-events:none;-' + vendor + '-transition-property:-' + vendor + '-transform;-' + vendor + '-transition-timing-function:cubic-bezier(0.33,0.66,0.66,1);-' + vendor + '-transition-duration:0;-' + vendor + '-transform:' + trnOpen + '0,0' + trnClose; + if (that.options.useTransition) bar.style.cssText += ';-' + vendor + '-transition-timing-function:cubic-bezier(0.33,0.66,0.66,1)'; + + that[dir + 'ScrollbarWrapper'].appendChild(bar); + that[dir + 'ScrollbarIndicator'] = bar; + } + + if (dir == 'h') { + that.hScrollbarSize = that.hScrollbarWrapper.clientWidth; + that.hScrollbarIndicatorSize = m.max(mround(that.hScrollbarSize * that.hScrollbarSize / that.scrollerW), 8); + that.hScrollbarIndicator.style.width = that.hScrollbarIndicatorSize + 'px'; + that.hScrollbarMaxScroll = that.hScrollbarSize - that.hScrollbarIndicatorSize; + that.hScrollbarProp = that.hScrollbarMaxScroll / that.maxScrollX; + } else { + that.vScrollbarSize = that.vScrollbarWrapper.clientHeight; + that.vScrollbarIndicatorSize = m.max(mround(that.vScrollbarSize * that.vScrollbarSize / that.scrollerH), 8); + that.vScrollbarIndicator.style.height = that.vScrollbarIndicatorSize + 'px'; + that.vScrollbarMaxScroll = that.vScrollbarSize - that.vScrollbarIndicatorSize; + that.vScrollbarProp = that.vScrollbarMaxScroll / that.maxScrollY; + } + + // Reset position + that._scrollbarPos(dir, true); + }, + + _resize: function () { + var that = this; + setTimeout(function () { that.refresh(); }, isAndroid ? 200 : 0); + }, + + _pos: function (x, y) { + x = this.hScroll ? x : 0; + y = this.vScroll ? y : 0; + + if (this.options.useTransform) { + this.scroller.style[vendor + 'Transform'] = trnOpen + x + 'px,' + y + 'px' + trnClose + ' scale(' + this.scale + ')'; + } else { + x = mround(x); + y = mround(y); + this.scroller.style.left = x + 'px'; + this.scroller.style.top = y + 'px'; + } + + this.x = x; + this.y = y; + + this._scrollbarPos('h'); + this._scrollbarPos('v'); + }, + + _scrollbarPos: function (dir, hidden) { + var that = this, + pos = dir == 'h' ? that.x : that.y, + size; + + if (!that[dir + 'Scrollbar']) return; + + pos = that[dir + 'ScrollbarProp'] * pos; + + if (pos < 0) { + if (!that.options.fixedScrollbar) { + size = that[dir + 'ScrollbarIndicatorSize'] + mround(pos * 3); + if (size < 8) size = 8; + that[dir + 'ScrollbarIndicator'].style[dir == 'h' ? 'width' : 'height'] = size + 'px'; + } + pos = 0; + } else if (pos > that[dir + 'ScrollbarMaxScroll']) { + if (!that.options.fixedScrollbar) { + size = that[dir + 'ScrollbarIndicatorSize'] - mround((pos - that[dir + 'ScrollbarMaxScroll']) * 3); + if (size < 8) size = 8; + that[dir + 'ScrollbarIndicator'].style[dir == 'h' ? 'width' : 'height'] = size + 'px'; + pos = that[dir + 'ScrollbarMaxScroll'] + (that[dir + 'ScrollbarIndicatorSize'] - size); + } else { + pos = that[dir + 'ScrollbarMaxScroll']; + } + } + + that[dir + 'ScrollbarWrapper'].style[vendor + 'TransitionDelay'] = '0'; + that[dir + 'ScrollbarWrapper'].style.opacity = hidden && that.options.hideScrollbar ? '0' : '1'; + that[dir + 'ScrollbarIndicator'].style[vendor + 'Transform'] = trnOpen + (dir == 'h' ? pos + 'px,0' : '0,' + pos + 'px') + trnClose; + }, + + _start: function (e) { + var that = this, + point = hasTouch ? e.touches[0] : e, + matrix, x, y, + c1, c2; + + if (!that.enabled) return; + + if (that.options.onBeforeScrollStart) that.options.onBeforeScrollStart.call(that, e); + + if (that.options.useTransition || that.options.zoom) that._transitionTime(0); + + that.moved = false; + that.animating = false; + that.zoomed = false; + that.distX = 0; + that.distY = 0; + that.absDistX = 0; + that.absDistY = 0; + that.dirX = 0; + that.dirY = 0; + + // Gesture start + if (that.options.zoom && hasTouch && e.touches.length > 1) { + c1 = m.abs(e.touches[0].pageX-e.touches[1].pageX); + c2 = m.abs(e.touches[0].pageY-e.touches[1].pageY); + that.touchesDistStart = m.sqrt(c1 * c1 + c2 * c2); + + that.originX = m.abs(e.touches[0].pageX + e.touches[1].pageX - that.wrapperOffsetLeft * 2) / 2 - that.x; + that.originY = m.abs(e.touches[0].pageY + e.touches[1].pageY - that.wrapperOffsetTop * 2) / 2 - that.y; + + if (that.options.onZoomStart) that.options.onZoomStart.call(that, e); + } + + if (that.options.momentum) { + if (that.options.useTransform) { + // Very lame general purpose alternative to CSSMatrix + matrix = getComputedStyle(that.scroller, null)[vendor + 'Transform'].replace(/[^0-9-.,]/g, '').split(','); + x = matrix[4] * 1; + y = matrix[5] * 1; + } else { + x = getComputedStyle(that.scroller, null).left.replace(/[^0-9-]/g, '') * 1; + y = getComputedStyle(that.scroller, null).top.replace(/[^0-9-]/g, '') * 1; + } + + if (x != that.x || y != that.y) { + if (that.options.useTransition) that._unbind('webkitTransitionEnd'); + else cancelFrame(that.aniTime); + that.steps = []; + that._pos(x, y); + } + } + + that.absStartX = that.x; // Needed by snap threshold + that.absStartY = that.y; + + that.startX = that.x; + that.startY = that.y; + that.pointX = point.pageX; + that.pointY = point.pageY; + + that.startTime = e.timeStamp || Date.now(); + + if (that.options.onScrollStart) that.options.onScrollStart.call(that, e); + + that._bind(MOVE_EV); + that._bind(END_EV); + that._bind(CANCEL_EV); + }, + + _move: function (e) { + var that = this, + point = hasTouch ? e.touches[0] : e, + deltaX = point.pageX - that.pointX, + deltaY = point.pageY - that.pointY, + newX = that.x + deltaX, + newY = that.y + deltaY, + c1, c2, scale, + timestamp = e.timeStamp || Date.now(); + + if (that.options.onBeforeScrollMove) that.options.onBeforeScrollMove.call(that, e); + + // Zoom + if (that.options.zoom && hasTouch && e.touches.length > 1) { + c1 = m.abs(e.touches[0].pageX - e.touches[1].pageX); + c2 = m.abs(e.touches[0].pageY - e.touches[1].pageY); + that.touchesDist = m.sqrt(c1*c1+c2*c2); + + that.zoomed = true; + + scale = 1 / that.touchesDistStart * that.touchesDist * this.scale; + + if (scale < that.options.zoomMin) scale = 0.5 * that.options.zoomMin * Math.pow(2.0, scale / that.options.zoomMin); + else if (scale > that.options.zoomMax) scale = 2.0 * that.options.zoomMax * Math.pow(0.5, that.options.zoomMax / scale); + + that.lastScale = scale / this.scale; + + newX = this.originX - this.originX * that.lastScale + this.x, + newY = this.originY - this.originY * that.lastScale + this.y; + + this.scroller.style[vendor + 'Transform'] = trnOpen + newX + 'px,' + newY + 'px' + trnClose + ' scale(' + scale + ')'; + + if (that.options.onZoom) that.options.onZoom.call(that, e); + return; + } + + that.pointX = point.pageX; + that.pointY = point.pageY; + + // Slow down if outside of the boundaries + if (newX > 0 || newX < that.maxScrollX) { + newX = that.options.bounce ? that.x + (deltaX / 2) : newX >= 0 || that.maxScrollX >= 0 ? 0 : that.maxScrollX; + } + if (newY > that.minScrollY || newY < that.maxScrollY) { + newY = that.options.bounce ? that.y + (deltaY / 2) : newY >= that.minScrollY || that.maxScrollY >= 0 ? that.minScrollY : that.maxScrollY; + } + + that.distX += deltaX; + that.distY += deltaY; + that.absDistX = m.abs(that.distX); + that.absDistY = m.abs(that.distY); + + if (that.absDistX < 6 && that.absDistY < 6) { + return; + } + + // Lock direction + if (that.options.lockDirection) { + if (that.absDistX > that.absDistY + 5) { + newY = that.y; + deltaY = 0; + } else if (that.absDistY > that.absDistX + 5) { + newX = that.x; + deltaX = 0; + } + } + + that.moved = true; + that._pos(newX, newY); + that.dirX = deltaX > 0 ? -1 : deltaX < 0 ? 1 : 0; + that.dirY = deltaY > 0 ? -1 : deltaY < 0 ? 1 : 0; + + if (timestamp - that.startTime > 300) { + that.startTime = timestamp; + that.startX = that.x; + that.startY = that.y; + } + + if (that.options.onScrollMove) that.options.onScrollMove.call(that, e); + }, + + _end: function (e) { + if (hasTouch && e.touches.length != 0) return; + + var that = this, + point = hasTouch ? e.changedTouches[0] : e, + target, ev, + momentumX = { dist:0, time:0 }, + momentumY = { dist:0, time:0 }, + duration = (e.timeStamp || Date.now()) - that.startTime, + newPosX = that.x, + newPosY = that.y, + distX, distY, + newDuration, + snap, + scale; + + that._unbind(MOVE_EV); + that._unbind(END_EV); + that._unbind(CANCEL_EV); + + if (that.options.onBeforeScrollEnd) that.options.onBeforeScrollEnd.call(that, e); + + if (that.zoomed) { + scale = that.scale * that.lastScale; + scale = Math.max(that.options.zoomMin, scale); + scale = Math.min(that.options.zoomMax, scale); + that.lastScale = scale / that.scale; + that.scale = scale; + + that.x = that.originX - that.originX * that.lastScale + that.x; + that.y = that.originY - that.originY * that.lastScale + that.y; + + that.scroller.style[vendor + 'TransitionDuration'] = '200ms'; + that.scroller.style[vendor + 'Transform'] = trnOpen + that.x + 'px,' + that.y + 'px' + trnClose + ' scale(' + that.scale + ')'; + + that.zoomed = false; + that.refresh(); + + if (that.options.onZoomEnd) that.options.onZoomEnd.call(that, e); + return; + } + + if (!that.moved) { + if (hasTouch) { + if (that.doubleTapTimer && that.options.zoom) { + // Double tapped + clearTimeout(that.doubleTapTimer); + that.doubleTapTimer = null; + if (that.options.onZoomStart) that.options.onZoomStart.call(that, e); + that.zoom(that.pointX, that.pointY, that.scale == 1 ? that.options.doubleTapZoom : 1); + if (that.options.onZoomEnd) { + setTimeout(function() { + that.options.onZoomEnd.call(that, e); + }, 200); // 200 is default zoom duration + } + } else { + that.doubleTapTimer = setTimeout(function () { + that.doubleTapTimer = null; + + // Find the last touched element + target = point.target; + while (target.nodeType != 1) target = target.parentNode; + + if (target.tagName != 'SELECT' && target.tagName != 'INPUT' && target.tagName != 'TEXTAREA') { + ev = document.createEvent('MouseEvents'); + ev.initMouseEvent('click', true, true, e.view, 1, + point.screenX, point.screenY, point.clientX, point.clientY, + e.ctrlKey, e.altKey, e.shiftKey, e.metaKey, + 0, null); + ev._fake = true; + target.dispatchEvent(ev); + } + }, that.options.zoom ? 250 : 0); + } + } + + that._resetPos(200); + + if (that.options.onTouchEnd) that.options.onTouchEnd.call(that, e); + return; + } + + if (duration < 300 && that.options.momentum) { + momentumX = newPosX ? that._momentum(newPosX - that.startX, duration, -that.x, that.scrollerW - that.wrapperW + that.x, that.options.bounce ? that.wrapperW : 0) : momentumX; + momentumY = newPosY ? that._momentum(newPosY - that.startY, duration, -that.y, (that.maxScrollY < 0 ? that.scrollerH - that.wrapperH + that.y - that.minScrollY : 0), that.options.bounce ? that.wrapperH : 0) : momentumY; + + newPosX = that.x + momentumX.dist; + newPosY = that.y + momentumY.dist; + + if ((that.x > 0 && newPosX > 0) || (that.x < that.maxScrollX && newPosX < that.maxScrollX)) momentumX = { dist:0, time:0 }; + if ((that.y > that.minScrollY && newPosY > that.minScrollY) || (that.y < that.maxScrollY && newPosY < that.maxScrollY)) momentumY = { dist:0, time:0 }; + } + + if (momentumX.dist || momentumY.dist) { + newDuration = m.max(m.max(momentumX.time, momentumY.time), 10); + + // Do we need to snap? + if (that.options.snap) { + distX = newPosX - that.absStartX; + distY = newPosY - that.absStartY; + if (m.abs(distX) < that.options.snapThreshold && m.abs(distY) < that.options.snapThreshold) { that.scrollTo(that.absStartX, that.absStartY, 200); } + else { + snap = that._snap(newPosX, newPosY); + newPosX = snap.x; + newPosY = snap.y; + newDuration = m.max(snap.time, newDuration); + } + } + + that.scrollTo(mround(newPosX), mround(newPosY), newDuration); + + if (that.options.onTouchEnd) that.options.onTouchEnd.call(that, e); + return; + } + + // Do we need to snap? + if (that.options.snap) { + distX = newPosX - that.absStartX; + distY = newPosY - that.absStartY; + if (m.abs(distX) < that.options.snapThreshold && m.abs(distY) < that.options.snapThreshold) that.scrollTo(that.absStartX, that.absStartY, 200); + else { + snap = that._snap(that.x, that.y); + if (snap.x != that.x || snap.y != that.y) that.scrollTo(snap.x, snap.y, snap.time); + } + + if (that.options.onTouchEnd) that.options.onTouchEnd.call(that, e); + return; + } + + that._resetPos(200); + if (that.options.onTouchEnd) that.options.onTouchEnd.call(that, e); + }, + + _resetPos: function (time) { + var that = this, + resetX = that.x >= 0 ? 0 : that.x < that.maxScrollX ? that.maxScrollX : that.x, + resetY = that.y >= that.minScrollY || that.maxScrollY > 0 ? that.minScrollY : that.y < that.maxScrollY ? that.maxScrollY : that.y; + + if (resetX == that.x && resetY == that.y) { + if (that.moved) { + that.moved = false; + if (that.options.onScrollEnd) that.options.onScrollEnd.call(that); // Execute custom code on scroll end + } + + if (that.hScrollbar && that.options.hideScrollbar) { + if (vendor == 'webkit') that.hScrollbarWrapper.style[vendor + 'TransitionDelay'] = '300ms'; + that.hScrollbarWrapper.style.opacity = '0'; + } + if (that.vScrollbar && that.options.hideScrollbar) { + if (vendor == 'webkit') that.vScrollbarWrapper.style[vendor + 'TransitionDelay'] = '300ms'; + that.vScrollbarWrapper.style.opacity = '0'; + } + + return; + } + + that.scrollTo(resetX, resetY, time || 0); + }, + + _wheel: function (e) { + var that = this, + wheelDeltaX, wheelDeltaY, + deltaX, deltaY, + deltaScale; + + if ('wheelDeltaX' in e) { + wheelDeltaX = e.wheelDeltaX / 12; + wheelDeltaY = e.wheelDeltaY / 12; + } else if('wheelDelta' in e) { + wheelDeltaX = wheelDeltaY = e.wheelDelta / 12; + } else if ('detail' in e) { + wheelDeltaX = wheelDeltaY = -e.detail * 3; + } else { + return; + } + + if (that.options.wheelAction == 'zoom') { + deltaScale = that.scale * Math.pow(2, 1/3 * (wheelDeltaY ? wheelDeltaY / Math.abs(wheelDeltaY) : 0)); + if (deltaScale < that.options.zoomMin) deltaScale = that.options.zoomMin; + if (deltaScale > that.options.zoomMax) deltaScale = that.options.zoomMax; + + if (deltaScale != that.scale) { + if (!that.wheelZoomCount && that.options.onZoomStart) that.options.onZoomStart.call(that, e); + that.wheelZoomCount++; + + that.zoom(e.pageX, e.pageY, deltaScale, 400); + + setTimeout(function() { + that.wheelZoomCount--; + if (!that.wheelZoomCount && that.options.onZoomEnd) that.options.onZoomEnd.call(that, e); + }, 400); + } + + return; + } + + deltaX = that.x + wheelDeltaX; + deltaY = that.y + wheelDeltaY; + + if (deltaX > 0) deltaX = 0; + else if (deltaX < that.maxScrollX) deltaX = that.maxScrollX; + + if (deltaY > that.minScrollY) deltaY = that.minScrollY; + else if (deltaY < that.maxScrollY) deltaY = that.maxScrollY; + + that.scrollTo(deltaX, deltaY, 0); + }, + + _mouseout: function (e) { + var t = e.relatedTarget; + + if (!t) { + this._end(e); + return; + } + + while (t = t.parentNode) if (t == this.wrapper) return; + + this._end(e); + }, + + _transitionEnd: function (e) { + var that = this; + + if (e.target != that.scroller) return; + + that._unbind('webkitTransitionEnd'); + + that._startAni(); + }, + + + /** + * + * Utilities + * + */ + _startAni: function () { + var that = this, + startX = that.x, startY = that.y, + startTime = Date.now(), + step, easeOut, + animate; + + if (that.animating) return; + + if (!that.steps.length) { + that._resetPos(400); + return; + } + + step = that.steps.shift(); + + if (step.x == startX && step.y == startY) step.time = 0; + + that.animating = true; + that.moved = true; + + if (that.options.useTransition) { + that._transitionTime(step.time); + that._pos(step.x, step.y); + that.animating = false; + if (step.time) that._bind('webkitTransitionEnd'); + else that._resetPos(0); + return; + } + + animate = function () { + var now = Date.now(), + newX, newY; + + if (now >= startTime + step.time) { + that._pos(step.x, step.y); + that.animating = false; + if (that.options.onAnimationEnd) that.options.onAnimationEnd.call(that); // Execute custom code on animation end + that._startAni(); + return; + } + + now = (now - startTime) / step.time - 1; + easeOut = m.sqrt(1 - now * now); + newX = (step.x - startX) * easeOut + startX; + newY = (step.y - startY) * easeOut + startY; + that._pos(newX, newY); + if (that.animating) that.aniTime = nextFrame(animate); + }; + + animate(); + }, + + _transitionTime: function (time) { + time += 'ms'; + this.scroller.style[vendor + 'TransitionDuration'] = time; + if (this.hScrollbar) this.hScrollbarIndicator.style[vendor + 'TransitionDuration'] = time; + if (this.vScrollbar) this.vScrollbarIndicator.style[vendor + 'TransitionDuration'] = time; + }, + + _momentum: function (dist, time, maxDistUpper, maxDistLower, size) { + var deceleration = 0.0006, + speed = m.abs(dist) / time, + newDist = (speed * speed) / (2 * deceleration), + newTime = 0, outsideDist = 0; + + // Proportinally reduce speed if we are outside of the boundaries + if (dist > 0 && newDist > maxDistUpper) { + outsideDist = size / (6 / (newDist / speed * deceleration)); + maxDistUpper = maxDistUpper + outsideDist; + speed = speed * maxDistUpper / newDist; + newDist = maxDistUpper; + } else if (dist < 0 && newDist > maxDistLower) { + outsideDist = size / (6 / (newDist / speed * deceleration)); + maxDistLower = maxDistLower + outsideDist; + speed = speed * maxDistLower / newDist; + newDist = maxDistLower; + } + + newDist = newDist * (dist < 0 ? -1 : 1); + newTime = speed / deceleration; + + return { dist: newDist, time: mround(newTime) }; + }, + + _offset: function (el) { + var left = -el.offsetLeft, + top = -el.offsetTop; + + while (el = el.offsetParent) { + left -= el.offsetLeft; + top -= el.offsetTop; + } + + if (el != this.wrapper) { + left *= this.scale; + top *= this.scale; + } + + return { left: left, top: top }; + }, + + _snap: function (x, y) { + var that = this, + i, l, + page, time, + sizeX, sizeY; + + // Check page X + page = that.pagesX.length - 1; + for (i=0, l=that.pagesX.length; i= that.pagesX[i]) { + page = i; + break; + } + } + if (page == that.currPageX && page > 0 && that.dirX < 0) page--; + x = that.pagesX[page]; + sizeX = m.abs(x - that.pagesX[that.currPageX]); + sizeX = sizeX ? m.abs(that.x - x) / sizeX * 500 : 0; + that.currPageX = page; + + // Check page Y + page = that.pagesY.length-1; + for (i=0; i= that.pagesY[i]) { + page = i; + break; + } + } + if (page == that.currPageY && page > 0 && that.dirY < 0) page--; + y = that.pagesY[page]; + sizeY = m.abs(y - that.pagesY[that.currPageY]); + sizeY = sizeY ? m.abs(that.y - y) / sizeY * 500 : 0; + that.currPageY = page; + + // Snap with constant speed (proportional duration) + time = mround(m.max(sizeX, sizeY)) || 200; + + return { x: x, y: y, time: time }; + }, + + _bind: function (type, el, bubble) { + (el || this.scroller).addEventListener(type, this, !!bubble); + }, + + _unbind: function (type, el, bubble) { + (el || this.scroller).removeEventListener(type, this, !!bubble); + }, + + + /** + * + * Public methods + * + */ + destroy: function () { + var that = this; + + that.scroller.style[vendor + 'Transform'] = ''; + + // Remove the scrollbars + that.hScrollbar = false; + that.vScrollbar = false; + that._scrollbar('h'); + that._scrollbar('v'); + + // Remove the event listeners + that._unbind(RESIZE_EV, window); + that._unbind(START_EV); + that._unbind(MOVE_EV); + that._unbind(END_EV); + that._unbind(CANCEL_EV); + + if (!that.options.hasTouch) { + that._unbind('mouseout', that.wrapper); + that._unbind(WHEEL_EV); + } + + if (that.options.useTransition) that._unbind('webkitTransitionEnd'); + + if (that.options.checkDOMChanges) clearInterval(that.checkDOMTime); + + if (that.options.onDestroy) that.options.onDestroy.call(that); + }, + + refresh: function () { + var that = this, + offset, + i, l, + els, + pos = 0, + page = 0; + + if (that.scale < that.options.zoomMin) that.scale = that.options.zoomMin; + that.wrapperW = that.wrapper.clientWidth || 1; + that.wrapperH = that.wrapper.clientHeight || 1; + + that.minScrollY = -that.options.topOffset || 0; + that.scrollerW = mround(that.scroller.offsetWidth * that.scale); + that.scrollerH = mround((that.scroller.offsetHeight + that.minScrollY) * that.scale); + that.maxScrollX = that.wrapperW - that.scrollerW; + that.maxScrollY = that.wrapperH - that.scrollerH + that.minScrollY; + that.dirX = 0; + that.dirY = 0; + + if (that.options.onRefresh) that.options.onRefresh.call(that); + + that.hScroll = that.options.hScroll && that.maxScrollX < 0; + that.vScroll = that.options.vScroll && (!that.options.bounceLock && !that.hScroll || that.scrollerH > that.wrapperH); + + that.hScrollbar = that.hScroll && that.options.hScrollbar; + that.vScrollbar = that.vScroll && that.options.vScrollbar && that.scrollerH > that.wrapperH; + + offset = that._offset(that.wrapper); + that.wrapperOffsetLeft = -offset.left; + that.wrapperOffsetTop = -offset.top; + + // Prepare snap + if (typeof that.options.snap == 'string') { + that.pagesX = []; + that.pagesY = []; + els = that.scroller.querySelectorAll(that.options.snap); + for (i=0, l=els.length; i= that.maxScrollX) { + that.pagesX[page] = pos; + pos = pos - that.wrapperW; + page++; + } + if (that.maxScrollX%that.wrapperW) that.pagesX[that.pagesX.length] = that.maxScrollX - that.pagesX[that.pagesX.length-1] + that.pagesX[that.pagesX.length-1]; + + pos = 0; + page = 0; + that.pagesY = []; + while (pos >= that.maxScrollY) { + that.pagesY[page] = pos; + pos = pos - that.wrapperH; + page++; + } + if (that.maxScrollY%that.wrapperH) that.pagesY[that.pagesY.length] = that.maxScrollY - that.pagesY[that.pagesY.length-1] + that.pagesY[that.pagesY.length-1]; + } + + // Prepare the scrollbars + that._scrollbar('h'); + that._scrollbar('v'); + + if (!that.zoomed) { + that.scroller.style[vendor + 'TransitionDuration'] = '0'; + that._resetPos(200); + } + }, + + scrollTo: function (x, y, time, relative) { + var that = this, + step = x, + i, l; + + that.stop(); + + if (!step.length) step = [{ x: x, y: y, time: time, relative: relative }]; + + for (i=0, l=step.length; i 0 ? 0 : pos.left < that.maxScrollX ? that.maxScrollX : pos.left; + pos.top = pos.top > that.minScrollY ? that.minScrollY : pos.top < that.maxScrollY ? that.maxScrollY : pos.top; + time = time === undefined ? m.max(m.abs(pos.left)*2, m.abs(pos.top)*2) : time; + + that.scrollTo(pos.left, pos.top, time); + }, + + scrollToPage: function (pageX, pageY, time) { + var that = this, x, y; + + time = time === undefined ? 400 : time; + + if (that.options.onScrollStart) that.options.onScrollStart.call(that); + + if (that.options.snap) { + pageX = pageX == 'next' ? that.currPageX+1 : pageX == 'prev' ? that.currPageX-1 : pageX; + pageY = pageY == 'next' ? that.currPageY+1 : pageY == 'prev' ? that.currPageY-1 : pageY; + + pageX = pageX < 0 ? 0 : pageX > that.pagesX.length-1 ? that.pagesX.length-1 : pageX; + pageY = pageY < 0 ? 0 : pageY > that.pagesY.length-1 ? that.pagesY.length-1 : pageY; + + that.currPageX = pageX; + that.currPageY = pageY; + x = that.pagesX[pageX]; + y = that.pagesY[pageY]; + } else { + x = -that.wrapperW * pageX; + y = -that.wrapperH * pageY; + if (x < that.maxScrollX) x = that.maxScrollX; + if (y < that.maxScrollY) y = that.maxScrollY; + } + + that.scrollTo(x, y, time); + }, + + disable: function () { + this.stop(); + this._resetPos(0); + this.enabled = false; + + // If disabled after touchstart we make sure that there are no left over events + this._unbind(MOVE_EV); + this._unbind(END_EV); + this._unbind(CANCEL_EV); + }, + + enable: function () { + this.enabled = true; + }, + + stop: function () { + if (this.options.useTransition) this._unbind('webkitTransitionEnd'); + else cancelFrame(this.aniTime); + this.steps = []; + this.moved = false; + this.animating = false; + }, + + zoom: function (x, y, scale, time) { + var that = this, + relScale = scale / that.scale; + + if (!that.options.useTransform) return; + + that.zoomed = true; + time = time === undefined ? 200 : time; + x = x - that.wrapperOffsetLeft - that.x; + y = y - that.wrapperOffsetTop - that.y; + that.x = x - x * relScale + that.x; + that.y = y - y * relScale + that.y; + + that.scale = scale; + that.refresh(); + + that.x = that.x > 0 ? 0 : that.x < that.maxScrollX ? that.maxScrollX : that.x; + that.y = that.y > that.minScrollY ? that.minScrollY : that.y < that.maxScrollY ? that.maxScrollY : that.y; + + that.scroller.style[vendor + 'TransitionDuration'] = time + 'ms'; + that.scroller.style[vendor + 'Transform'] = trnOpen + that.x + 'px,' + that.y + 'px' + trnClose + ' scale(' + scale + ')'; + that.zoomed = false; + }, + + isReady: function () { + return !this.moved && !this.zoomed && !this.animating; + } +}; + +if (typeof exports !== 'undefined') exports.iScroll = iScroll; +else window.iScroll = iScroll; + +})(); +bb.menuBar = { + height: 100, + menuOpen: false, + menu: false, + + apply: function(menuBar,screen){ + if (bb.device.isPlayBook || bb.device.isBB10) { + bb.menuBar.createSwipeMenu(menuBar,screen); + menuBar.parentNode.removeChild(menuBar); + if (window.blackberry){ + if(bb.device.isPlayBook && blackberry.app.event) { + blackberry.app.event.onSwipeDown(bb.menuBar.showMenuBar); + }else if(bb.device.isBB10 && blackberry.app){ + blackberry.event.addEventListener("swipedown", bb.menuBar.showMenuBar); + } + } + }else if(window.blackberry && blackberry.ui.menu){ + bb.menuBar.createBlackberryMenu(menuBar); + menuBar.parentNode.removeChild(menuBar); + }else{ + console.log('Unable to create Blackberry/onSwipeDown menu.'); + } + }, + + createBlackberryMenu: function(menuBar){ + var items, + item, + title, + div; + items = menuBar.getElementsByTagName('div'); + for (var j = 0; j < items.length; j++) { + div = items[j]; + if(div.getAttribute('data-bb-type') === "menu-item"){ + title = div.innerHTML; + if(title){ + item = new blackberry.ui.menu.MenuItem(false, j, title, div.onclick); + blackberry.ui.menu.addMenuItem(item); + if(div.hasAttribute('data-bb-selected') && div.getAttribute('data-bb-selected') === "true"){ + blackberry.ui.menu.setDefaultMenuItem(item); + } + }else{ + console.log("can't add menu item without data-bb-caption"); + } + }else if(div.getAttribute('data-bb-type') === "menu-separator"){ + item = new blackberry.ui.menu.MenuItem(true, j); + blackberry.ui.menu.addMenuItem(item); + }else{ + console.log('invalid menu item type'); + } + } + }, + + createSwipeMenu: function(menuBar, screen){ + // Get our resolution text for BB10 styling + if (bb.device.isBB10) { + var bb10Menu = document.createElement('div'), + res, + i, + type, + item, + foundItems = [], + img, + imgPath, + caption, + div, + width, + bb10MenuItem; + + if (bb.device.isPlayBook) { + res = 'lowres'; + bb.menuBar.height = 100; + } else { + res = 'hires'; + bb.menuBar.height = 140; + } + + bb10Menu.setAttribute('class','bb-bb10-menu-bar-'+res+' bb-bb10-menu-bar-'+bb.actionBar.color); + items = menuBar.querySelectorAll('[data-bb-type=menu-item]'); + if(items.length > 0){ + for (i = 0; i < items.length; i++) { + item = items[i]; + type = item.hasAttribute('data-bb-type') ? item.getAttribute('data-bb-type').toLowerCase() : undefined; + // Get our menu items + if (type == 'menu-item') { + caption = item.innerHTML; + imgPath = item.getAttribute('data-bb-img'); + // If the item doesn't have both an image and text then remove it + if ((caption && imgPath) && (foundItems.length < 5)) { + // BB10 menus only allow 5 items max + bb10MenuItem = document.createElement("div"); + foundItems.push(bb10MenuItem); + // Set our item information + bb10MenuItem.setAttribute('class','bb-bb10-menu-bar-item-'+res); + item.innerHTML = ''; + // Add the image + img = document.createElement('img'); + img.setAttribute('src',imgPath); + bb10MenuItem.appendChild(img); + // Add the caption + div = document.createElement('div'); + div.setAttribute('class','bb-bb10-menu-bar-item-caption-'+res); + div.innerHTML = caption; + bb10MenuItem.appendChild(div); + + // Assign any click handlers + bb10MenuItem.onclick = item.onclick; + bb10Menu.appendChild(bb10MenuItem); + } else { + if(foundItems.length >= 5){ + console.log('too many menu items.'); + } else { + console.log('missing menu item caption or image.'); + } + } + } else { + console.log('invalid menu item type for bb10'); + } + } + } + // Now apply the widths since we now know how many there are + if (foundItems.length > 0) { + width = Math.floor(100/foundItems.length); + for (i = 0; i < foundItems.length;i++) { + item = foundItems[i]; + if (i == foundItems.length -1) { + item.style.width = width - 1 +'%'; + item.style.float = 'right'; + } else { + item.style.width = width +'%'; + } + } + } else { + bb10Menu.style.display = 'none'; + bb.menuBar.menu = null; + } + + // Set the size of the menu bar and assign the lstener + bb10Menu.style['-webkit-transform'] = 'translate(0,0)'; + bb10Menu.addEventListener('click', bb.menuBar.onMenuBarClicked, false); + document.body.appendChild(bb10Menu); + // Assign the menu + bb.menuBar.menu = bb10Menu; + } else { + var pbMenu = document.createElement('div'), + items, + pbMenuInner, + j, + item, + img, + title, + div, + br, + pbMenuItem; + pbMenu.setAttribute('class','pb-menu-bar'); + // See if there are any items declared + items = menuBar.getElementsByTagName('div'); + if(items.length > 0){ + pbMenuInner = document.createElement("ul"); + pbMenu.appendChild(pbMenuInner); + // Loop through our menu items + for (j = 0; j < items.length; j++) { + item = items[j]; + if(item.getAttribute('data-bb-type') === "menu-item"){ + // Assign our values + title = item.innerHTML + iconPath = item.getAttribute('data-bb-img'); + + // If they don't hav both an icon and a title ignore the item + if (title && iconPath) { + // Create our item + pbMenuItem = document.createElement("li"); + item.innerHTML = ''; + + // Get our image + img = new Image(); + img.src = iconPath; + pbMenuItem.appendChild(img); + + // Add our caption + div = document.createElement('div'); + div.setAttribute('class','pb-menu-bar-caption'); + div.innerText = title; + pbMenuItem.appendChild(div); + + // Assign any click handlers + pbMenuItem.onclick = item.onclick; + pbMenuInner.appendChild(pbMenuItem); + } + } else if(item.getAttribute('data-bb-type') === "menu-separator"){ + pbMenuInner = document.createElement('ul'); + pbMenu.appendChild(pbMenuInner); + } else{ + console.log('invalid menu item type'); + } + } + } + // Set the size of the menu bar and assign the lstener + pbMenu.style['-webkit-transform'] = 'translate(0,0)'; + pbMenu.addEventListener('click', bb.menuBar.onMenuBarClicked, false); + document.body.appendChild(pbMenu); + // Assign the menu + bb.menuBar.menu = pbMenu; + } + + // Add the overlay for trapping clicks on items below + if (!bb.screen.overlay) { + bb.screen.overlay = document.createElement('div'); + bb.screen.overlay.setAttribute('class','bb-bb10-context-menu-overlay'); + } + screen.appendChild(bb.screen.overlay); + bb.menuBar.menu.overlay = bb.screen.overlay; + }, + + showMenuBar: function(){ + if(!bb.menuBar.menuOpen){ + bb.menuBar.menu.overlay.style.display = 'inline'; + if(bb.device.isPlayBook){ + blackberry.app.event.onSwipeDown(bb.menuBar.hideMenuBar); + }else if(bb.device.isBB10){ + blackberry.event.removeEventListener("swipedown", bb.menuBar.showMenuBar); + blackberry.event.addEventListener("swipedown", bb.menuBar.hideMenuBar); + } + bb.menuBar.menu.style['-webkit-transition'] = 'all 0.5s ease-in-out'; + bb.menuBar.menu.style['-webkit-transform'] = 'translate(0, ' + (bb.menuBar.height + 3) + 'px)'; + bb.menuBar.menuOpen = true; + bb.menuBar.menu.overlay.addEventListener('touchstart', bb.menuBar.overlayTouchHandler, false); + } + }, + + hideMenuBar: function(){ + if(bb.menuBar.menuOpen){ + bb.menuBar.menu.overlay.style.display = 'none'; + if(bb.device.isPlayBook){ + blackberry.app.event.onSwipeDown(bb.menuBar.showMenuBar); + }else if(bb.device.isBB10){ + blackberry.event.removeEventListener("swipedown", bb.menuBar.hideMenuBar); + blackberry.event.addEventListener("swipedown", bb.menuBar.showMenuBar); + } + bb.menuBar.menu.style['-webkit-transition'] = 'all 0.5s ease-in-out'; + bb.menuBar.menu.style['-webkit-transform'] = 'translate(0, -' + (bb.menuBar.height + 3) + 'px)'; + bb.menuBar.menuOpen = false; + bb.menuBar.menu.overlay.removeEventListener('touchstart', bb.menuBar.overlayTouchHandler, false); + } + }, + + overlayTouchHandler: function(event){ + event.preventDefault(); + event.stopPropagation(); + bb.menuBar.hideMenuBar(); + }, + + onMenuBarClicked: function () { + bb.menuBar.hideMenuBar(); + }, + + clearMenu: function(){ + if(window.blackberry){ + if(bb.menuBar.menu && (bb.device.isPlayBook || bb.device.isBB10)){ + if (bb.device.isPlayBook && blackberry.app.event) { + blackberry.app.event.onSwipeDown(''); + }else if(bb.device.isBB10 && blackberry.app){ + blackberry.event.removeEventListener("swipedown", bb.menuBar.showMenuBar); + blackberry.event.removeEventListener("swipedown", bb.menuBar.hideMenuBar); + } + bb.menuBar.menu.parentNode.removeChild(bb.menuBar.menu); + bb.menuBar.menu = false; + bb.menuBar.menuOpen = false; + }else if(blackberry.ui && blackberry.ui.menu){ + blackberry.ui.menu.clearMenuItems(); + } + } + } +}; + +_bb_progress = { + + NORMAL : 0, + PAUSED : 1, + ERROR : 2, + + apply: function(elements) { + for (var i = 0; i < elements.length; i++) { + bb.progress.style(elements[i]); + } + }, + + // Style individual item + style: function(progress) { + var res, + color, + highlightColor, + accentColor, + NORMAL = 0, + PAUSED = 1, + ERROR = 2; + + if (bb.device.isBB10) { + res = (bb.device.isPlayBook) ? 'lowres' : 'hires', + color = bb.screen.controlColor; + highlightColor = bb.options.highlightColor; + accentColor = bb.options.shades.darkHighlight; + } else { + res = 'lowres'; + color = 'light'; + highlightColor = (bb.device.isPlayBook) ? bb.options.highlightColor : '#92B43B'; + accentColor = '#8FB03B'; + } + + // Create our container div + outerElement = document.createElement('div'); + outerElement.progress = progress; + outerElement.state = bb.progress.NORMAL; + if (progress.parentNode) { + progress.parentNode.insertBefore(outerElement, progress); + } + progress.style.display = 'none'; + outerElement.appendChild(progress); + // Get our values + outerElement.maxValue = progress.hasAttribute('max') ? parseInt(progress.getAttribute('max')) : 0; + outerElement.value = progress.hasAttribute('value') ? parseInt(progress.getAttribute('value')) : 0; + // Set our styling and create the inner divs + outerElement.className = 'bb-progress'; + outerElement.outer = document.createElement('div'); + outerElement.outer.setAttribute('class','outer bb-progress-outer-' + color + ' bb-progress-outer-idle-background-' + color); + outerElement.appendChild(outerElement.outer); + outerElement.fill = document.createElement('div'); + if (bb.device.isBB10) { + outerElement.fill.normal = 'bb-progress-fill bb10Highlight'; + } else { + outerElement.fill.normal = 'bb-progress-fill bbProgressHighlight'; + } + outerElement.fill.setAttribute('class',outerElement.fill.normal); + outerElement.outer.appendChild(outerElement.fill); + outerElement.inner = document.createElement('div'); + outerElement.inner.className = 'inner'; + outerElement.outer.appendChild(outerElement.inner); + + // Assign our function to set the value for the control + progress.outerElement = outerElement; + progress.setValue = function(value) { + var percent = 0, + width, + xpos; + if ((value && (value < 0)) || (value && (value > parseInt(this.outerElement.maxValue)))) { + return; + } else if (value) { + this.outerElement.value = value; + this.value = value; + } else if (value == 0) { + this.outerElement.value = 0; + this.value = 0; + } else { + value = parseInt(this.outerElement.value); + } + + // Calculate percentage and styling + if (value == this.outerElement.maxValue) { + this.outerElement.fill.style.background = '-webkit-gradient(linear, center top, center bottom, from(' + accentColor+ '), to('+highlightColor+'))'; + percent = 1; + } else if (value == 0) { + this.outerElement.outer.setAttribute('class','outer bb-progress-outer-' + color + ' bb-progress-outer-idle-background-' + color); + } else { + if (this.outerElement.state == bb.progress.PAUSED) { + this.outerElement.fill.style.background = '-webkit-gradient(linear, center top, center bottom, from(#EDC842), to(#BA991E))'; + } else if (this.outerElement.state == bb.progress.ERROR) { + this.outerElement.fill.style.background = '-webkit-gradient(linear, center top, center bottom, from( #E04242), to(#D91111))'; + } else { + this.outerElement.outer.setAttribute('class','outer bb-progress-outer-' + color); + this.outerElement.fill.setAttribute('class',this.outerElement.fill.normal); + this.outerElement.fill.style.background =''; + } + percent = (this.outerElement.value/parseInt(this.outerElement.maxValue)); + } + + // Determine width by percentage + xpos = Math.floor(parseInt(window.getComputedStyle(this.outerElement.outer).width) * percent); + this.outerElement.fill.style.width = xpos + 'px'; + }; + progress.setValue = progress.setValue.bind(progress); + + // Set the state of the control + progress.setState = function(state) { + this.outerElement.state = state; + this.setValue(); + }; + progress.setState = progress.setState.bind(progress); + + // Add our show function + progress.show = function() { + this.outerElement.style.display = 'block'; + bb.refresh(); + }; + progress.show = progress.show.bind(progress); + + // Add our hide function + progress.hide = function() { + this.outerElement.style.display = 'none'; + bb.refresh(); + }; + progress.hide = progress.hide.bind(progress); + + // Add remove function + progress.remove = function() { + this.outerElement.parentNode.removeChild(this.outerElement); + bb.refresh(); + }; + progress.remove = progress.remove.bind(progress); + + // Add setMax function + progress.setMax = function(value) { + if (!value || (value < 0) || (value == this.max)) return; + this.max = value; + this.outerElement.maxValue = value; + }; + progress.setMax = progress.setMax.bind(progress); + + // Set our value on a timeout so that it can calculate width once in the DOM + window.setTimeout(progress.setValue, 0); + outerElement.doOrientationChange = function() { + window.setTimeout(this.progress.setValue, 0); + }; + outerElement.doOrientationChange = outerElement.doOrientationChange.bind(outerElement); + // Assign our document event listeners + window.addEventListener('resize', outerElement.doOrientationChange,false); + + return outerElement; + } +}; +bb.screen = { + scriptCounter: 0, + totalScripts: 0, + controlColor: 'light', + listColor: 'light', + overlay : null, + tabOverlay : null, + contextMenu : null, + animating : false, + + apply: function(elements) { + var screenRes, + outerElement; + // Reset our context Menu + bb.screen.contextMenu = null; + + if (bb.device.isBB10 && bb.device.isPlayBook) { + screenRes = 'bb-bb10-lowres-screen'; + } else if (bb.device.isBB10) { + screenRes = 'bb-bb10-hires-screen'; + } else if (bb.device.isHiRes) { + screenRes = 'bb-hires-screen'; + } + + for (var i = 0; i < elements.length; i++) { + outerElement = elements[i]; + + // Set our screen resolution + outerElement.setAttribute('class', screenRes); + + //check to see if a menu/menuBar needs to be created + var menuBar = outerElement.querySelectorAll('[data-bb-type=menu]'); + if (menuBar.length > 0) { + menuBar = menuBar[0]; + bb.menuBar.apply(menuBar,outerElement); + } + + if (bb.device.isBB10) { + var titleBar = outerElement.querySelectorAll('[data-bb-type=title]'), + actionBar = outerElement.querySelectorAll('[data-bb-type=action-bar]'), + context = outerElement.querySelectorAll('[data-bb-type=context-menu]'), + outerScrollArea, + scrollArea, + tempHolder = [], + childNode = null, + j, + actionBarHeight = (bb.device.isPlayBook) ? 73 : 140, + titleBarHeight = (bb.device.isPlayBook) ? 65 : 111; + + // Figure out what to do with the title bar + if (titleBar.length > 0) { + titleBar = titleBar[0]; + } else { + titleBar = null; + } + + // Assign our action bar + if (actionBar.length > 0) { + actionBar = actionBar[0]; + outerElement.actionBar = actionBar; + } else { + actionBar = null; + } + + // Create our scrollable
+ outerScrollArea = document.createElement('div'); + outerElement.appendChild(outerScrollArea); + // Turn off scrolling effects if they don't want them + if (!outerElement.hasAttribute('data-bb-scroll-effect') || outerElement.getAttribute('data-bb-scroll-effect').toLowerCase() != 'off') { + outerElement.bbUIscrollWrapper = outerScrollArea; + } + + // Inner Scroll Area + scrollArea = document.createElement('div'); + outerScrollArea.appendChild(scrollArea); + + // Copy all nodes in the screen that are not the action bar + for (j = 0; j < outerElement.childNodes.length - 1; j++) { + childNode = outerElement.childNodes[j]; + if ((childNode != actionBar) && (childNode != menuBar) && (childNode != titleBar)) { + tempHolder.push(childNode); + } + } + // Add them into the scrollable area + for (j = 0; j < tempHolder.length -1; j++) { + scrollArea.appendChild(tempHolder[j]); + } + + // Set our outer scroll area dimensions + if (titleBar && actionBar) { + outerScrollArea.style['overflow'] = 'auto'; + outerScrollArea.style['position'] = 'absolute'; + outerScrollArea.style['bottom'] = actionBarHeight+ 'px'; + outerScrollArea.style['top'] = titleBarHeight + 'px'; + outerScrollArea.style['left'] = '0px'; + outerScrollArea.style['right'] = '0px'; + } else if (titleBar) { + outerScrollArea.style['overflow'] = 'auto'; + outerScrollArea.style['position'] = 'absolute'; + outerScrollArea.style['bottom'] = '0px'; + outerScrollArea.style['top'] = titleBarHeight + 'px'; + outerScrollArea.style['left'] = '0px'; + outerScrollArea.style['right'] = '0px'; + } else if (actionBar) { + outerScrollArea.style['overflow'] = 'auto'; + outerScrollArea.style['position'] = 'absolute'; + outerScrollArea.style['bottom'] = actionBarHeight+ 'px'; + outerScrollArea.style['top'] = '0px'; + outerScrollArea.style['left'] = '0px'; + outerScrollArea.style['right'] = '0px'; + } else { + outerScrollArea.setAttribute('style','overflow:auto;bottom:0px;position:absolute;top:0px;left:0px;right:0px;'); + outerScrollArea.style['overflow'] = 'auto'; + outerScrollArea.style['position'] = 'absolute'; + outerScrollArea.style['bottom'] = '0px'; + outerScrollArea.style['top'] = '0px'; + outerScrollArea.style['left'] = '0px'; + outerScrollArea.style['right'] = '0px'; + } + + // Apply any title bar styling + if (titleBar) { + bb.titleBar.apply(titleBar); + } + + // Apply any action Bar styling + if (actionBar) { + bb.actionBar.apply(actionBar,outerElement); + } + + // Assign our context + if (context.length > 0) { + bb.screen.processContext(context[0], outerElement); + } else { + context = null; + } + } + else if (bb.device.isPlayBook) { + var titleBar = outerElement.querySelectorAll('[data-bb-type=title]'), + outerScrollArea, + scrollArea, + tempHolder = [], + childNode = null, + j, + actionBar = outerElement.querySelectorAll('[data-bb-type=action-bar]'), + context = outerElement.querySelectorAll('[data-bb-type=context-menu]'); + + // Remove any BB10 context menus or action bars from sight + for (j = 0; j < actionBar.length; j++) { + actionBar[j].style.display = 'none'; + } + for (j = 0; j < context.length; j++) { + context[j].style.display = 'none'; + } + + if (titleBar.length > 0) { + titleBar = titleBar[0]; } + else { + titleBar = null; + } + + // Create our scrollable
+ outerScrollArea = document.createElement('div'); + outerElement.appendChild(outerScrollArea); + // Turn off scrolling effects if they don't want them + if (!outerElement.hasAttribute('data-bb-scroll-effect') || outerElement.getAttribute('data-bb-scroll-effect').toLowerCase() != 'off') { + outerElement.bbUIscrollWrapper = outerScrollArea; + } + // Inner Scroll Area + scrollArea = document.createElement('div'); + outerScrollArea.appendChild(scrollArea); + + // Copy all nodes that are not the title bar + for (j = 0; j < outerElement.childNodes.length - 1; j++) { + childNode = outerElement.childNodes[j]; + if (childNode != titleBar) { + tempHolder.push(childNode); + } + } + // Add them into the scrollable area + for (j = 0; j < tempHolder.length -1; j++) { + scrollArea.appendChild(tempHolder[j]); + } + + if (titleBar) { + outerScrollArea.style['overflow'] = 'auto'; + outerScrollArea.style['bottom'] = '0px'; + outerScrollArea.style['position'] = 'absolute'; + outerScrollArea.style['top'] = '55px'; + outerScrollArea.style['left'] = '0px'; + outerScrollArea.style['right'] = '0px'; + bb.titleBar.apply(titleBar); + } + else { + outerScrollArea.setAttribute('style','overflow:auto;bottom:0px;position:absolute;top:0px;left:0px;right:0px;'); + outerScrollArea.style['overflow'] = 'auto'; + outerScrollArea.style['bottom'] = '0px'; + outerScrollArea.style['position'] = 'absolute'; + outerScrollArea.style['top'] = '0px'; + outerScrollArea.style['left'] = '0px'; + outerScrollArea.style['right'] = '0px'; + } + } + else { + // See if there is a title bar + var titleBar = outerElement.querySelectorAll('[data-bb-type=title]'), + actionBar = outerElement.querySelectorAll('[data-bb-type=action-bar]'), + context = outerElement.querySelectorAll('[data-bb-type=context-menu]'); + + + // Remove any BB10 context menus or action bars from sight + for (j = 0; j < actionBar.length; j++) { + actionBar[j].style.display = 'none'; + } + for (j = 0; j < context.length; j++) { + context[j].style.display = 'none'; + } + + if (titleBar.length > 0) { + titleBar = titleBar[0]; + bb.titleBar.apply(titleBar); + } + } + + // Set refresh + outerElement.refresh = function() { + if (!bb.scroller) return; + bb.scroller.refresh(); + }; + outerElement.refresh = outerElement.refresh.bind(outerElement); + // Set ScrollTo + outerElement.scrollTo = function(x, y) { + if (bb.scroller) { + bb.scroller.scrollTo(x, y); + } else if (bb.device.isBB10) { + this.bbUIscrollWrapper.scrollTop = x; + } + }; + outerElement.scrollTo = outerElement.scrollTo.bind(outerElement); + // Set ScrollToElement + outerElement.scrollToElement = function(element) { + if (bb.scroller) { + bb.scroller.scrollToElement(element); + } else if (bb.device.isBB10) { + if (!element) return; + this.scrollTo(element.offsetTop); + } + }; + outerElement.scrollToElement = outerElement.scrollToElement.bind(outerElement); + } + }, + + // Process all of the context menu code + processContext : function (context, screen) { + screen.appendChild(context); + context.menu = bb.contextMenu.create(screen); + context.appendChild(context.menu); + bb.screen.contextMenu = context.menu; + // Add the actions + var actions = context.querySelectorAll('[data-bb-type=action]'), + i; + for (i = 0; i < actions.length; i++) { + context.menu.add(actions[i]); + } + context.menu.centerMenuItems(); + }, + + fadeIn: function (screen) { + // set default values + var duration = 0.3, + timing = 'ease-out', + s = screen.style; + s['-webkit-animation-name'] = 'bbUI-fade-in'; + s['-webkit-animation-duration'] = duration + 's'; + s['-webkit-animation-timing-function'] = timing; + s['-webkit-transform'] = 'translate3d(0,0,0)'; + s['-webkit-backface-visibility'] = 'hidden'; + }, + + fadeOut: function (screen) { + // set default values + var duration = 0.3, + timing = 'ease-out', + s = screen.style; + s['-webkit-animation-name'] = 'bbUI-fade-out'; + s['-webkit-animation-duration'] = duration + 's'; + s['-webkit-animation-timing-function'] = timing; + s['-webkit-transform'] = 'translate3d(0,0,0)'; + s['-webkit-backface-visibility'] = 'hidden'; + }, + + slideLeft: function (screen) { + // set default values + var r = 0, + duration = 0.3, + timing = 'ease-out', + s = screen.style; + + s.width = bb.innerWidth()+'px'; + s['-webkit-animation-name'] = 'bbUI-slide-left'; + s['-webkit-animation-duration'] = duration + 's'; + s['-webkit-animation-timing-function'] = timing; + s['-webkit-transform'] = 'translate3d(0,0,0)'; + s['-webkit-backface-visibility'] = 'hidden'; + }, + + slideOutLeft: function (screen) { + // set default values + var r = 0, + duration = 0.3, + timing = 'ease-out', + s = screen.style; + + s.width = bb.innerWidth()+'px'; + s['-webkit-animation-name'] = 'bbUI-slide-out-left'; + s['-webkit-animation-duration'] = duration + 's'; + s['-webkit-animation-timing-function'] = timing; + s['-webkit-transform'] = 'translate3d(0,0,0)'; + s['-webkit-backface-visibility'] = 'hidden'; + }, + + slideRight: function (screen) { + // set default values + var r = 0, + duration = 0.3, + timing = 'ease-out', + s = screen.style; + + s.width = bb.innerWidth()+'px'; + s['-webkit-animation-name'] = 'bbUI-slide-right'; + s['-webkit-animation-duration'] = duration + 's'; + s['-webkit-animation-timing-function'] = timing; + s['-webkit-transform'] = 'translate3d(0,0,0)'; + s['-webkit-backface-visibility'] = 'hidden'; + }, + + slideOutRight: function (screen) { + // set default values + var r = 0, + duration = 0.3, + timing = 'ease-out', + s = screen.style; + + s.width = bb.innerWidth()+'px'; + s['-webkit-animation-name'] = 'bbUI-slide-out-right'; + s['-webkit-animation-duration'] = duration + 's'; + s['-webkit-animation-timing-function'] = timing; + s['-webkit-transform'] = 'translate3d(0,0,0)'; + s['-webkit-backface-visibility'] = 'hidden'; + }, + + slideUp: function (screen) { + // set default values + var r = 0, + duration = 0.3, + timing = 'ease-out', + s = screen.style; + + s.height = bb.innerHeight()+'px'; + s['-webkit-animation-name'] = 'bbUI-slide-up'; + s['-webkit-animation-duration'] = duration + 's'; + s['-webkit-animation-timing-function'] = timing; + s['-webkit-transform'] = 'translate3d(0,0,0)'; + s['-webkit-backface-visibility'] = 'hidden'; + }, + + slideOutUp: function (screen) { + // set default values + var r = 0, + duration = 0.3, + timing = 'ease-out', + s = screen.style; + + s.height = bb.innerHeight()+'px'; + s['-webkit-animation-name'] = 'bbUI-slide-out-up'; + s['-webkit-animation-duration'] = duration + 's'; + s['-webkit-animation-timing-function'] = timing; + s['-webkit-transform'] = 'translate3d(0,0,0)'; + s['-webkit-backface-visibility'] = 'hidden'; + }, + + slideDown: function (screen) { + // set default values + var r = 0, + duration = 0.3, + timing = 'ease-out', + s = screen.style; + + s.height = bb.innerHeight()+'px'; + s['-webkit-animation-name'] = 'bbUI-slide-down'; + s['-webkit-animation-duration'] = duration + 's'; + s['-webkit-animation-timing-function'] = timing; + s['-webkit-transform'] = 'translate3d(0,0,0)'; + s['-webkit-backface-visibility'] = 'hidden'; + }, + + slideOutDown: function (screen) { + // set default values + var r = 0, + duration = 0.3, + timing = 'ease-out', + s = screen.style; + + s.height = bb.innerHeight()+'px'; + s['-webkit-animation-name'] = 'bbUI-slide-out-down'; + s['-webkit-animation-duration'] = duration + 's'; + s['-webkit-animation-timing-function'] = timing; + s['-webkit-transform'] = 'translate3d(0,0,0)'; + s['-webkit-backface-visibility'] = 'hidden'; + }, + + + reAdjustHeight: function() { + // perform device specific formatting + if (bb.device.isBB5) { + document.body.style.height = screen.height - 27 + 'px'; + } + else if (bb.device.isBB6) { + document.body.style.height = screen.height - 17 + 'px'; + } + else if (bb.device.isBB7 && (navigator.appVersion.indexOf('Ripple') < 0)) { + document.body.style.height = screen.height + 'px'; + } + } + +}; +bb.tabOverflow = { + + create : function(screen) { + var menu = document.createElement('div'), + overlay; + menu.screen = screen; + menu.itemClicked = false; + menu.visible = false; + menu.actions = []; + menu.tabOverflowState = { + display : undefined, + img : undefined, + style : undefined, + caption : undefined + }; + menu.res = (bb.device.isPlayBook) ? 'lowres' : 'hires'; + menu.setAttribute('class','bb-bb10-tab-overflow-menu bb-bb10-tab-overflow-menu-'+bb.actionBar.color); + screen.parentNode.appendChild(menu); + + if (!bb.screen.tabOverlay) { + overlay = document.createElement('div'); + overlay.menu = menu; + bb.screen.tabOverlay = overlay; + overlay.setAttribute('class','bb-bb10-tab-overflow-menu-overlay '); + screen.appendChild(overlay); + + // Hide the menu on touch + overlay.ontouchstart = function() { + this.menu.hide(); + }; + + } + menu.overlay = bb.screen.tabOverlay; + + menu.show = function() { + this.itemClicked = false; + this.visible = true; + var tabOverflowBtn = this.actionBar.tabOverflowBtn; + this.tabOverflowState.display = tabOverflowBtn.tabHighlight.style.display; + this.tabOverflowState.img = tabOverflowBtn.icon.src; + this.tabOverflowState.caption = tabOverflowBtn.display.innerHTML; + this.tabOverflowState.style = tabOverflowBtn.icon.getAttribute('class'); + this.setDimensions(); + // Reset our overflow menu button + tabOverflowBtn.reset(); + }; + menu.show = menu.show.bind(menu); + + // Adjust the dimensions of the menu and screen + menu.setDimensions = function() { + var width = (bb.device.isPlayBook) ? bb.innerWidth() - 77 : bb.innerWidth() - 154; + // Set our screen's parent to have no overflow so the browser doesn't think it needs to scroll + this.screen.parentNode.style.position = 'absolute'; + this.screen.parentNode.style.left = '0px'; + this.screen.parentNode.style.top = '0px'; + this.screen.parentNode.style.bottom = '0px'; + this.screen.parentNode.style.right = '0px'; + this.screen.parentNode.style.width = '100%'; + this.screen.parentNode.style['overflow'] = 'hidden'; + // Make our overlay visible + this.overlay.style.display = 'block'; + // Show our menu + this.style.width = width + 'px'; + this.style['-webkit-transition'] = 'all 0.2s ease-out'; + this.style['-webkit-backface-visibility'] = 'hidden'; + // Slide our screen + this.screen.style.left = width + 'px'; + this.screen.style.right = '-' + width +'px'; + this.screen.style['-webkit-transition'] = 'all 0.2s ease-out'; + this.screen.style['-webkit-backface-visibility'] = 'hidden'; + }; + menu.setDimensions = menu.setDimensions.bind(menu); + + menu.hide = function() { + this.visible = false; + // Set our sizes + this.style.width = '0px'; + this.screen.style.left = '0px'; + this.screen.style.right = '0px'; + // Make our overlay invisible + this.overlay.style.display = 'none'; + + // Re-apply the old button styling if needed + if (!this.itemClicked) { + var tabOverflowBtn = this.actionBar.tabOverflowBtn; + tabOverflowBtn.icon.setAttribute('src',this.tabOverflowState.img); + tabOverflowBtn.icon.setAttribute('class',this.tabOverflowState.style); + tabOverflowBtn.tabHighlight.style.display = this.tabOverflowState.display; + tabOverflowBtn.display.innerHTML = this.tabOverflowState.caption; + } + }; + menu.hide = menu.hide.bind(menu); + + // Hide the menu + menu.onclick = function() { + this.hide(); + }; + + // Center the items in the list + menu.centerMenuItems = function() { + var windowHeight = bb.innerHeight(), + itemHeight = (bb.device.isPlayBook) ? 53 : 111, + margin; + margin = windowHeight - Math.floor(windowHeight/2) - Math.floor((this.actions.length * itemHeight)/2) - itemHeight; //itemHeight is the header + if (margin < 0) margin = 0; + this.actions[0].style['margin-top'] = margin + 'px'; + }; + menu.centerMenuItems = menu.centerMenuItems.bind(menu); + + // Initialize any selected items + menu.initSelected = function() { + var i, + action; + for (i = 0; i < this.actions.length; i++) { + action = this.actions[i]; + if (action.initialSelected) { + action.setOverflowTab(true); + break; + } + } + }; + menu.initSelected = menu.initSelected.bind(menu); + + // Make sure we move when the orientation of the device changes + menu.orientationChanged = function(event) { + this.centerMenuItems(); + // Resize the menu if it is currently open + if (this.visible) { + this.setDimensions(); + } + }; + menu.orientationChanged = menu.orientationChanged.bind(menu); + window.addEventListener('orientationchange', menu.orientationChanged,false); + + // Create our add item function + menu.add = function(action) { + var normal, + caption = action.innerHTML, + accentTextValue = action.getAttribute('data-bb-accent-text'), + inner = document.createElement('div'), + innerClass = 'bb-bb10-tab-overflow-menu-item-inner-'+this.res, + img = document.createElement('img'), + table, tr, td; + + // set our styling + normal = 'bb-bb10-tab-overflow-menu-item-'+this.res+' bb-bb10-tab-overflow-menu-item-'+this.res+'-' + bb.actionBar.color; + this.appendChild(action); + this.actions.push(action); + // If it is the top item it needs a top border + if (this.actions.length == 1) { + normal = normal + ' bb-bb10-tab-overflow-menu-item-first-' + this.res + '-' + bb.actionBar.color; + } + // Set our inner information + action.normal = normal; + action.accentText = null; + action.menu = this; + action.caption = caption; + action.setAttribute('class',action.normal); + action.innerHTML = ''; + if (!action.visibleTab) { + action.visibleTab = action.actionBar.tabOverflowBtn; + } + // Create our layout + table = document.createElement('table'); + tr = document.createElement('tr'); + table.appendChild(tr); + action.appendChild(table); + // Add our image + td = document.createElement('td'); + img.setAttribute('src', action.getAttribute('data-bb-img')); + img.setAttribute('class','bb-bb10-tab-overflow-menu-item-image-'+this.res); + action.img = img; + td.appendChild(img); + tr.appendChild(td); + // Add our caption + td = document.createElement('td'); + inner.innerHTML = caption; + action.display = inner; + td.appendChild(inner); + // See if there is accent text + if (accentTextValue) { + action.accentText = document.createElement('div'); + action.accentText.innerHTML = accentTextValue; + action.accentText.setAttribute('class','tab-accent-text'); + td.appendChild(action.accentText); + innerClass = innerClass + ' bb-bb10-tab-overflow-menu-item-double-' + this.res; + } else { + innerClass = innerClass + ' bb-bb10-tab-overflow-menu-item-single-' + this.res; + } + // Set our styling + inner.setAttribute('class',innerClass); + tr.appendChild(td); + + //Set the overflow tab item + action.setOverflowTab = function(hightlight) { + var tabOverflowBtn = this.actionBar.tabOverflowBtn; + if (hightlight) { + bb.actionBar.highlightAction(this.visibleTab, this); + } + if (this.visibleTab == tabOverflowBtn) { + tabOverflowBtn.icon.setAttribute('src',this.img.src); + tabOverflowBtn.icon.setAttribute('class',tabOverflowBtn.icon.highlight); + tabOverflowBtn.tabHighlight.style.display = 'block'; + tabOverflowBtn.display.innerHTML = this.caption; + } + }; + action.setOverflowTab = action.setOverflowTab.bind(action); + + // See if it was selected + action.initialSelected = (action.hasAttribute('data-bb-selected') && (action.getAttribute('data-bb-selected').toLowerCase() == 'true')); + + // Trap the old click so that we can call it later + action.oldClick = action.onclick; + action.onclick = function() { + var tabOverflowBtn = this.actionBar.tabOverflowBtn; + this.menu.itemClicked = true; + bb.actionBar.highlightAction(this.visibleTab, this); + if (this.visibleTab == tabOverflowBtn) { + this.setOverflowTab(false); + } + if (this.oldClick) { + this.oldClick(); + } + }; + + // Assign the setCaption function + action.setCaption = function(value) { + this.display.innerHTML = value; + }; + action.setCaption = action.setCaption.bind(action); + + // Assign the setImage function + action.setImage = function(value) { + this.img.setAttribute('src',value); + }; + action.setImage = action.setImage.bind(action); + }; + menu.add = menu.add.bind(menu); + return menu; + } +}, +bb.titleBar = { + + apply: function(titleBar) { + + if (bb.device.isBB10) { + var res = (bb.device.isPlayBook) ? 'lowres' : 'hires', + orientation = bb.getOrientation(), + button, + caption, + titleBarClass, + details, + topTitleArea = document.createElement('div'), + img, + accentText; + + // Insert our title area + titleBar.topTitleArea = topTitleArea; + titleBar.appendChild(topTitleArea); + + // Style our title bar + + if (bb.options.coloredTitleBar) { + titleBarClass = 'bb-bb10-title-bar-'+res +' bb-bb10-title-bar-'+ orientation + '-' +res +' bb10-title-colored'; + } else { + titleBarClass = 'bb-bb10-title-bar-'+res +' bb-bb10-title-bar-'+ orientation + '-' +res +' bb-bb10-title-bar-' + bb.screen.controlColor; + } + topTitleArea.setAttribute('class', titleBarClass); + + // Set our caption + caption = document.createElement('div'); + titleBar.caption = caption; + caption.setAttribute('class','bb-bb10-title-bar-caption-'+res+ ' bb-bb10-title-bar-caption-'+ orientation+ '-'+res); + caption.innerHTML = titleBar.getAttribute('data-bb-caption'); + topTitleArea.appendChild(caption); + + // Get our back button if provided + if (titleBar.hasAttribute('data-bb-back-caption')) { + button = document.createElement('div'); + button.innerHTML = titleBar.getAttribute('data-bb-back-caption'); + topTitleArea.appendChild(button); + titleBar.backButton = button; + button.onclick = bb.popScreen; + bb.titleBar.styleBB10Button(button); + button.style.left = '0px'; + } + // Get our action button if provided + if (titleBar.hasAttribute('data-bb-action-caption')) { + button = document.createElement('div'); + button.innerHTML = titleBar.getAttribute('data-bb-action-caption'); + if (titleBar.hasAttribute('onactionclick')) { + button.titleBar = titleBar; + button.onactionclick = titleBar.getAttribute('onactionclick'); + titleBar.onactionclick = function() { + eval(this.actionButton.onactionclick); + }; + button.onclick = function() { + if (this.titleBar.onactionclick) { + this.titleBar.onactionclick(); + } + }; + } else if (titleBar.onactionclick) { + button.onclick = titleBar.onactionclick; + } + bb.titleBar.styleBB10Button(button); + button.style.right = '0px'; + topTitleArea.appendChild(button); + titleBar.actionButton = button; + } + // Create an adjustment function for the widths + if (titleBar.actionButton || titleBar.backButton) { + titleBar.evenButtonWidths = function() { + var backWidth = this.backButton ? parseInt(window.getComputedStyle(this.backButton).width) : 0, + actionWidth = this.actionButton ? parseInt(window.getComputedStyle(this.actionButton).width) : 0, + commonWidth; + + if (this.actionButton && this.backButton) { + commonWidth = (backWidth > actionWidth) ? backWidth : actionWidth; + this.backButton.style.width = commonWidth +'px'; + this.actionButton.style.width = commonWidth +'px'; + this.caption.style['margin-left'] = (commonWidth + 24) +'px'; + this.caption.style['margin-right'] = (commonWidth + 24) +'px'; + } else if (this.actionButton) { + this.caption.style['margin-left'] = '0px'; + this.caption.style['margin-right'] = (actionWidth + 24) +'px'; + } else if (this.backButton) { + this.caption.style['margin-right'] = '0px'; + this.caption.style['margin-left'] = (backWidth + 24) +'px'; + } + }; + titleBar.evenButtonWidths = titleBar.evenButtonWidths.bind(titleBar); + window.setTimeout(titleBar.evenButtonWidths,0); + } + + // Display our image ONLY if there are no title bar images + if ((!titleBar.actionButton && !titleBar.backButton) && (titleBar.hasAttribute('data-bb-img') || titleBar.hasAttribute('data-bb-accent-text'))){ + caption.setAttribute('class','bb-bb10-title-bar-caption-left-'+res); + details = document.createElement('div'); + titleBar.details = details; + topTitleArea.appendChild(details); + details.appendChild(caption); + + // First check for the image + if (titleBar.hasAttribute('data-bb-img')) { + img = document.createElement('img'); + img.src = titleBar.getAttribute('data-bb-img'); + titleBar.img = img; + topTitleArea.insertBefore(img, details); + details.setAttribute('class', 'bb-bb10-title-bar-caption-details-img-'+res); + } + // Next check for the accent text + if (titleBar.hasAttribute('data-bb-accent-text')) { + caption.style['line-height'] = bb.device.isPlayBook ? '40px' : '70px'; + accentText = document.createElement('div'); + accentText.setAttribute('class','bb-bb10-title-bar-accent-text-'+ res); + if (bb.options.coloredTitleBar) { + accentText.style.color = 'silver'; + } + titleBar.accentText = accentText; + accentText.innerHTML = titleBar.getAttribute('data-bb-accent-text'); + details.appendChild(accentText); + } + + } + + // Assign the setCaption function + titleBar.setCaption = function(value) { + this.caption.innerHTML = value; + }; + titleBar.setCaption = titleBar.setCaption.bind(titleBar); + // Assign the getCaption function + titleBar.getCaption = function() { + return this.caption.innerHTML; + }; + titleBar.getCaption = titleBar.getCaption.bind(titleBar); + // Assign the setBackCaption function + titleBar.setBackCaption = function(value) { + this.backButton.firstChild.innerHTML = value; + if (this.actionButton) { + this.backButton.style.width = ''; + this.evenButtonWidths(); + } + }; + titleBar.setBackCaption = titleBar.setBackCaption.bind(titleBar); + // Assign the getBackCaption function + titleBar.getBackCaption = function() { + return this.backButton.firstChild.innerHTML; + }; + titleBar.getBackCaption = titleBar.getBackCaption.bind(titleBar); + // Assign the setActionCaption function + titleBar.setActionCaption = function(value) { + this.actionButton.firstChild.innerHTML = value; + if (this.backButton) { + this.actionButton.style.width = ''; + this.evenButtonWidths(); + } + }; + titleBar.setActionCaption = titleBar.setActionCaption.bind(titleBar); + // Assign the getActionCaption function + titleBar.getActionCaption = function() { + return this.actionButton.firstChild.innerHTML; + }; + titleBar.getActionCaption = titleBar.getActionCaption.bind(titleBar); + + } else if (bb.device.isPlayBook) { + titleBar.setAttribute('class', 'pb-title-bar'); + titleBar.innerHTML = titleBar.getAttribute('data-bb-caption'); + if (titleBar.hasAttribute('data-bb-back-caption')) { + var button = document.createElement('div'), + buttonInner = document.createElement('div'); + button.setAttribute('class', 'pb-title-bar-back'); + button.onclick = bb.popScreen; + buttonInner.setAttribute('class','pb-title-bar-back-inner'); + buttonInner.innerHTML = titleBar.getAttribute('data-bb-back-caption'); + button.appendChild(buttonInner); + titleBar.appendChild(button); + } + } else { + if (titleBar.hasAttribute('data-bb-caption')) { + if (bb.device.isHiRes) { + titleBar.setAttribute('class', 'bb-hires-screen-title'); + } else { + titleBar.setAttribute('class', 'bb-lowres-screen-title'); + } + titleBar.innerHTML = titleBar.getAttribute('data-bb-caption'); + } + } + }, + + styleBB10Button: function(outerElement) { + var res = (bb.device.isPlayBook) ? 'lowres' : 'hires', + //disabledStyle, + innerElement = document.createElement('div'), + //disabled = outerElement.hasAttribute('data-bb-disabled'), + normal, + highlight, + outerNormal; + + if (bb.options.coloredTitleBar) { + normal = 'bb-bb10-titlebar-button bb-bb10-titlebar-button-'+res+' bb10-title-button-colored'; + highlight = 'bb-bb10-titlebar-button bb-bb10-titlebar-button-'+res+' bb10-title-button-colored-highlight'; + outerNormal = 'bb-bb10-titlebar-button-container-'+res+' bb10-title-button-container-colored'; + // Set our styles + //disabledStyle = normal + ' bb-bb10-button-disabled-'+bb.screen.controlColor; + } else { + normal = 'bb-bb10-titlebar-button bb-bb10-titlebar-button-'+res+' bb-bb10-titlebar-button-' + bb.screen.controlColor; + highlight = 'bb-bb10-titlebar-button bb-bb10-titlebar-button-'+res+' bb-bb10-titlebar-button-highlight-'+ bb.screen.controlColor; + outerNormal = 'bb-bb10-titlebar-button-container-'+res+' bb-bb10-titlebar-button-container-' + bb.screen.controlColor; + // Set our styles + //disabledStyle = normal + ' bb-bb10-button-disabled-'+bb.screen.controlColor; + } + + //outerElement.enabled = !disabled; + outerElement.enabled = true; + innerElement.innerHTML = outerElement.innerHTML; + outerElement.innerHTML = ''; + outerElement.appendChild(innerElement); + + /*if (disabled) { + outerElement.removeAttribute('data-bb-disabled'); + innerElement.setAttribute('class',disabledStyle); + } else {*/ + innerElement.setAttribute('class',normal); + //} + // Set our variables on the elements + outerElement.setAttribute('class',outerNormal); + outerElement.outerNormal = outerNormal; + outerElement.innerElement = innerElement; + innerElement.normal = normal; + innerElement.highlight = highlight; + //innerElement.disabledStyle = disabledStyle; + //if (!disabled) { + outerElement.ontouchstart = function() { + this.innerElement.setAttribute('class', this.innerElement.highlight); + }; + outerElement.ontouchend = function() { + this.innerElement.setAttribute('class', this.innerElement.normal); + }; + //} + + // Trap the click and call it only if the button is enabled + outerElement.trappedClick = outerElement.onclick; + outerElement.onclick = undefined; + if (outerElement.trappedClick !== null) { + outerElement.addEventListener('click',function (e) { + if (this.enabled) { + this.trappedClick(); + } + },false); + } + + // Assign our enable function + /* outerElement.enable = function(){ + if (this.enabled) return; + this.innerElement.setAttribute('class', this.innerElement.normal); + this.ontouchstart = function() { + this.innerElement.setAttribute('class', this.innerElement.highlight); + + }; + this.ontouchend = function() { + this.innerElement.setAttribute('class', this.innerElement.normal); + }; + this.enabled = true; + }; + // Assign our disable function + outerElement.disable = function(){ + if (!this.enabled) return; + this.innerElement.setAttribute('class', this.innerElement.disabledStyle); + this.ontouchstart = null; + this.ontouchend = null; + this.enabled = false; + };*/ + + + } +}; + +_bb10_activityIndicator = { + apply: function(elements) { + var i, + outerElement, + innerElement, + indicator, + color = bb.screen.controlColor, + res = (bb.device.isPlayBook) ? 'lowres' : 'hires', + size, + width, + swirl; + + if (elements.length > 0) { + var canvas = document.createElement('canvas'), + ctx, + lingrad; + // Create our color matched swirl + canvas.setAttribute('height','184px'); + canvas.setAttribute('width', '184px'); + ctx = canvas.getContext('2d'); + ctx.beginPath(); + ctx.moveTo(92,154); + ctx.arcTo(154,154,154,92,62); + ctx.arcTo(154,30,92,30,62); + ctx.arcTo(81,30,81,20,10); + ctx.arcTo(81,10,91,10,10); + ctx.arcTo(173,10,173,92,82); + ctx.arcTo(173,173,92,173,82); + ctx.arcTo(81,173,81,164,10); + ctx.arcTo(81,154,92,154,10); + ctx.closePath(); + ctx.strokeStyle = 'transparent'; + ctx.stroke(); + + // Create our fill color + var lingrad = ctx.createLinearGradient(0,50,0,154); + lingrad.addColorStop(0, 'transparent'); + lingrad.addColorStop(1, bb.options.highlightColor); + ctx.fillStyle = lingrad; + ctx.fill(); + + swirl = canvas.toDataURL(); + } + + for (i = 0; i < elements.length; i++) { + outerElement = elements[i]; + size = (outerElement.hasAttribute('data-bb-size')) ? outerElement.getAttribute('data-bb-size').toLowerCase() : 'medium'; + + if (size == 'large') { + width = (bb.device.isPlayBook) ? '93px' : '184px'; + } else if (size == 'small') { + width = (bb.device.isPlayBook) ? '21px' : '41px'; + } else { + size = 'medium'; + width = (bb.device.isPlayBook) ? '46px' : '93px'; + } + + outerElement.style.width = width; + // Add another div so that the developers styling on the original div is left untouched + indicator = document.createElement('div'); + indicator.setAttribute('class', 'bb-bb10-activity-margin-'+res+' bb-bb10-activity-'+size+'-'+res+' bb-activity-'+color); + outerElement.appendChild(indicator); + innerElement = document.createElement('div'); + innerElement.setAttribute('class','bb-bb10-activity-'+size+'-'+res); + innerElement.style['background-image'] = 'url("'+ swirl +'")'; + indicator.appendChild(innerElement); + + // Set our animation + innerElement.style['-webkit-animation-name'] = 'activity-rotate'; + innerElement.style['-webkit-animation-duration'] = '0.8s'; + innerElement.style['-webkit-animation-iteration-count'] = 'infinite'; + innerElement.style['-webkit-animation-timing-function'] = 'linear'; + + + // Assign our show function + outerElement.show = function(){ + this.style.display = ''; + bb.refresh(); + }; + outerElement.show = outerElement.show.bind(outerElement); + + // Assign our hide function + outerElement.hide = function(){ + this.style.display = 'none'; + bb.refresh(); + }; + outerElement.hide = outerElement.hide.bind(outerElement); + + // Assign our remove function + outerElement.remove = function(){ + this.parentNode.removeChild(this); + bb.refresh(); + }; + outerElement.remove = outerElement.remove.bind(outerElement); + + return outerElement; + } + } +} +_bb10_button = { + // Apply styling for a list of buttons + apply: function(elements) { + for (var i = 0; i < elements.length; i++) { + bb.button.style(elements[i]); + } + }, + // Style an individual button + style: function(outerElement) { + var res = (bb.device.isPlayBook) ? res = 'lowres' : 'hires', + disabledStyle, + imgSrc, + caption, + imgElement, + captionElement = document.createElement('div'), + innerElement = document.createElement('div'); + disabled = outerElement.hasAttribute('data-bb-disabled'), + normal = 'bb-bb10-button bb-bb10-button-'+res, + highlight = 'bb-bb10-button bb-bb10-button-'+res+' bb10-button-highlight', + outerNormal = 'bb-bb10-button-container-'+res+' bb-bb10-button-container-' + bb.screen.controlColor, + outerNormalWithoutImageOnly = outerNormal; + + outerElement.isImageOnly = false; + outerElement.enabled = !disabled; + caption = outerElement.innerHTML; + captionElement.innerHTML = caption; + outerElement.innerHTML = ''; + outerElement.stretched = false; + outerElement.captionElement = captionElement; + outerElement.appendChild(innerElement); + outerElement.innerElement = innerElement; + + if (outerElement.hasAttribute('data-bb-style')) { + var style = outerElement.getAttribute('data-bb-style'); + if (style == 'stretch') { + outerNormal = outerNormal + ' bb-bb10-button-stretch'; + outerElement.stretched = true; + } + } + // look for our image + imgSrc = outerElement.hasAttribute('data-bb-img') ? outerElement.getAttribute('data-bb-img') : undefined; + if (imgSrc) { + if (!caption || caption.length == 0) { + outerNormal = outerNormal + ' bb-bb10-button-container-image-only-'+res; + captionElement.style['background-image'] = 'url("'+imgSrc+'")'; + outerElement.style['line-height'] = '0px'; + captionElement.setAttribute('class','bb-bb10-button-caption-with-image-only-'+res); + outerElement.isImageOnly = true; + } else { + // Configure our caption element + captionElement.setAttribute('class','bb-bb10-button-caption-with-image-'+res); + imgElement = document.createElement('div'); + outerElement.imgElement = imgElement; + imgElement.setAttribute('class','bb-bb10-button-image-'+res); + imgElement.style['background-image'] = 'url("'+imgSrc+'")'; + innerElement.appendChild(imgElement); + } + } + // Insert caption after determining what to do with the image + innerElement.appendChild(captionElement); + + // Set our styles + disabledStyle = normal + ' bb-bb10-button-disabled-'+bb.screen.controlColor; + normal = normal + ' bb-bb10-button-' + bb.screen.controlColor; + + if (disabled) { + outerElement.removeAttribute('data-bb-disabled'); + innerElement.setAttribute('class',disabledStyle); + } else { + innerElement.setAttribute('class',normal); + } + // Set our variables on the elements + outerElement.setAttribute('class',outerNormal); + outerElement.outerNormal = outerNormal; + outerElement.outerNormalWithoutImageOnly = outerNormalWithoutImageOnly; + outerElement.innerElement = innerElement; + innerElement.normal = normal; + innerElement.highlight = highlight; + innerElement.disabledStyle = disabledStyle; + if (!disabled) { + outerElement.ontouchstart = function() { + this.innerElement.setAttribute('class', this.innerElement.highlight); + + }; + outerElement.ontouchend = function() { + this.innerElement.setAttribute('class', this.innerElement.normal); + }; + } + + // Trap the click and call it only if the button is enabled + outerElement.trappedClick = outerElement.onclick; + outerElement.onclick = undefined; + if (outerElement.trappedClick !== null) { + outerElement.addEventListener('click',function (e) { + if (this.enabled) { + this.trappedClick(); + } + },false); + } + + // Assign our set caption function + outerElement.setCaption = function(value) { + if (this.isImageOnly && (value.length > 0)) { + // Configure our caption element + this.captionElement.setAttribute('class','bb-bb10-button-caption-with-image-'+res); + var imgElement = document.createElement('div'); + this.imgElement = imgElement; + imgElement.setAttribute('class','bb-bb10-button-image-'+res); + imgElement.style['background-image'] = this.captionElement.style['background-image']; + // Remove and re-order the caption element + this.innerElement.removeChild(this.captionElement); + this.innerElement.appendChild(imgElement); + this.innerElement.appendChild(this.captionElement); + // Reset our image only styling + this.setAttribute('class',this.outerNormalWithoutImageOnly); + this.captionElement.style['background-image'] = ''; + this.isImageOnly = false; + } else if ((value.length == 0) && this.imgElement) { + this.captionElement.setAttribute('class','bb-bb10-button-caption-with-image-only-'+res); + // Reset our image only styling + this.setAttribute('class',this.outerNormalWithoutImageOnly + ' bb-bb10-button-container-image-only-'+res); + this.captionElement.style['background-image'] = this.imgElement.style['background-image']; + this.isImageOnly = true; + // Remove the image div + this.innerElement.removeChild(this.imgElement); + this.imgElement = null; + } + this.captionElement.innerHTML = value; + }; + + // Assign our set image function + outerElement.setImage = function(value) { + if (this.isImageOnly) { + this.captionElement.style['background-image'] = 'url("'+value+'")'; + } else if (this.imgElement && (value.length > 0)) { + this.imgElement.style['background-image'] = 'url("'+value+'")'; + } else if (value.length > 0){ + // Configure our caption element + this.captionElement.setAttribute('class','bb-bb10-button-caption-with-image-'+res); + var imgElement = document.createElement('div'); + this.imgElement = imgElement; + imgElement.setAttribute('class','bb-bb10-button-image-'+res); + imgElement.style['background-image'] = 'url("'+value+'")'; + // Remove and re-order the caption element + this.innerElement.removeChild(this.captionElement); + this.innerElement.appendChild(imgElement); + this.innerElement.appendChild(this.captionElement); + } else if (this.imgElement && (value.length == 0)){ + // Supplied an empty image value + this.innerElement.removeChild(this.imgElement); + this.imgElement = null; + this.captionElement.setAttribute('class',''); + } + }; + + // Assign our enable function + outerElement.enable = function(){ + if (this.enabled) return; + this.innerElement.setAttribute('class', this.innerElement.normal); + this.ontouchstart = function() { + this.innerElement.setAttribute('class', this.innerElement.highlight); + + }; + this.ontouchend = function() { + this.innerElement.setAttribute('class', this.innerElement.normal); + }; + this.enabled = true; + }; + outerElement.enable = outerElement.enable.bind(outerElement); + + // Assign our disable function + outerElement.disable = function(){ + if (!this.enabled) return; + this.innerElement.setAttribute('class', this.innerElement.disabledStyle); + this.ontouchstart = null; + this.ontouchend = null; + this.enabled = false; + }; + outerElement.disable = outerElement.disable.bind(outerElement); + + // Assign our show function + outerElement.show = function(){ + this.style.display = this.stretched ? 'block' : 'inline-block'; + bb.refresh(); + }; + outerElement.show = outerElement.show.bind(outerElement); + + // Assign our hide function + outerElement.hide = function(){ + this.style.display = 'none'; + bb.refresh(); + }; + outerElement.hide = outerElement.hide.bind(outerElement); + + // Assign our remove function + outerElement.remove = function(){ + this.parentNode.removeChild(this); + bb.refresh(); + }; + outerElement.remove = outerElement.remove.bind(outerElement); + + return outerElement; + } +}; + +_bb10_checkbox = { + apply: function(elements) { + var i, + input, + touchTarget, + outerElement, + innerElement, + checkElement, + res = (bb.device.isPlayBook) ? 'lowres' : 'hires', + color = bb.screen.controlColor; + + for (i = 0; i < elements.length; i++) { + input = elements[i]; + // Outside touch target + touchTarget = document.createElement('div'); + touchTarget.setAttribute('class','bb-bb10-checkbox-target-'+res); + input.parentNode.insertBefore(touchTarget, input); + input.style.display = 'none'; + touchTarget.appendChild(input); + touchTarget.input = input; + input.touchTarget = touchTarget; + // Main outer border of the control + outerElement = document.createElement('div'); + outerElement.setAttribute('class', 'bb-bb10-checkbox-outer-'+res+' bb-bb10-checkbox-outer-'+color); + touchTarget.appendChild(outerElement); + // Inner check area + innerElement = document.createElement('div'); + innerElement.normal = 'bb-bb10-checkbox-inner-'+res+' bb-bb10-checkbox-inner-'+color; + innerElement.setAttribute('class', innerElement.normal); + outerElement.appendChild(innerElement); + // Create our check element with the image + checkElement = document.createElement('div'); + checkElement.hiddenClass = 'bb-bb10-checkbox-check-hidden-'+res+' bb-bb10-checkbox-check-image'; + checkElement.displayClass = 'bb-bb10-checkbox-check-display-'+res+' bb-bb10-checkbox-check-image'; + checkElement.setAttribute('class',checkElement.hiddenClass); + checkElement.style['-webkit-transition-property'] = 'all'; + checkElement.style['-webkit-transition-duration'] = '0.1s'; + innerElement.appendChild(checkElement); + touchTarget.checkElement = checkElement; + + // Set our coloring for later + touchTarget.innerElement = innerElement; + touchTarget.highlight = '-webkit-linear-gradient(top, rgb('+ (bb.options.shades.R + 32) +', '+ (bb.options.shades.G + 32) +', '+ (bb.options.shades.B + 32) +') 0%, rgb('+ bb.options.shades.R +', '+ bb.options.shades.G +', '+ bb.options.shades.B +') 100%)'; + touchTarget.touchHighlight = '-webkit-linear-gradient(top, rgba('+ (bb.options.shades.R - 64) +', '+ (bb.options.shades.G - 64) +', '+ (bb.options.shades.B - 64) +',0.25) 0%, rgba('+ bb.options.shades.R +', '+ bb.options.shades.G +', '+ bb.options.shades.B +',0.25) 100%)'; + + touchTarget.ontouchstart = function() { + if (!this.input.checked && !this.input.disabled) { + // Do our touch highlight + this.innerElement.style.background = this.touchHighlight; + } + }; + touchTarget.ontouchend = function() { + if (!this.input.checked && !this.input.disabled) { + this.innerElement.style.background = ''; + } + }; + touchTarget.onclick = function() { + if (!this.input.disabled) { + var evObj = document.createEvent('HTMLEvents'); + evObj.initEvent('change', false, true ); + // Set our checked state + this.input.checked = !this.input.checked; + this.drawChecked(); + this.input.dispatchEvent(evObj); + } + }; + touchTarget.drawChecked = function() { + if (this.input.checked) { + this.checkElement.setAttribute('class',this.checkElement.displayClass); + this.innerElement.style['background-image'] = touchTarget.highlight; + } else { + this.checkElement.setAttribute('class',this.checkElement.hiddenClass); + this.innerElement.style['background-image'] = ''; + } + if (this.input.disabled){ + this.innerElement.parentNode.setAttribute('class', 'bb-bb10-checkbox-outer-'+res+' bb-bb10-checkbox-outer-disabled-'+color); + this.innerElement.setAttribute('class', 'bb-bb10-checkbox-inner-'+res+' bb-bb10-checkbox-inner-disabled-'+color); + this.innerElement.style.background = '#c0c0c0'; + } else{ + this.innerElement.parentNode.setAttribute('class', 'bb-bb10-checkbox-outer-'+res+' bb-bb10-checkbox-outer-'+color); + this.innerElement.setAttribute('class', 'bb-bb10-checkbox-inner-'+res+' bb-bb10-checkbox-inner-'+color); + } + }; + touchTarget.drawChecked = touchTarget.drawChecked.bind(touchTarget); + + // Add our set Checked function + input.setChecked = function(value) { + if (value == this.checked) return; + this.checked = value; + this.touchTarget.drawChecked(); + }; + input.setChecked = input.setChecked.bind(input); + + // Add our get Checked function + input.getChecked = function() { + return this.checked; + }; + input.getChecked = input.getChecked.bind(input); + + // Add our enable function + input.enable = function(){ + this.removeAttribute('disabled'); + this.enabled = true; + this.touchTarget.drawChecked(); + }; + input.enable = input.enable.bind(input); + + // Add our disable function + input.disable = function(){ + this.enabled = false; + this.setAttribute('disabled','disabled'); + this.touchTarget.drawChecked(); + }; + input.disable = input.disable.bind(input); + + // Add our show function + input.show = function(){ + this.touchTarget.style.display = 'block'; + bb.refresh(); + }; + input.show = input.show.bind(input); + + // Add our hide function + input.hide = function(){ + this.touchTarget.style.display = 'none'; + bb.refresh(); + }; + input.hide = input.hide.bind(input); + + // Add our remove function + input.remove = function(){ + this.touchTarget.parentNode.removeChild(this.touchTarget); + bb.refresh(); + }; + input.remove = input.remove.bind(input); + + // Set our initial state + touchTarget.drawChecked(); + } + + } +}; +_bb10_dropdown = { + // Apply our transforms to all dropdowns passed in + apply: function(elements) { + for (i = 0; i < elements.length; i++) { + bb.dropdown.style(elements[i]); + } + }, + // Apply our styling to an individual dropdown + style: function(select) { + var res = (bb.device.isPlayBook) ? 'lowres' : 'hires', + img, + i,j, + innerElement, + innerContainer, + buttonOuter, + dropdown, + labelElement, + captionElement, + itemsElement, + enabled = !select.hasAttribute('disabled'), + normal = 'bb-bb10-dropdown bb-bb10-dropdown-'+res+' bb-bb10-dropdown-' + bb.screen.controlColor + ' bb-bb10-dropdown-'+res, + highlight = 'bb-bb10-dropdown bb-bb10-dropdown-'+res+' bb-bb10-dropdown-highlight-'+ bb.screen.controlColor+ ' bb10Highlight bb-bb10-dropdown-'+res, + outerContainerStyle = 'bb-bb10-dropdown-container-'+res+' bb-bb10-dropdown-container-' + bb.screen.controlColor + ' bb-bb10-dropdown-container-'+res, + innerContainerStyle = 'bb-bb10-dropdown-container-inner-'+res+' bb-bb10-dropdown-container-inner-'+bb.screen.controlColor, + innerButtonStyle = 'bb-bb10-dropdown-inner-'+res+' bb-bb10-dropdown-inner-'+bb.screen.controlColor; + + // Make the existing +
+ +
+
Status Message
+ +
+ +
+
Personal Message
+ +
+ +
+
PPID
+ +
+ +
+
Handle
+ +
+ +
+
Application Version
+ +
+ +
+
BBM SDK Version
+ +
+ +
+
+
+
Refresh
+
Save
+
+ \ No newline at end of file