diff --git a/CHANGELOG.md b/CHANGELOG.md index c2d09347eb..788e346dee 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,86 @@ + +# [3.1.0](https://github.com/driftyco/ionic/compare/v3.0.1...v3.1.0) (2017-04-26) + + +### Steps to Upgrade + +Update your package.json to match the following dependencies, remove the existing `node_modules` directory, and then run `npm install`: + +``` +"dependencies": { + "@angular/common": "4.0.2", + "@angular/compiler": "4.0.2", + "@angular/compiler-cli": "4.0.2", + "@angular/core": "4.0.2", + "@angular/forms": "4.0.2", + "@angular/http": "4.0.2", + "@angular/platform-browser": "4.0.2", + "@angular/platform-browser-dynamic": "4.0.2", + "@ionic-native/core": "3.4.2", + "@ionic-native/splash-screen": "3.4.2", + "@ionic-native/status-bar": "3.4.2", + "@ionic/storage": "2.0.1", + "ionic-angular": "3.1.0", + "ionicons": "3.0.0", + "rxjs": "5.1.1", + "sw-toolbox": "3.4.0", + "zone.js": "^0.8.5" +}, +"devDependencies": { + "@ionic/app-scripts": "1.3.4", + "typescript": "~2.2.1" +}, +``` + + +### Bug Fixes + +* **input:** trigger inputUpdated on initialize ([5776f76](https://github.com/driftyco/ionic/commit/5776f76)) +* **input:** make sure isDisabled gets set to a boolean ([bfa2362](https://github.com/driftyco/ionic/commit/bfa2362)) +* **item-options:** rtl support ([#11188](https://github.com/driftyco/ionic/issues/11188)) ([ea6450e](https://github.com/driftyco/ionic/commit/ea6450e)) +* **menu:** rtl support ([5311336](https://github.com/driftyco/ionic/commit/5311336)) +* **menu:** rtl support ([51d5079](https://github.com/driftyco/ionic/commit/51d5079)) +* **nav-controller:** print exceptions inside lifecycle events ([95c06a5](https://github.com/driftyco/ionic/commit/95c06a5)), closes [#10974](https://github.com/driftyco/ionic/issues/10974) +* **nav-controller:** filter null view-controllers ([8605672](https://github.com/driftyco/ionic/commit/8605672)) +* **nav-controller:** queue lazy loading ([f88823a](https://github.com/driftyco/ionic/commit/f88823a)) +* **nav-controller:** fix crash when it is destroyed ([cc1eb02](https://github.com/driftyco/ionic/commit/cc1eb02)), closes [#11338](https://github.com/driftyco/ionic/issues/11338) +* **navigation:** legacy deeplink config can have a defaultHistory entry that is a component ([35f3947](https://github.com/driftyco/ionic/commit/35f3947)) +* **platform:** resize events are dispatched inside zone ([83509db](https://github.com/driftyco/ionic/commit/83509db)) +* **scroll:** fix memory leak ([3c8edba](https://github.com/driftyco/ionic/commit/3c8edba)) +* **searchbar:** debounce input for ionInput ([11a1c70](https://github.com/driftyco/ionic/commit/11a1c70)) +* **select:** stores string | string[] ([ba44780](https://github.com/driftyco/ionic/commit/ba44780)), closes [#11337](https://github.com/driftyco/ionic/issues/11337) +* **slides:** fix fast rerendering crash ([#11100](https://github.com/driftyco/ionic/issues/11100)) ([78d427d](https://github.com/driftyco/ionic/commit/78d427d)), closes [#10830](https://github.com/driftyco/ionic/issues/10830) +* **sliding-gesture:** add missing return value ([3b32b8e](https://github.com/driftyco/ionic/commit/3b32b8e)) +* **tabs:** invalid component comparison ([#11084](https://github.com/driftyco/ionic/issues/11084)) ([e423e08](https://github.com/driftyco/ionic/commit/e423e08)) +* **toggle:** use correct toggle background color for iOS colors ([b3d68c9](https://github.com/driftyco/ionic/commit/b3d68c9)) +* **util:** pass an option to default to right side in isRightSide ([7bcf5a0](https://github.com/driftyco/ionic/commit/7bcf5a0)) +* **virtual-scroll:** create views inside zone ([fd3c6ba](https://github.com/driftyco/ionic/commit/fd3c6ba)), closes [#10451](https://github.com/driftyco/ionic/issues/10451) +* **virtual-scroll:** supports null records ([67af71b](https://github.com/driftyco/ionic/commit/67af71b)) + + +### Features + +* **app:** add pull-left/right/start/end ([#11214](https://github.com/driftyco/ionic/issues/11214)) ([d9ac950](https://github.com/driftyco/ionic/commit/d9ac950)) +* **app:** add text-start and text-end ([#11213](https://github.com/driftyco/ionic/issues/11213)) ([6cd719f](https://github.com/driftyco/ionic/commit/6cd719f)) +* **app:** add responsive utility attributes by screen size ([#11228](https://github.com/driftyco/ionic/issues/11228)) ([cf24057](https://github.com/driftyco/ionic/commit/cf24057)), closes [#10567](https://github.com/driftyco/ionic/issues/10567) +* **item:** add sass variable to override avatar border radius ([b0dc856](https://github.com/driftyco/ionic/commit/b0dc856)), closes [#10763](https://github.com/driftyco/ionic/issues/10763) +* **label:** fix positioning of floating label for rtl ([#11324](https://github.com/driftyco/ionic/issues/11324)) ([0ec71cd](https://github.com/driftyco/ionic/commit/0ec71cd)) +* **list:** rtl support for list-header ([#11328](https://github.com/driftyco/ionic/issues/11328)) ([e31a4da](https://github.com/driftyco/ionic/commit/e31a4da)) +* **modal:** add cssClass to modal options ([5cb51ef](https://github.com/driftyco/ionic/commit/5cb51ef)), closes [#10020](https://github.com/driftyco/ionic/issues/10020) +* **platform:** add electron as a platform ([#10868](https://github.com/driftyco/ionic/issues/10868)) ([c0df862](https://github.com/driftyco/ionic/commit/c0df862)) +* **rtl:** add start and end text-align for alert and picker ([cb5707d](https://github.com/driftyco/ionic/commit/cb5707d)) +* **segment:** add segment rtl support ([#11215](https://github.com/driftyco/ionic/issues/11215)) ([dd0b293](https://github.com/driftyco/ionic/commit/dd0b293)) +* **select:** add popover interface as an option ([745d808](https://github.com/driftyco/ionic/commit/745d808)) + + +### Performance Improvements + +* **toggle:** css containment ([93d1d02](https://github.com/driftyco/ionic/commit/93d1d02)) +* **toggle:** events are not zoned ([bda624f](https://github.com/driftyco/ionic/commit/bda624f)) +* **toggle:** toggle's button is not activated ([17c0543](https://github.com/driftyco/ionic/commit/17c0543)) + + + ## [3.0.1](https://github.com/driftyco/ionic/compare/v3.0.0...v3.0.1) (2017-04-06) @@ -14,7 +97,7 @@ # [3.0.0](https://github.com/driftyco/ionic/compare/v2.3.0...v3.0.0) (2017-04-05) -### Steps to Upgrade +### Steps to Upgrade to 3.0 With this release comes a major update to Angular (Angular 4.0!), the latest version of TypeScript, and some optional structural changes to your application. @@ -66,7 +149,7 @@ With this release comes a major update to Angular (Angular 4.0!), the latest ver ``` import { HttpModule } from '@angular/http'; ``` - + and then add it to the imports in the same file: ``` diff --git a/demos/src/slides/pages/page-one/page-one.html b/demos/src/slides/pages/page-one/page-one.html index b4dd4f6a8f..4e67e33737 100644 --- a/demos/src/slides/pages/page-one/page-one.html +++ b/demos/src/slides/pages/page-one/page-one.html @@ -1,5 +1,5 @@ - + diff --git a/package.json b/package.json index 64c9e2e0f1..b3042d6db5 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "private": true, "name": "ionic2", - "version": "3.0.1", + "version": "3.1.0", "description": "A powerful framework for building mobile and progressive web apps with JavaScript and Angular 2", "keywords": [ "ionic", @@ -144,4 +144,4 @@ "pre-push#master": [ "test" ] -} +} \ No newline at end of file diff --git a/src/components/item/item-options.ts b/src/components/item/item-options.ts index 22cc117db7..13b86ca30c 100644 --- a/src/components/item/item-options.ts +++ b/src/components/item/item-options.ts @@ -51,7 +51,7 @@ export class ItemOptions { * @hidden */ isRightSide(): boolean { - return isRightSide(this.side, this._plt.isRTL); + return isRightSide(this.side, this._plt.isRTL, true); } /** diff --git a/src/components/label/label.ios.scss b/src/components/label/label.ios.scss index 7bb6c0f0fe..8b686b40c0 100644 --- a/src/components/label/label.ios.scss +++ b/src/components/label/label.ios.scss @@ -44,6 +44,10 @@ $label-ios-margin: $item-ios-padding-top ($item-ios-padding-right / transition: transform 150ms ease-in-out; } +[dir="rtl"] .label-ios[floating] { + transform-origin: right top; +} + .input-has-focus .label-ios[floating], .input-has-value .label-ios[floating] { transform: translate3d(0, 0, 0) scale(.8); diff --git a/src/components/label/label.md.scss b/src/components/label/label.md.scss index 2ad4403803..484e157f91 100644 --- a/src/components/label/label.md.scss +++ b/src/components/label/label.md.scss @@ -48,6 +48,10 @@ $label-md-margin: $item-md-padding-top ($item-md-padding-rig transition: transform 150ms ease-in-out; } +[dir="rtl"] .label-md[floating] { + transform-origin: right top; +} + .label-md[stacked], .label-md[floating] { margin-bottom: 0; diff --git a/src/components/label/label.wp.scss b/src/components/label/label.wp.scss index f39fc91587..ccb55ddcad 100644 --- a/src/components/label/label.wp.scss +++ b/src/components/label/label.wp.scss @@ -40,6 +40,11 @@ $label-wp-text-color-focused: color($colors-wp, primary) !default; transform-origin: left top; } +[dir="rtl"] .label-wp[floating] { + transform: translate3d(-8px, 34px, 0); + transform-origin: right top; +} + .label-wp[stacked], .label-wp[floating] { margin-bottom: 0; diff --git a/src/components/list/list.ios.scss b/src/components/list/list.ios.scss index 76bdfa848a..d36c3a6341 100644 --- a/src/components/list/list.ios.scss +++ b/src/components/list/list.ios.scss @@ -182,6 +182,10 @@ $list-ios-header-background-color: transparent !default; background: $list-ios-header-background-color; } +[dir="rtl"] .list-header-ios { + padding-right: $list-ios-header-padding-left; + padding-left: 0; +} // Generate iOS List Header Colors // -------------------------------------------------- diff --git a/src/components/list/list.md.scss b/src/components/list/list.md.scss index bed52d80b8..d4f6167ee9 100644 --- a/src/components/list/list.md.scss +++ b/src/components/list/list.md.scss @@ -168,6 +168,11 @@ $list-md-header-color: #757575 !default; color: $list-md-header-color; } +[dir="rtl"] .list-header-md { + padding-right: $list-md-header-padding-left; + padding-left: 0; +} + // Generate Material Design List Header Colors // -------------------------------------------------- diff --git a/src/components/list/list.wp.scss b/src/components/list/list.wp.scss index 64593d5680..84f952c33c 100644 --- a/src/components/list/list.wp.scss +++ b/src/components/list/list.wp.scss @@ -165,6 +165,11 @@ $list-wp-header-color: $list-wp-text-color !default; color: $list-wp-header-color; } +[dir="rtl"] .list-header-wp { + padding-right: $list-wp-header-padding-left; + padding-left: 0; +} + // Generate Windows List Header Colors // -------------------------------------------------- diff --git a/src/components/searchbar/searchbar.ts b/src/components/searchbar/searchbar.ts index 1d63188be8..0234eb67d9 100644 --- a/src/components/searchbar/searchbar.ts +++ b/src/components/searchbar/searchbar.ts @@ -4,6 +4,7 @@ import { NgControl } from '@angular/forms'; import { Config } from '../../config/config'; import { BaseInput } from '../../util/base-input'; import { isPresent, isTrueProperty } from '../../util/util'; +import { TimeoutDebouncer } from '../../util/debouncer'; import { Platform } from '../../platform/platform'; /** @@ -63,6 +64,7 @@ export class Searchbar extends BaseInput { _isActive: boolean = false; _showCancelButton: boolean = false; _animated: boolean = false; + _inputDebouncer: TimeoutDebouncer = new TimeoutDebouncer(0); /** * @input {string} Set the the cancel button text. Default: `"Cancel"`. @@ -89,6 +91,7 @@ export class Searchbar extends BaseInput { } set debounce(val: number) { this._debouncer.wait = val; + this._inputDebouncer.wait = val; } /** @@ -288,7 +291,9 @@ export class Searchbar extends BaseInput { */ inputChanged(ev: any) { this.value = ev.target.value; - this.ionInput.emit(ev); + this._inputDebouncer.debounce(() => { + this.ionInput.emit(ev); + }); } /** diff --git a/src/components/select/select.ts b/src/components/select/select.ts index b5d4acfaba..19da56ae24 100644 --- a/src/components/select/select.ts +++ b/src/components/select/select.ts @@ -147,12 +147,13 @@ import { SelectPopover, SelectPopoverOption } from './select-popover-component'; providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: Select, multi: true } ], encapsulation: ViewEncapsulation.None, }) -export class Select extends BaseInput implements AfterViewInit, OnDestroy { +export class Select extends BaseInput implements AfterViewInit, OnDestroy { _multi: boolean = false; _options: QueryList