Upgrade to ExtJS 4.0.2 - Released 06/09/2011
[extjs.git] / docs / guides / data / examples / model_with_proxy / app.js
diff --git a/docs/guides/data/examples/model_with_proxy/app.js b/docs/guides/data/examples/model_with_proxy/app.js
new file mode 100644 (file)
index 0000000..3d6959a
--- /dev/null
@@ -0,0 +1,56 @@
+/**
+ * @example Model with Proxy
+ *
+ * This example demonstrates using a {@link Ext.data.proxy.Proxy} directly on a {@link Ext.data.Model}
+ * The data is loaded and saved using a dummy rest api at url `data/users`.  You should see messages appear
+ * in your console when the data is loaded and saved.
+ * A global variable called "userStore" is created which is an instance of {@link Ext.data.Store}.
+ * Feel free to experiment with the "userStore" object on the console command line.
+ */
+Ext.define('User', {
+    extend: 'Ext.data.Model',
+    fields: ['id', 'name', 'age'],
+    proxy: {
+        type: 'rest',
+        url : 'data/users',
+        reader: {
+            type: 'json',
+            root: 'users'
+        }
+    }
+});
+
+var userStore;
+Ext.require('Ext.data.Store');
+Ext.onReady(function() {
+    // Uses the User Model's Proxy
+    userStore = Ext.create('Ext.data.Store', {
+        model: 'User',
+        autoLoad: true
+    });
+
+    // Gives us a reference to the User class
+    var User = Ext.ModelMgr.getModel('User');
+
+    var ed = Ext.create('User', {
+        name: 'Ed Spencer',
+        age : 25
+    });
+
+    // We can save Ed directly without having to add him to a Store first because we
+    // configured a RestProxy this will automatically send a POST request to the url data/users
+    ed.save({
+        success: function(ed) {
+            console.log("Saved Ed! His ID is "+ ed.getId());
+        }
+    });
+
+    // Load User 1 and do something with it (performs a GET request to /users/1)
+    User.load(1, {
+        success: function(user) {
+            console.log("Loaded user 1: " + user.get('name'));
+        }
+    });
+
+});
+