License text

/*
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER 
 * Copyright  2008, 2010 Oracle and/or its affiliates.  All rights reserved. 
 * Use is subject to license terms.
 * 
 * This file is available and licensed under the following license:
 * 
 * Redistribution and use in source and binary forms, with or without 
 * modification, are permitted provided that the following conditions are met: 
 * 
 *   * Redistributions of source code must retain the above copyright notice, 
 *     this list of conditions and the following disclaimer. 
 *
 *   * Redistributions in binary form must reproduce the above copyright notice,
 *     this list of conditions and the following disclaimer in the documentation
 *     and/or other materials provided with the distribution.
 *
 *   * Neither the name of Oracle Corporation nor the names of its contributors 
 *     may be used to endorse or promote products derived from this software 
 *     without specific prior written permission. 
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 
 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 
 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 
 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
 */

    

/*
 * TitleBar.fx
 *
 * Created on Dec 22, 2009, 5:11:23 AM
 */

package fxpodcastviewer.ui.desktop;

import javafx.scene.CustomNode;
import javafx.scene.Group;
import javafx.scene.Node;
import javafx.scene.image.Image;
import javafx.scene.text.*;
import fxpodcastviewer.util.ImageButton;
import javafx.scene.shape.Line;
import javafx.stage.Stage;
import javafx.scene.Scene;
import javafx.scene.paint.Color;
import javafx.scene.shape.Rectangle;
import fxpodcastviewer.Main;

/**
 * @author raghunair
 */

public class TitleBar extends CustomNode{

    public var titleStr:String;
    var iconSize = 30;
    public var detailView:DetailView;

    var title = Text{
        translateY:30
        translateX:10
        content:bind if (titleStr == null) "Unknown" else titleStr
        font:bind Font{
            size:18
        }
        fill:Color.WHITE
    }

    var rectangle:Rectangle = Rectangle{
        width:640
        height:50
        fill:Color.TRANSPARENT
        stroke:Color.TRANSPARENT
    }

    var info = ImageButton{
        translateX:640 - iconSize - 10
        translateY:10
        normalImage:Image{ url:"{__DIR__}resources/info.png" }
        fitHeight:iconSize
        fitWidth:iconSize
        action:function(){
            detailView.show();
        }

    }

    var next = ImageButton{
        translateX:640 - (iconSize + 10)*2
        translateY:10
        normalImage:Image{ url:"{__DIR__}resources/next.png" }
        fitHeight:iconSize
        fitWidth:iconSize
        action:function(){
            Main.nextMedia();
        }

    }


    var prev = ImageButton{
        translateX:640 - (iconSize + 10)*3
        translateY:10
        normalImage:Image{ url:"{__DIR__}resources/prev.png" }
        fitHeight:iconSize
        fitWidth:iconSize
        action:function(){
            Main.prevMedia();
        }

    }


    var list = ImageButton{
        translateX:640 - (iconSize + 10)*4
        translateY:10
        normalImage:Image{ url:"{__DIR__}resources/feed.png" }
        fitHeight:iconSize
        fitWidth:iconSize
        action:function(){
            Main.list();
        }

    }


    var line:Line = Line{
        stroke:Color.GRAY
        translateY:49        
        startX:10
        startY:0
        endX:630
        endY:0
    }


    override function create():Node{
        Group{
            content: [rectangle, title,info,next,prev,list,line]
        }
    }

}

function run(){
            Stage {
                title : "MyApp"
                scene: Scene {
                        width: 640
                        height: 480
                        fill:Color.BLACK
                        content: [ TitleBar{
                                        titleStr:"Test title by Raghu Nair"
                                    
                                   }
                                 ]
                }
        }


}