martinmicunda/employee-scheduling-ui

View on GitHub
src/app/routes/layout-app/availability/availability.js

Summary

Maintainability
A
0 mins
Test Coverage
/**
 * @author    Martin Micunda {@link http://martinmicunda.com}
 * @copyright Copyright (c) 2015, Martin Micunda
 * @license   GPL-3.0
 */
'use strict';

import template from './availability.html!text';
import {ACCESS_LEVELS} from '../../../core/constants/constants';
import {RouteConfig, Component, View, Inject} from '../../../ng-decorators'; // jshint unused: false

//start-non-standard
@RouteConfig('app.availability', {
    url: '/availability',
    template: '<availability></availability>',
    data: {
        access: ACCESS_LEVELS.employee
    }
})
@Component({
    selector: 'availability'
})
@View({
    template: template
})
@Inject('$scope','AvailabilityService')
//end-non-standard
class Availability {
    constructor($scope, AvailabilityService) {
        this.calendarViews = [{id: 'me', label: 'My Availability'}, {id: 'everyone', label: 'Everyone\'s Availability'}];
        this.calendarView = this.calendarViews[0].id;
        this.calendarData = AvailabilityService.getCalendarData(this);
        this.calendarConfig = AvailabilityService.getCalendarConfig($scope, this.calendarViews[0].id);
        this.AvailabilityService = AvailabilityService;
        this.$scope = $scope;
    }

    toggleView(view) {
        this.calendarData = this.AvailabilityService.getCalendarData(this);
        this.calendarConfig = this.AvailabilityService.getCalendarConfig(this.$scope, view);
    }
}

export default Availability;
// !!! http://24days.in/umbraco/2014/extending-umbraco-7-backend/extend-with-angularjs-and-typescript/
// !! http://calendar.demo.title.dk/calendar/
// !! https://www.silverstripe.org/blog/managing-events-with-silverstripe-a-new-calendar-module/ --> check ORM model schema