Cet outil permet de donner à tous blocs multi-lignes un comportement semblable à un composant Java Swing JTable.
Dans l'application Forms, lorsque le curseur est situé dans un bloc multi-lignes, l'utilisateur peut effectuer les opérations suivantes:
Permuter les colonnes entre elles
Augmenter / réduire la largeur de chaque colonne
Trier le bloc sur n'importe quelle colonne basée (ASC/DESC)
Cet outil a été testé avec les configurations suivantes:
Forms 9i et Database 9i
Forms 10g et Database 10g
Si vous utilisez toujours une ancienne version, n'oubliez-pas que vous pouvez télécharger gratuitement (pour test uniquement) une version plus récente sur OTN.
2. Comment invoquer la palette d'options dans un bloc multi-lignes ?
Lorsque le curseur est situé dans un bloc multi-lignes, l'utilisateur peut afficher la palette d'options en double-cliquant dans une des colonnes du bloc.
Si un accélérateur clavier a été spécifié, l'utilisateur doit presser cette touche pendant le double-clic.
Si vous utilisez déjà le double-clic dans votre application pour un autre usage, vous devez définir un accélérateur clavier pour accéder à la palette d'options.
L'accélérateur est lu depuis le paramètre Forms : :PARAMETER.PM$SHIFTSTATUS
Les valeurs possibles sont les suivantes:
Shift+
Caps Lock+
Control+ (valeur par défaut)
Alt+
Command+
Super+
Hyper+
Si vous ne souhaitez pas utiliser d'accélérateur, laissez le paramètre vide.
3. Quelques copies d'écran
Dans cet exemple, l'utilisateur veut augmenter la largeur de la colonne Job.
Il (Ctrl+) double-clique dans la colonne Job...
... puis presse le bouton Increase size (+) autant de fois que nécessaire. (l'incrément est d'environ 1 caractère de large).
Aussi longtemps que la pallete d'options est affichée, l'utilisateur peut effectuer toutes les opérations sur la colonne sélectionnée.
Lorsqu'il veut revenir au bloc, il clique le bouton Cancel.
Maintenant, il veut déplacer la colonne Sal juste après la colonne Job.
Il (Ctrl+) double-clique dans la colonne Sal puis presse deux fois le bouton << Move to left.
Finalement, il souhaite trier le bloc sur la colonne Ename dans l'ordre ascendant.
Il (Ctrl+) double-clique dans la colonne Ename puis clique le bouton Set Order by ASC.
4. Les composants de l'outil
L'outil se compose des objets suivants:
Une librairie PL/SQL contenant un package ( fjtable.pll )
Une librarie d'objets contenant un groupe d'objets ( obj_fjtable.olb )
Si vous utilisez déjà le double-clic dans un trigger de niveau bloc ou item:
Positionnez la propriété du trigger: Ordre d'exécution à : Après
Assurez-vous que le paramètre PM$SHIFTSTATUS Contient un accélérateur.
Le paramètre :PARAMETER.PM$RESIZEWINDOW
Il est utilisé pour indiqué si la fenêtre peut être agrandie lorsque l'utilisateur agrandit la taille des colonnes.
La valeur par défaut de ce paramètre est : 'O'. Si vous ne souhaitez pas que la fenêtre soit agrandie à l'exécution, indiquez 'N' dans ce paramètre.
Le paramètre :PARAMETER.PM$RESIZECANVAS
Il est utilisé pour indiqué si le canevas peut être agrandi lorsque l'utilisateur agrandit la taille des colonnes.
La valeur par défaut de ce paramètre est : 'O'. Si vous ne souhaitez pas que le canevas soit agrandi à l'exécution, indiquez 'N' dans ce paramètre.
Le paramètre :PARAMETER.PM$INITIAL_VERSION
Il est utilisé pour indiqué si la forme provient d'une ancienne version (inférieure à 9i) migrée en 9i ou 10g.
La valeur par défaut de ce paramètre est : 9.
Si votre forme provient d'un procesus de migration d'une version antérieure, indiquez dans ce paramètre un chiffre inférieur à 9.
8. Traductions
Certaines chaînes de caratères peuvent être traduites dans une autre langue.
Il s'agit du libellé des boutons de la palette d'options ainsi que certains messages affichés pendant l'exécution.
Ces chaînes de caractères sont stockées dans les spécification du package PKG_JTABLE de la librairie PL/SQL.
9. Problèmes répertoriés
Les versions actuelles de Forms ne permettent pas de manipuler à l'exécutions les objets graphiques (frames).
Ne les utilisez-pas dans vos blocs multi-lignes.
Lorsque l'utilisateur agrandit la taille d'une colonne, la taille du canevas (et de la fenêtre) est automatiquent agrandie, mais pas le cadre graphique qui entoure le bloc!
Une solution est de remplacer le cadre par trait horizontal en entête du bloc.
Ordre des items dans le navigateur d'objets
Les items doivent être ordonnées selon leur coordonnée X sur le canevas
Exemple correct:
Item
Position X
Item1
50
Item2
100
Item3
140
Exemple incorrect:
Item
Position X
Item1
50
Item2
140 (cet item doit être glissé après l'item3 dans le navigateur d'objets)
Item3
100
Lorsqu'un bloc multi-lignes n'affiche pas d'ascenceur, Forms génère une erreur FRM-99999
Le problème vient de l'instruction Get_Block_Property( ..., BLOCKSCROLLBAR_X_POS ).
Si votre forme contient des blocs multi-lignes pour lesquels vous n'affichez pas d'ascenceur, modifiez le trigger de niveau form ON-ERROR ou créez le:
ON-ERROR
DeclareLN$ErrCode Number := ERROR_CODE ;
LC$ErrType VArchar(3) := ERROR_TYPE;
LC$ErrText Varchar2(256) := ERROR_TEXT ;
BeginIfLN$ErrCode = 99999 and LC$ErrText like '%1413%' Then-- Error on Get_Block_Property( ..., BLOCKSCROLLBAR_X_POS ) ---- If Block does not have Scrollbar defined --Null ;
Else
Bell ;
Message( LC$ErrType || '-' || TO_CHAR(LN$ErrCode) || ': ' || LC$ErrText);
Raise form_trigger_failure ;
Endif ;
End ;
Parce qu'il n'est pas possible d'obtenir, à l'exécution, la liste des boutons du Radio Group, ce type d'item ne peux pas être redimensionné dynamiquement.
Lorsqu'un bloc multi-lignes contient un Radio group, la palette d'options ne peut pas être invoquée.