diff --git a/README.md b/README.md
index 726e99d0..ea9b585a 100644
--- a/README.md
+++ b/README.md
@@ -1,14 +1,13 @@
[data:image/s3,"s3://crabby-images/2da80/2da803cf4dee49d97b214502c1b202c299af04be" alt="Ember Versions"](https://travis-ci.org/offirgolan/ember-light-table)
-[data:image/s3,"s3://crabby-images/e5115/e511543be5a0dd719d4506c8003d1fb089ac3441" alt="Build Status"](https://travis-ci.org/offirgolan/ember-light-table)
[data:image/s3,"s3://crabby-images/5ecf3/5ecf37c9c6e127089c2cc2d57494b3047a3b1037" alt="npm version"](http://badge.fury.io/js/ember-light-table)
[data:image/s3,"s3://crabby-images/6db03/6db03e0e24e2e5cc048520f9b390f33ac1431504" alt="Download Total"](http://badge.fury.io/js/ember-light-table)
[data:image/s3,"s3://crabby-images/5e4a4/5e4a47b47dd471270fbf6e51fa71aa5409189cf7" alt="Ember Observer Score"](https://emberobserver.com/addons/ember-light-table)
@@ -16,8 +15,9 @@
**Ember Light Table** is a lightweight contextual component based table addon that follows Ember's actions up, data down ideology.
-# WARNING
-_The API for initializing Ember Light Table (v2.x) has recently changed. Please review the [Pull Request](https://github.com/adopted-ember-addons/ember-light-table/pull/701) for more information._
+## Warning
+
+Version 3.x has significant updates including breaking changes. See the [upgrade guide](https://github.com/adopted-ember-addons/ember-light-table/master/docs/upgrade-quide.md).
## Features
diff --git a/docs/upgrade-guide.md b/docs/upgrade-guide.md
new file mode 100644
index 00000000..d1dbe08b
--- /dev/null
+++ b/docs/upgrade-guide.md
@@ -0,0 +1,111 @@
+## Upgrading to V3
+
+1. BREAKING: `ember-light-table` components no longer support positional parameters, use named parameters instead.
+
+1. BREAKING: A custom icon component is now required for sorting icons
+
+ In prior versions, the lt-head `iconComponent` parameter was optional if Font Awesome icons were used. Font Awesome and the ember-fontawesome addon no longer provide the class based icons used in ember-light-table.
+
+ If the host app uses the default Font Awesome icons duplicate the `fa-wrapper-component` used in the dummy app. The `sort`, `sort-down`, and `sort-up` Font Awesome icons are imported with the addon. 1
+
+ ```hbs
+
+
+ ```
+
+ ```hbs
+
+
+
+
+
+
+
+ ```
+ The `iconSortable`, `iconAscending` and `iconDescending` properties are now the icon names used by the icon component, not class names.
+
+ To use other Font Awesome icons add the appropiate icon pacakge (i.e. @fortawesome/free-solid-svg-icons) to your devDependencies. Depending on the icon paccage, the `FaIcon` component may need the `prefix` parameter. See `ember-fontawesome` [dcoumentation](https://www.npmjs.com/package/@fortawesome/ember-fontawesome#template).
+
+ If the comsuming app does not use the `ember-font-awesonme` addon, it can be removed from `package.json`.
+
+ 1 Icons are tree-shaken to minimize the package size
+
+1. The `ember-composable-helpers` dependency has been removed
+
+ See issue [#524](https://github.com/adopted-ember-addons/ember-light-table/issues/524). This is a breaking change if your host app depends on composable helpers and `ember-composable-helpers` is not defined in your devDependencies.
+
+ If the host app `package.json` has a yarn resolution or npm override for `ember-composable-helpers` to resolve the `'attemped to overwrite the built-in helper array'` [error](https://github.com/adopted-ember-addons/ember-light-table/issues/731), it can be removed.
+
+1. `ember-responsive` is now an addon dependency
+
+ If the host app is not using `ember-repsonsive` functionality, it can be removed from `package.json`.
+
+
+
+1. Mixins for common table functions (i.e. scrollToBottom, data loading, etc) should be converted to components.
+
+ OLD:
+
+ ```js
+ // table-common mixin
+ import Mixin from '@ember/object/mixin';
+ import Table from 'ember-light-table';
+ import { inject as service } from '@ember/service';
+
+ export default Mixin.create({
+ store: service(),
+
+ page: 0,
+ limit: 10,
+ dir: 'asc',
+ sort: 'firstName',
+ ...
+ })
+ ```
+
+ NEW:
+
+ ```js
+ // base table component
+ import Component from '@glimmer/component';
+ import Table from 'ember-light-table';
+ import { inject as service } from '@ember/service';
+ import { tracked } from '@glimmer/tracking';
+
+ export default class BaseTable extends Component {
+ @service store;
+
+ @tracked page = 0;
+ @tracked limit = 10;
+ @tracked dir = 'asc';
+ @tracked sort = 'firstName';
+ ...
+ }
+ ```
+ The `BaseTable` component in the dummy application shows a complete example.
+
+
+
+## Upgrading to v2
+
+1. The API for initializing new tables, rows and columns has changed.
+
+ ```js
+ // old methods
+ new Table(columns, rows)
+ new Row(content, options)
+ new Column(opts)
+ ```
+
+ ```js
+ // new methods
+ Table.create(columns: columns, rows: rows)
+ Row.create({ content: content })
+ Column.create(opts)
+ ```
+ Positional arguments are also no longer supported. See [this pull request](https://github.com/adopted-ember-addons/ember-light-table/pull/701) for more information.