Accéder au contenu principal

editActionsForRowAtIndexPath et trailingSwipeActionsConfigurationForRowAtIndexPath

Lorsque l'on passe une application de l'iPad au Mac avec Catalyst, certaines fonctions se retrouvent deprecated. C'est le cas de editActionsForRowAtIndexPath qui permet de rajouter des bouton sous la ligne d'une table. La solution préconisée par Apple est d'utiliser trailingSwipeActionsConfigurationForRowAtIndexPath mais cette fonction est apparue avec IOS11 et mes applications fonctionne à partie de IOS9.
On doit donc mettre les deux fonctions avec des #if TARGET_OS_....

Voici un exemple de fonction qui fonctionne de IOS9 à IOS13 :

#if !TARGET_OS_MACCATALYST

- (NSArray<UITableViewRowAction *> *)tableView:(UITableView *)tableView

                  editActionsForRowAtIndexPath:(NSIndexPath *)indexPath {



    UITableViewRowAction *action_reuse =

    [UITableViewRowAction rowActionWithStyle:UITableViewRowActionStyleDefault

                                       title:@"Utiliser"

                                     handler:^(UITableViewRowAction *action,NSIndexPath *indexPath) {

                                         [self reutiliser:indexPath];

                                     }];

    action_reuse.backgroundColor = [UIColor systemTealColor];


    UITableViewRowAction *action_suppr =

    [UITableViewRowAction rowActionWithStyle:UITableViewRowActionStyleDestructive

                                       title:@"Supprimer"

                                     handler:^(UITableViewRowAction *action,NSIndexPath *indexPath) {

                                         [self supprimer:indexPath];

                                     }];

    action_suppr.backgroundColor = [UIColor systemRedColor];


    return @[ action_suppr, action_reuse ];

}

#endif


Vous remarquerez le #if !TARGET_OS_MACCATALYST au tout début.
Voici la même chose pour Mac :

#if TARGET_OS_MACCATALYST

/* UISwipeActionsConfiguration available IOS11 */

- (UISwipeActionsConfiguration *)tableView:(UITableView *)tableView

trailingSwipeActionsConfigurationForRowAtIndexPath:(NSIndexPath *)indexPath {


    NSMutableArray<UIContextualAction*>* actions = [NSMutableArray new];


    [actions addObject:[UIContextualAction

                        contextualActionWithStyle:UIContextualActionStyleNormal

                        title:@"Utiliser"

                        handler:^(UIContextualAction *action

                                  , __kindof UIView *sourceView,

                                  void(^completionHandler)(BOOL actionPerformed)){

        [self reutiliser:indexPath];

        completionHandler(true);

    }]];


    [actions addObject:[UIContextualAction

                        contextualActionWithStyle:UIContextualActionStyleDestructive

                        title:@"Supprimer"

                        handler:^(UIContextualAction *action

                                  , __kindof UIView *sourceView,

                                  void(^completionHandler)(BOOL actionPerformed)){

        [self supprimer:indexPath];

        completionHandler(true);

    }]];


    return [UISwipeActionsConfiguration configurationWithActions:actions];

}

#endif


Evidemment, si vous avez définit que votre application fonctionnerait à partir de IOS11, 12, 13 vous n'avez qu'à mettre la nouvelle version (et enlever la compilation conditionnelle).



Commentaires

Posts les plus consultés de ce blog

malloc: xzm: failed to initialize deferred reclamation buffer

Lorsque je lance une de mes applications avec Xcode sur mon iPhone .... J'ai ce message de début :  malloc: xzm: failed to initialize deferred reclamation buffer (46)  Et franchement, je n'aime pas avoir des message que je ne comprends pas et qui contiennent le mot "failed" ! Mais le message n'existe pas avec mon iPad IOS16. Donc, ok, malloc je connais, on parle de la fonction de base d'allocation de mémoire système, il y a pleins d'outils pour les problèmes d'allocation mémoire, "xzm" doit être un de ces outils. Je ne trouve rien sur internet ! RIEN ! Perplexity ou Claude ne savent pas non plus ce que c'est. Je suis obligé de faire des suppositions... XZ est un format de compression conçu pour remplacer BZIP qui est conçu pour remplacer GZIP qui est conçu pour remplacer Z. Peut-être que les données de debug de Xcode transitent en étant compressé par défaut ? Allons voir dans le schéma du projet, pour voir les options concernant les mallo...

UIMenu de UICollectionView

 Dans une UICollectionView, pour faire un menu, le plus simple est d'utiliser une des fonctions delegate standard. La création de cette fonction lancera automatiquement un gestionnaire d'appuie long, et l'affichage du menu au bon endroit. - ( UIContextMenuConfiguration *) collectionView :( UICollectionView *)collectionView   contextMenuConfigurationForItemAtIndexPath :( nonnull NSIndexPath *)indexPath point :( CGPoint )point {               return [ UIContextMenuConfiguration configurationWithIdentifier : nil          previewProvider : nil           actionProvider :^ UIMenu *( NSArray < UIMenuElement *> *suggestedActions) {            return [ UIMenu menuWithTitle : @""                           children : @[               [ UIAction actio...

Bloquer l'orientation d'une UIViewController

La gestion de l'orientation de l'iPad ou de l'iPhone a changé entre les différente version d'IOS. Avant, on pouvait utiliser la fonction shouldRotate qui bloquait la rotation... Simple. Mais cela ne fonctionne plus. Maintenant on doit forcément utiliser supportedInterfaceOrientation qui renvoie un masque des orientations supportées. Mon problème est que je ne veux pas limiter l'application à une orientation, mais que je veux que la gestion de l'orientation ne se face pas avec une UIViewController particulière. Pour cela j'ai besoin, au lancement de mon contrôleur, de sauvegarder l'orientation en cours. Avant IOS13 on utilisait UIApplication.sharedApplication.statusBarOrientation , mais avec IOS13 il peut y avoir plusieurs écrans (UIWindow) rangés par scène (UIScene). Donc statusBarOrientation est deprecated. Comme je n'utilise qu'un écran dans mon application, je récupère la scène avec UIApplication.sharedApplication.connectedScenes.anyObject , ...