Edit in JSFiddle

angular.module('myApp', [])
    .service('Session', function () {
    // built on login, contains information about the current user

    var user = {
        id: 81,
        firstName: 'Alec',
        lastName: 'LaLonde',
        active: true,
        joinDate: new Date(1444166612822),
        roles: [{
            name: 'Administrator',
            isAdmin: true
        }, {
            name: 'Owner'
        }]
    };
    return user;
})
    .service('UserDataService', function ($q) {
	return {
        // dummy implementation, just returns a promise resolved with the passed-in user
        save: function(user) {
            return $q.when(user);
        }
    };
})
    .service('UserModel', function ($location, UserDataService) {
    function UserModel(user) {
        angular.extend(this, user);

        this.isAdmin = this.calculateIsAdmin();
        // this could be a filter also
        this.fullName = user.firstName + " " + user.lastName;
    }

    angular.extend(UserModel.prototype, {
        persistAttrs: function() {
          	return _.pick(this, ['id', 'firstName', 'lastName', 'active', 'joinDate']);  
        },
        calculateIsAdmin: function () {
            if (!this.roles) return false;
            return _.some(this.roles, 'isAdmin');
        },
        save: function () {
            UserDataService.save(this.persistAttrs()).then(function(user) {
                $location.path('user/' + user.id);
            });
        }
    });

    return UserModel;
})
    .controller('MyCtrl', function ($scope, Session, UserModel) {
    $scope.userModel = new UserModel(Session);

    // or, e.g.
    // UserDataService.getUser(81).then(function(user) {
    //   $scope.userModel = new UserModel(user);
    // });
});
<div ng-controller="MyCtrl">
    <div class="panel panel-default">
        <div class="panel-heading">
             <h3 class="panel-title">
                 {{ userModel.fullName }}
                 <span ng-if="userModel.isAdmin" class="small pull-right badge">Administrator</span>
            </h3>

        </div>
        <div class="panel-body">
            <form name="userForm" ng-submit="userModel.save()">
                <div class="row">
                    <div class="col-xs-4">Active?</div>
                    <div class="col-xs-8">
                        <input type="checkbox" ng-model="userModel.active">
                    </div>
                </div>
                <div class="row">
                    <div class="col-xs-4">Joined on</div>
                    <div class="col-xs-8">{{ userModel.joinDate | date:'short' }}</div>
                </div>
                <div class="form-group">
                    <button type="submit" class="btn btn-primary">Save</button>
                </div>
            </form>
        </div>
    </div>
</div>
body {
    margin: 15px;
}

External resources loaded into this fiddle: