/*-
 * ============LICENSE_START=======================================================
 * SDC
 * ================================================================================
 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
 * ================================================================================
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ============LICENSE_END=========================================================
 */

'use strict';

export interface ISdcModalScope extends ng.IScope {
    modal:ng.ui.bootstrap.IModalServiceInstance;
    hideBackground:string;
    ok():void;
    close(result:any):void;
    cancel(reason:any):void;
}

export interface ISdcModalButton {
    name:string;
    css:string;
    disabled?:boolean;
    callback:Function;
}

export class SdcModalDirective implements ng.IDirective {

    constructor() {
    }

    scope = {
        modal: '=',
        type: '@',
        header: '@',
        headerTranslate: '@',
        headerTranslateValues: '@',
        showCloseButton: '@',
        hideBackground: '@',
        buttons: '=',
        getCloseModalResponse: '='
    };

    public replace = true;
    public restrict = 'E';
    public transclude = true;

    template = ():string => {
        return require('./sdc-modal.html');
    };

    link = (scope:ISdcModalScope, $elem:any) => {

        if (scope.hideBackground === "true") {
            $(".modal-backdrop").css('opacity', '0');
        }

        scope.close = function (result:any) {
            scope.modal.close(result);
        };

        scope.ok = function () {
            scope.modal.close();
        };

        scope.cancel = function (reason:any) {
            if (this.getCloseModalResponse)
                scope.modal.dismiss(this.getCloseModalResponse());
            else {
                scope.modal.dismiss();
            }
        };

        if (scope.modal) {
            scope.modal.result.then(function (selectedItem) {
                //$scope.selected = selectedItem;
            }, function () {
                //console.info('Modal dismissed at: ' + new Date());
            });
        }
    }

    public static factory = ()=> {
        return new SdcModalDirective();
    };

}

SdcModalDirective.factory.$inject = [];