/** * GRANITE DATA SERVICES * Copyright (C) 2006-2015 GRANITE DATA SERVICES S.A.S. * * This file is part of the Granite Data Services Platform. * * *** * * Community License: GPL 3.0 * * This file is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published * by the Free Software Foundation, either version 3 of the License, * or (at your option) any later version. * * This file is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. * * *** * * Available Commercial License: GraniteDS SLA 1.0 * * This is the appropriate option if you are creating proprietary * applications and you are not prepared to distribute and share the * source code of your application under the GPL v3 license. * * Please visit http://www.granitedataservices.com/license for more * details. */ package org.granite.client.tide; import java.util.Map; /** * SPI for platform-specific integration * * Allows to define default components available in all contexts or apply specific configurations on components annotated with {@link org.granite.client.tide.ApplicationConfigurable} * * @author William DRAI * @see org.granite.client.tide.ApplicationConfigurable */ public interface Application { /** * Define a map of beans that will be setup in the context before initialization * @param context Tide context * @param initialBeans map of bean instances keyed by name */ public void initContext(Context context, Map<String, Object> initialBeans); /** * Configure a bean instance for platform-specific behaviour * @param instance bean instance */ public void configure(Object instance); /** * Integration with deferred execution of a runnable on the UI thread * @param context context to run the UI thread * @param runnable runnable to execute in the UI thread */ public void execute(Object context, Runnable runnable); }