All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.hcl.domino.design.DesignElement Maven / Gradle / Ivy

/*
 * ==========================================================================
 * Copyright (C) 2019-2022 HCL America, Inc. ( http://www.hcl.com/ )
 *                            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 .
 *
 * 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.
 * ==========================================================================
 */
package com.hcl.domino.design;

import java.util.List;
import java.util.Optional;

import com.hcl.domino.admin.idvault.UserId;
import com.hcl.domino.data.Document;

/**
 * Access to forms, views, resources read/write
 *
 * @author t.b.d
 */
public interface DesignElement {
  interface NamedDesignElement extends DesignElement {
    List getAliases();

    String getTitle();

    /**
     * Sets the title of the design element.
     *
     * @param title the new element title and any aliases
     */
    void setTitle(String... title);
  }

  /**
   * This mixin interface describes a design element element that has
   * "display XPage instead" capabilities for web viewers.
   *
   * @author Jesse Gallagher
   * @since 1.0.27
   */
  interface XPageAlternativeElement extends DesignElement {
    Optional getWebXPageAlternative();
  }

  /**
   * This mixin interface describes a design element element that has
   * "display XPage instead" capabilities for Notes viewers.
   *
   * @author Jesse Gallagher
   * @since 1.0.27
   */
  interface XPageNotesAlternativeElement extends DesignElement {
    Optional getNotesXPageAlternative();
  }
  
  /**
   * This mixin interface describes a non-XPages design element that can
   * have a setting for NSF-level theme behavior.
   * 
   * @author Jesse Gallagher
   * @since 1.0.32
   */
  interface ThemeableClassicElement {
    ClassicThemeBehavior getClassicThemeBehavior();
  }
  
  /**
   * This mixin interface describes design elements that have "Auto Frame"
   * behavior available.
   * 
   * @author Jesse Gallagher
   * @since 1.0.32
   */
  interface AutoFrameElement extends DesignElement {
    /**
     * Retrieves the name of the frameset used for "Auto Frame" behavior in the
     * Notes client, if specified.
     * 
     * @return an {@link Optional} describing the auto-frame frameset name, or
     *         an empty one if this is unspecified
     */
    Optional getAutoFrameFrameset();
    /**
     * Retrieves the target frame ID used for "Auto Frame" behavior in the
     * Notes client, if specified.
     * 
     * @return an {@link Optional} describing the auto-frame target frame, or
     *         an empty one if this is unspecified
     */
    Optional getAutoFrameTarget();
  }
  
  /**
   * This mixin interface describes design elements that have an action bar
   * displayed across the top.
   * 
   * @author Jesse Gallagher
   * @since 1.0.32
   */
  interface ActionBarElement extends DesignElement {
    /**
     * Retrieves a view onto this design element's action bar and the associated
     * actions.
     * 
     * @return an {@link ActionBar} instance
     * @since 1.0.32
     */
    ActionBar getActionBar();
  }
  
  /**
   * This mixin interface describes design elements that can be restricted to specific
   * names and roles.
   * 
   * @author Jesse Gallagher
   * @since 1.0.35
   */
  interface ReadersRestrictedElement extends DesignElement {
    /**
     * Retrieves the list of users, groups, and roles allowed to access this design element.
     * 
     * @return an {@link Optional} describing the list of reader names, or an empty one
     *         if this element is not reader-restricted
     * @since 1.0.35
     */
    Optional> getReaders();
  }
  
  /**
   * Deletes the design element note from the database.
   * 
   * @since 1.1.2
   */
  void delete();
  
  /**
   * Deletes the design element note from the database.
   *
   * @param noStub whether to purge the note without leaving a deletion stub
   */
  void delete(boolean noStub);
  
  /**
   * @return the comment assigned to the design element
   * @since 1.0.24
   */
  String getComment();

  String getDesignerVersion();

  /**
   * @return the document underlying this design element
   * @since 1.0.18
   */
  Document getDocument();
  
  /**
   * Convenience method to get the UNID of the underlying design document
   * 
   * @return UNID
   * @since 1.6.7
   */
  default String getUNID() {
    return getDocument().getUNID();
  }
  
  /**
   * Convenience method to get the note ID of the underlying design document
   * 
   * @return the integer note ID
   * @since 1.6.7
   */
  default int getNoteID() {
    return getDocument().getNoteID();
  }
  
  /**
   * Retrieves the name of the note-specific template this design element
   * is set to derive from.
   * 
   * @return an {@link Optional} describing the note's template, or an empty
   *         one if this note does not derive from a distinct template
   * @since 1.1.2
   */
  Optional getTemplateName();

  boolean isHideFromMobile();

  boolean isHideFromNotes();

  boolean isHideFromWeb();

  boolean isProhibitRefresh();

  boolean save();

  /**
   * Sets a comment for the design element
   *
   * @param comment the comment to set
   * @since 1.0.24
   */
  void setComment(String comment);

  void setHideFromMobile(boolean hideFromMobile);

  void setHideFromNotes(boolean hideFromNotes);

  void setHideFromWeb(boolean hideFromWeb);

  void setProhibitRefresh(boolean prohibitRefresh);
  
  /**
   * Sets the name of the note-specific template this design element
   * should derive from.
   * 
   * @param templateName the name of the template the element should
   *                     derive from, or an empty value to un-set this
   * @since 1.1.2
   */
  void setTemplateName(String templateName);

  void sign();

  void sign(UserId id);
  
  /**
   * Determines whether the design element should be accessible to
   * sub-Reader users with Public Access rights.
   * 
   * @return {@code true} if the element should allow public access;
   *         {@code false} otherwise
   */
  boolean isAllowPublicAccess();

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy