System functions

Framework controls have functions that are called by the system at different times. Each system function calls the respective system function of the base class (TcHmiControl) via the "super" object.

PrevInit function

TypeScript:

protected __elementTemplateRoot!: JQuery;
public __previnit() {
   /** Handle template elements. Should be done before call to __previnit of super class. */
   this.__elementTemplateRoot = this.getElement().find('.TcHmi_Controls_FrameworkPrj1_FrameworkControlJs1-Template');

   /** Call __previnit of super class. */
   super.__previnit();
}

If variables (such as __elementTemplateRoot) are written with the final value in PrevInit, they do not need the type undefined. In this case the type JQuery is sufficient. To notify TypeScript that these variables are still not used uninitialized, the Definite Assignment Assertion operator must be used with an exclamation mark.

JavaScript:

__previnit() {
   /** Handle template elements. Should be done before call to __previnit of super class. */
   this.__elementTemplateRoot = this.getElement().find('.TcHmi_Controls_FrameworkPrj1_FrameworkControlJs1-Template');

   /** Call __previnit of super class. */
   super.__previnit();
}

The PrevInit function is automatically called after the system calls the constructor and before the attribute setters of each attribute are called. Accordingly, the member variables of the attributes have the value "undefined" when the PrevInit function is called. Within the PrevInit function, the references to the HMTL elements are created from the Template.html file.

System functions 1:

This function may only be called by the system and not explicitly by the developer.

Init function

TypeScript:

public __init() {
   super.__init();
}

JavaScript:

__init() {
   super.__init();
}

The Init function is called automatically by the system after the attribute setters of the individual attributes have been called. Accordingly, when the Init function is called, the member variables of the attributes already have the values that were passed to the control or defined internally as default values.

System functions 2:

This function may only be called by the system and not explicitly by the developer.

Attach function

TypeScript:

public __attach() {
   /**
   * Enable everything which was disabled while __detach function was called!
   */
   /**
   * Initialize everything which is only available while the control is part of the active dom.
   */
   /** Call base __attach function */
   super.__attach();
}

JavaScript:

__attach() {
   /**
   * Enable everything which was disabled while __detach function was called!
   */
   /**
   * Initialize everything which is only available while the control is part of the active dom.
   */
   /** Call base __attach function */
   super.__attach();
}

The Attach function is automatically called by the system after the current control instance has been added to the DOM of the HTML document. Within the Attach function, all calculations should be performed that are only available while the control instance is in the DOM (e.g. .getBoundingClientRect() of DOM elements or .width() of jQuery elements). The opposite of the Attach function is the Detach function.

System functions 3:

This function may only be called by the system and not explicitly by the developer.

Detach function

TypeScript:

public __detach() {
   /**
   * Disable everything which is not needed while the control is not part of the active dom.
   * No need to listen to events for example!
   */
   /** Call base __detach function */
   super.__detach();
}

JavaScript:

__detach() {
   /**
   * Disable everything which is not needed while the control is not part of the active dom.
   * No need to listen to events for example!
   */
   /** Call base __detach function */
   super.__detach();
}

The system automatically calls the Detach function after the current control instance has been removed from the DOM of the HTML document. In the Detach function, all functions that are no longer required after the control instance has been removed from the DOM are to be disabled. The opposite of the Detach function is the Attach function.

System functions 4:

This function may only be called by the system and not explicitly by the developer.

Destroy function

TypeScript:

public destroy() {
   if (this.__keepAlive) {
      return;
   }
   /**
   * Free resources
   */
   /** Call base __destroy function */
   super.destroy();
}

JavaScript:

destroy() {
   if (this.__keepAlive) {
      return;
   }
   /**
   * Free resources like events etc.
   */
   /** Call base __destroy function */
   super.destroy();
}

The system automatically calls the Destroy function when the control instance is no longer used (after the Detach function). If the control is on an HTML page where "Preload Partial" is enabled, the Destroy function is not called because the page is still saved in the browser cache. Within the Destroy function, the elements that were created during runtime are to be destroyed.

System functions 5:

This function can also be called explicitly (for example when child controls are destroyed).