Skip to content
ashvin777 edited this page Jul 2, 2016 · 1 revision

Welcome to the framework7.angular wiki!

Framework7.AngularJS v2.0.beta

Join the chat at https://gitter.im/ashvin777/framework7.angular

Full Featured Mobile HTML Framework For Building iOS & Android Apps with the Power of AngularJS.

Demo

http://ashvin777.github.io/framework7.angular/kitchen-sink-material/#!/home.html

Configurations

Add the below hooks into the Framework7 Project index file https://github.com/ashvin777/framework7.angular/blob/master/kitchen-sink-material/js/framework7.angular.hook.js

	<script type="text/javascript" src="../build/js/framework7.js"></script>
    <!-- Framework7 Hook for AngularJS -->
    <script type="text/javascript" src="js/framework7.angular.hook.js"></script>
    <script type="text/javascript" src="js/index.js"></script>

Then initialize the application by setting angular:true and pushState:true in options

var myApp = {};
var mainView = {};
var $$ = Dom7;

angular.module("AngularApp", [])

.run(function() {
    myApp = new Framework7({
        modalTitle: 'Framework7',
        material: true,
        pushState: true, //set it true. It will enable the hash based navigation
        angular: true //set it to true to enable angular binding in Framework pages
    });
    mainView = myApp.addView('.view-main', {});
})

After this setup, you can define the controller, directives, services, factories or provider as per your requirement. The code structure will remain same as Framework7 standard app.

Screenshots

Routing - WIP

For now use Framework7 default router http://framework7.io/docs/router-api.html

Controller

Controller can be directly assgined to the template root element. By doing so while the Framework7 will initialize the page then AngularJS hooks compiler will compile the template and bind the data based on the scrope of the controller.

So you html template should look like this

<div data-page="calendar" class="page" ng-controller="CalendarCtrl">
	...
    ...
</div>

Framework7 Template

The templates of side panels, popover, modals etc, wrap them in a element directive and add that directive in html. Like below

Side Panel

<body ng-controller="RootCtrl"  ng-cloak >
    ...
    <panel-left></panel-left>
    <panel-right></panel-right>
    ...
</body>

Directive

app.directive("panelLeft", function() {
    return {
        templateUrl: "panel-left.html"
    }
});

app.directive("panelRight", function() {
    return {
        templateUrl: "panel-right.html"
    }
});

And defind a controller in the root element of the panels template and use it as required.

Using Framework7 Components

Framework7 components can be used as it is. Inside the controller those can be initialize like below

..
.controller("CalendarCtrl", ["$scope", function($scope) {
	....
    var calendarDefault = myApp.calendar({
        input: '#ks-calendar-default',
    });
    ....
}]);

Limitation

No limitation

Contact

ashvin.suthar777@gmail.com

Licence

No License is required for this plugin.