Swipe gesture does't work when i add more items

90 views Asked by At

In my app I use swipe gesture but when I add more items my app crashes and swipe gesture doesn't work. I don't know what to do. In my view controller I have

class controller: UIViewController, UITableViewDelegate,  UITableViewDataSource {

var array = [AnyObject]()

var check = false

@IBOutlet weak var tableView: UITableView!

override func viewDidLoad() {

    super.viewDidLoad()

    var rightButton : UIBarButtonItem = UIBarButtonItem(image: UIImage(named: "edit"), style: UIBarButtonItemStyle.Done, target: self, action: "editClicked")

    self.editing = !self.editing

    rightButton.tintColor = UIColor.whiteColor()

    self.navigationItem.rightBarButtonItem = rightButton

    var leftButton : UIBarButtonItem = UIBarButtonItem(image: UIImage(named: "settings"), style: UIBarButtonItemStyle.Plain, target: self, action: "settingsClicked")

    leftButton.tintColor = UIColor.whiteColor()

    self.navigationItem.leftBarButtonItem = leftButton
}

func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

    return array.count
}

func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {

    let cell: CustomCell = tableView.dequeueReusableCellWithIdentifier("Cell") as! CustomCell

    let object = array[indexPath.row] as! NSString

    cell.editCell(object, delete: check)

    cell.button.addTarget(self, action: "deleteClicked", forControlEvents : UIControlEvents.TouchUpInside)

    return cell
}

here is the function I use to add items

func addClicked () {

    check = true

    var alert = UIAlertController(title: "add", message: "", preferredStyle: UIAlertControllerStyle.Alert)

    alert.addTextFieldWithConfigurationHandler({ (textField) -> Void in textField.text = ""

    })

    alert.addAction(UIAlertAction(title: "confirm", style: .Default, handler: { (action) -> Void in

        let textField = (alert.textFields![0] as! UITextField).text as String

        if textField != "" {

            self.array.insert(textField, atIndex: 0)

            let indexPath = NSIndexPath(forRow: 0, inSection: 0)

            self.tableView.insertRowsAtIndexPaths([indexPath], withRowAnimation: .Automatic)
        }

    }))

    alert.addAction(UIAlertAction(title: "cancel", style: .Cancel, handler: {

        (ACTION) -> Void in

    }))

   self.presentViewController(alert, animated: true, completion: nil)

   self.tableView.reloadData()
}

and

class CustomCell: UITableViewCell {

    @IBOutlet weak var label: UILabel!

    @IBOutlet weak var view: UIView!

    @IBOutlet weak var toBuy: UIImageView!

    @IBOutlet weak var atHome: UIImageView!

    @IBOutlet weak var button: UIButton!

    var gesture, check: Bool!

    override func awakeFromNib() {
        super.awakeFromNib()

        var leftSwipe = UISwipeGestureRecognizer(target: self, action: Selector("handleSwipes:"))
        var rightSwipe = UISwipeGestureRecognizer(target: self, action: Selector("handleSwipes:"))

        leftSwipe.direction = .Left
        rightSwipe.direction = .Right

        self.addGestureRecognizer(leftSwipe)
        self.addGestureRecognizer(rightSwipe)

        gesture = false;
        check = false
    }


    func handleSwipes(sender:UISwipeGestureRecognizer) {

        if (gesture == false) && (check == true){

            if (sender.direction == .Left) {

                gesture = true;

                var labelPosition = CGPointMake(self.view.frame.origin.x - 55.0, self.view.frame.origin.y);

                UIView.animateWithDuration(0.5, animations: {

                    self.view.frame = CGRectMake( labelPosition.x , labelPosition.y , self.view.frame.size.width, self.view.frame.size.height)

                }, completion: { (value: Bool) in

                    self.gesture = false;

                })
            }

            if (sender.direction == .Right) {

                gesture = true;

                var viewPosition = CGPointMake(self.view.frame.origin.x + 55.0, self.view.frame.origin.y);

                UIView.animateWithDuration(0.5, animations: {

                    self.view.frame = CGRectMake( viewPosition.x , viewPosition.y , self.view.frame.size.width, self.view.frame.size.height)

                }, completion: { (value: Bool) in

                    self.gesture = false;

                })
            }

        }
    }

    override func setSelected(selected: Bool, animated: Bool) {
        super.setSelected(selected, animated: animated)
    }
1

There are 1 answers

2
Ankit Sachan On

I see MVC violation in your code. Please add the Swipe gesture handlers to your controller instead of your View(i.e) your Custom cell.

thus handlesSwipeMethod will move to "controller"