Repository: lemanhtien/MTSlideToOpen
Branch: master
Commit: c127000a143e
Files: 16
Total size: 43.1 KB
Directory structure:
gitextract_dmy5_76p/
├── .gitignore
├── .swift-version
├── LICENSE
├── MTSlideToOpen/
│ ├── AppDelegate.swift
│ ├── Assets.xcassets/
│ │ ├── AppIcon.appiconset/
│ │ │ └── Contents.json
│ │ ├── Contents.json
│ │ └── ic_arrow.imageset/
│ │ └── Contents.json
│ ├── Base.lproj/
│ │ ├── LaunchScreen.storyboard
│ │ └── Main.storyboard
│ ├── Info.plist
│ └── ViewController.swift
├── MTSlideToOpen.podspec
├── MTSlideToOpen.xcodeproj/
│ ├── project.pbxproj
│ └── project.xcworkspace/
│ └── contents.xcworkspacedata
├── README.md
└── Source/
└── MTSlideToOpenView.swift
================================================
FILE CONTENTS
================================================
================================================
FILE: .gitignore
================================================
## Build generated
build/
DerivedData
build.xcarchive
## Various settings
*.pbxuser
!default.pbxuser
*.mode1v3
!default.mode1v3
*.mode2v3
!default.mode2v3
*.perspectivev3
!default.perspectivev3
xcuserdata
## Other
*.xccheckout
*.moved-aside
*.xcuserstate
*.xcscmblueprint
## Obj-C/Swift specific
*.hmap
*.ipa
# CocoaPods
Pods/
# Carthage
Carthage/Checkouts
Carthage/Build
================================================
FILE: .swift-version
================================================
5.0
================================================
FILE: LICENSE
================================================
The MIT License (MIT)
Copyright (c) 2017 Tien Le
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
================================================
FILE: MTSlideToOpen/AppDelegate.swift
================================================
//
// AppDelegate.swift
// MTSlideToOpen
//
// Created by Martin Lee on 10/12/17.
// Copyright © 2017 Martin Le. All rights reserved.
//
import UIKit
@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {
var window: UIWindow?
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
// Override point for customization after application launch.
return true
}
func applicationWillResignActive(_ application: UIApplication) {
// Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state.
// Use this method to pause ongoing tasks, disable timers, and invalidate graphics rendering callbacks. Games should use this method to pause the game.
}
func applicationDidEnterBackground(_ application: UIApplication) {
// Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later.
// If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits.
}
func applicationWillEnterForeground(_ application: UIApplication) {
// Called as part of the transition from the background to the active state; here you can undo many of the changes made on entering the background.
}
func applicationDidBecomeActive(_ application: UIApplication) {
// Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface.
}
func applicationWillTerminate(_ application: UIApplication) {
// Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:.
}
}
================================================
FILE: MTSlideToOpen/Assets.xcassets/AppIcon.appiconset/Contents.json
================================================
{
"images" : [
{
"idiom" : "iphone",
"size" : "20x20",
"scale" : "2x"
},
{
"idiom" : "iphone",
"size" : "20x20",
"scale" : "3x"
},
{
"idiom" : "iphone",
"size" : "29x29",
"scale" : "2x"
},
{
"idiom" : "iphone",
"size" : "29x29",
"scale" : "3x"
},
{
"idiom" : "iphone",
"size" : "40x40",
"scale" : "2x"
},
{
"idiom" : "iphone",
"size" : "40x40",
"scale" : "3x"
},
{
"idiom" : "iphone",
"size" : "60x60",
"scale" : "2x"
},
{
"idiom" : "iphone",
"size" : "60x60",
"scale" : "3x"
},
{
"idiom" : "ipad",
"size" : "20x20",
"scale" : "1x"
},
{
"idiom" : "ipad",
"size" : "20x20",
"scale" : "2x"
},
{
"idiom" : "ipad",
"size" : "29x29",
"scale" : "1x"
},
{
"idiom" : "ipad",
"size" : "29x29",
"scale" : "2x"
},
{
"idiom" : "ipad",
"size" : "40x40",
"scale" : "1x"
},
{
"idiom" : "ipad",
"size" : "40x40",
"scale" : "2x"
},
{
"idiom" : "ipad",
"size" : "76x76",
"scale" : "1x"
},
{
"idiom" : "ipad",
"size" : "76x76",
"scale" : "2x"
},
{
"idiom" : "ipad",
"size" : "83.5x83.5",
"scale" : "2x"
},
{
"idiom" : "ios-marketing",
"size" : "1024x1024",
"scale" : "1x"
}
],
"info" : {
"version" : 1,
"author" : "xcode"
}
}
================================================
FILE: MTSlideToOpen/Assets.xcassets/Contents.json
================================================
{
"info" : {
"version" : 1,
"author" : "xcode"
}
}
================================================
FILE: MTSlideToOpen/Assets.xcassets/ic_arrow.imageset/Contents.json
================================================
{
"images" : [
{
"idiom" : "universal",
"scale" : "1x"
},
{
"idiom" : "universal",
"filename" : "ic_arrow.png",
"scale" : "2x"
},
{
"idiom" : "universal",
"scale" : "3x"
}
],
"info" : {
"version" : 1,
"author" : "xcode"
}
}
================================================
FILE: MTSlideToOpen/Base.lproj/LaunchScreen.storyboard
================================================
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="13122.16" systemVersion="17A277" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" launchScreen="YES" useTraitCollections="YES" useSafeAreas="YES" colorMatched="YES" initialViewController="01J-lp-oVM">
<dependencies>
<plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="13104.12"/>
<capability name="Safe area layout guides" minToolsVersion="9.0"/>
<capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
</dependencies>
<scenes>
<!--View Controller-->
<scene sceneID="EHf-IW-A2E">
<objects>
<viewController id="01J-lp-oVM" sceneMemberID="viewController">
<view key="view" contentMode="scaleToFill" id="Ze5-6b-2t3">
<rect key="frame" x="0.0" y="0.0" width="375" height="667"/>
<autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
<color key="backgroundColor" red="1" green="1" blue="1" alpha="1" colorSpace="custom" customColorSpace="sRGB"/>
<viewLayoutGuide key="safeArea" id="6Tk-OE-BBY"/>
</view>
</viewController>
<placeholder placeholderIdentifier="IBFirstResponder" id="iYj-Kq-Ea1" userLabel="First Responder" sceneMemberID="firstResponder"/>
</objects>
<point key="canvasLocation" x="53" y="375"/>
</scene>
</scenes>
</document>
================================================
FILE: MTSlideToOpen/Base.lproj/Main.storyboard
================================================
<?xml version="1.0" encoding="UTF-8"?>
<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="13196" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" useTraitCollections="YES" useSafeAreas="YES" colorMatched="YES" initialViewController="BYZ-38-t0r">
<device id="retina4_7" orientation="portrait">
<adaptation id="fullscreen"/>
</device>
<dependencies>
<plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="13173"/>
<capability name="Safe area layout guides" minToolsVersion="9.0"/>
<capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
</dependencies>
<scenes>
<!--View Controller-->
<scene sceneID="tne-QT-ifu">
<objects>
<viewController id="BYZ-38-t0r" customClass="ViewController" customModule="MTSlideToOpen" customModuleProvider="target" sceneMemberID="viewController">
<view key="view" contentMode="scaleToFill" id="8bC-Xf-vdC">
<rect key="frame" x="0.0" y="0.0" width="375" height="667"/>
<autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
<color key="backgroundColor" red="1" green="1" blue="1" alpha="1" colorSpace="calibratedRGB"/>
<viewLayoutGuide key="safeArea" id="6Tk-OE-BBY"/>
</view>
</viewController>
<placeholder placeholderIdentifier="IBFirstResponder" id="dkx-z0-nzr" sceneMemberID="firstResponder"/>
</objects>
</scene>
</scenes>
</document>
================================================
FILE: MTSlideToOpen/Info.plist
================================================
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>CFBundleDevelopmentRegion</key>
<string>$(DEVELOPMENT_LANGUAGE)</string>
<key>CFBundleExecutable</key>
<string>$(EXECUTABLE_NAME)</string>
<key>CFBundleIdentifier</key>
<string>$(PRODUCT_BUNDLE_IDENTIFIER)</string>
<key>CFBundleInfoDictionaryVersion</key>
<string>6.0</string>
<key>CFBundleName</key>
<string>$(PRODUCT_NAME)</string>
<key>CFBundlePackageType</key>
<string>APPL</string>
<key>CFBundleShortVersionString</key>
<string>1.0</string>
<key>CFBundleVersion</key>
<string>1</string>
<key>LSRequiresIPhoneOS</key>
<true/>
<key>UILaunchStoryboardName</key>
<string>LaunchScreen</string>
<key>UIMainStoryboardFile</key>
<string>Main</string>
<key>UIRequiredDeviceCapabilities</key>
<array>
<string>armv7</string>
</array>
<key>UISupportedInterfaceOrientations</key>
<array>
<string>UIInterfaceOrientationPortrait</string>
<string>UIInterfaceOrientationLandscapeLeft</string>
<string>UIInterfaceOrientationLandscapeRight</string>
</array>
<key>UISupportedInterfaceOrientations~ipad</key>
<array>
<string>UIInterfaceOrientationPortrait</string>
<string>UIInterfaceOrientationPortraitUpsideDown</string>
<string>UIInterfaceOrientationLandscapeLeft</string>
<string>UIInterfaceOrientationLandscapeRight</string>
</array>
</dict>
</plist>
================================================
FILE: MTSlideToOpen/ViewController.swift
================================================
//
// ViewController.swift
// MTSlideToOpen
//
// Created by Martin Lee on 10/12/17.
// Copyright © 2017 Martin Le. All rights reserved.
//
import UIKit
class ViewController: UIViewController, MTSlideToOpenDelegate {
lazy var slideToOpen: MTSlideToOpenView = {
let slide = MTSlideToOpenView(frame: CGRect(x: 26, y: 100, width: 317, height: 56))
slide.sliderViewTopDistance = 0
slide.sliderCornerRadius = 28
slide.showSliderText = true
slide.thumbnailColor = UIColor(red:141.0/255, green:19.0/255, blue:65.0/255, alpha:1.0)
slide.slidingColor = UIColor.red
slide.textColor = UIColor.orange
slide.sliderBackgroundColor = UIColor(red:0.88, green:1, blue:0.98, alpha:1.0)
slide.delegate = self
slide.thumnailImageView.image = #imageLiteral(resourceName: "ic_arrow").imageFlippedForRightToLeftLayoutDirection()
return slide
}()
lazy var slideToLock: MTSlideToOpenView = {
let slide = MTSlideToOpenView(frame: CGRect(x: 26, y: 200, width: 317, height: 56))
slide.sliderViewTopDistance = 0
slide.sliderCornerRadius = 28
slide.thumnailImageView.backgroundColor = UIColor(red:200.0/255, green:200.0/255, blue:200.0/255, alpha:1.0)
slide.draggedView.backgroundColor = UIColor(red:200.0/255, green:200.0/255, blue:200.0/255, alpha:1.0)
slide.delegate = self
slide.thumbnailViewStartingDistance = 20
slide.labelText = "Slide To Lock"
slide.thumnailImageView.image = #imageLiteral(resourceName: "ic_arrow").imageFlippedForRightToLeftLayoutDirection()
return slide
}()
lazy var customizeSlideToOpen: MTSlideToOpenView = {
let slide = MTSlideToOpenView(frame: CGRect(x: 26, y: 300, width: 317, height: 56))
slide.sliderViewTopDistance = 0
slide.thumbnailViewTopDistance = 4;
slide.thumbnailViewStartingDistance = 4;
slide.sliderCornerRadius = 28
slide.thumnailImageView.backgroundColor = .white
slide.draggedView.backgroundColor = .clear
slide.delegate = self
slide.thumnailImageView.image = #imageLiteral(resourceName: "ic_arrow").imageFlippedForRightToLeftLayoutDirection()
slide.sliderBackgroundColor = .black
return slide
}()
lazy var slideToUnlock: MTSlideToOpenView = {
let frame = CGRect(x: 26, y: 400, width: 317, height: 56)
let slide = MTSlideToOpenView(frame: frame)
slide.sliderViewTopDistance = 6
slide.sliderCornerRadius = 22
slide.delegate = self
slide.labelText = "Slide To Unlock"
slide.thumnailImageView.image = #imageLiteral(resourceName: "ic_arrow").imageFlippedForRightToLeftLayoutDirection()
slide.animationChangedEnabledBlock = { isEnabled in
if isEnabled {
slide.thumnailImageView.backgroundColor = slide.thumbnailColor
slide.draggedView.isHidden = false
slide.thumnailImageView.backgroundColor = slide.sliderBackgroundColor
slide.textLabel.text = slide.labelText
slide.thumnailImageView.layer.shadowOpacity = 0
} else {
slide.thumnailImageView.backgroundColor = UIColor(red:210.0/255, green:219.0/255, blue:228.0/255, alpha:0.8)
slide.thumnailImageView.layer.shadowColor = UIColor(red:0/255, green:0/255, blue:0/255, alpha:0.2).cgColor
slide.thumnailImageView.layer.shadowOffset = CGSize(width: 0, height: 25)
slide.thumnailImageView.layer.shadowRadius = 28
slide.thumnailImageView.layer.shadowOpacity = 1
slide.draggedView.isHidden = true
slide.sliderHolderView.backgroundColor = UIColor(red:245.0/255, green:247.0/255, blue:250.0/255, alpha:1)
slide.textLabel.text = ""
}
}
slide.isEnabled = false
return slide
}()
override func viewDidLoad() {
super.viewDidLoad()
self.view.addSubview(slideToOpen)
self.view.addSubview(slideToUnlock)
self.view.addSubview(customizeSlideToOpen)
self.view.addSubview(slideToLock)
}
// MARK: MTSlideToOpenDelegate
func mtSlideToOpenDelegateDidFinish(_ sender: MTSlideToOpenView) {
let alertController = UIAlertController(title: "", message: "Done!", preferredStyle: .alert)
let doneAction = UIAlertAction(title: "Okay", style: .default) { (action) in
sender.resetStateWithAnimation(false)
}
alertController.addAction(doneAction)
self.present(alertController, animated: true, completion: nil)
}
}
================================================
FILE: MTSlideToOpen.podspec
================================================
Pod::Spec.new do |s|
# ――― Spec Metadata ―――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
#
s.name = "MTSlideToOpen"
s.version = "1.5.1"
s.summary = "A simple SlideToUnlock iOS UI component."
s.description = "A simple iOS UI component acts Slide To Unlock."
s.homepage = "https://github.com/lemanhtien/MTSlideToOpen"
s.screenshots = "https://raw.githubusercontent.com/lemanhtien/MTSlideToOpen/master/Screenshot.png"
# ――― Spec License ――――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
#
s.license = { :type => "MIT", :file => "LICENSE" }
# ――― Author Metadata ――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
#
s.author = { "Tien Le" => "lemanhtien.bka@gmail.com" }
s.social_media_url = "https://twitter.com/Martin_ManhTien"
# ――― Platform Specifics ――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
#
# If this Pod runs only on iOS or OS X, then specify the platform and
# the deployment target. You can optionally include the target after the platform.
#
s.platform = :ios, "9.0"
# ――― Source Location ―――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
#
s.source = { :git => "https://github.com/lemanhtien/MTSlideToOpen.git", :tag => s.version }
# ――― Source Code ―――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
#
s.source_files = "Source"
s.framework = "UIKit"
s.pod_target_xcconfig = { "SWIFT_VERSION" => "5.0" }
s.swift_version = '5.0'
s.requires_arc = true
end
================================================
FILE: MTSlideToOpen.xcodeproj/project.pbxproj
================================================
// !$*UTF8*$!
{
archiveVersion = 1;
classes = {
};
objectVersion = 48;
objects = {
/* Begin PBXBuildFile section */
BD0B6A0F1F8F4E1200D3AC94 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = BD0B6A0E1F8F4E1200D3AC94 /* AppDelegate.swift */; };
BD0B6A111F8F4E1200D3AC94 /* ViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = BD0B6A101F8F4E1200D3AC94 /* ViewController.swift */; };
BD0B6A141F8F4E1200D3AC94 /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = BD0B6A121F8F4E1200D3AC94 /* Main.storyboard */; };
BD0B6A161F8F4E1200D3AC94 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = BD0B6A151F8F4E1200D3AC94 /* Assets.xcassets */; };
BD0B6A191F8F4E1200D3AC94 /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = BD0B6A171F8F4E1200D3AC94 /* LaunchScreen.storyboard */; };
BD392E561F8F5835005F0194 /* MTSlideToOpenView.swift in Sources */ = {isa = PBXBuildFile; fileRef = BD392E551F8F5835005F0194 /* MTSlideToOpenView.swift */; };
/* End PBXBuildFile section */
/* Begin PBXFileReference section */
BD0B6A0B1F8F4E1200D3AC94 /* MTSlideToOpen.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = MTSlideToOpen.app; sourceTree = BUILT_PRODUCTS_DIR; };
BD0B6A0E1F8F4E1200D3AC94 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = "<group>"; };
BD0B6A101F8F4E1200D3AC94 /* ViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewController.swift; sourceTree = "<group>"; };
BD0B6A131F8F4E1200D3AC94 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = "<group>"; };
BD0B6A151F8F4E1200D3AC94 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
BD0B6A181F8F4E1200D3AC94 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = "<group>"; };
BD0B6A1A1F8F4E1200D3AC94 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
BD392E551F8F5835005F0194 /* MTSlideToOpenView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MTSlideToOpenView.swift; sourceTree = "<group>"; };
/* End PBXFileReference section */
/* Begin PBXFrameworksBuildPhase section */
BD0B6A081F8F4E1200D3AC94 /* Frameworks */ = {
isa = PBXFrameworksBuildPhase;
buildActionMask = 2147483647;
files = (
);
runOnlyForDeploymentPostprocessing = 0;
};
/* End PBXFrameworksBuildPhase section */
/* Begin PBXGroup section */
BD0B6A021F8F4E1200D3AC94 = {
isa = PBXGroup;
children = (
BD0B6A0D1F8F4E1200D3AC94 /* MTSlideToOpen */,
BD0B6A0C1F8F4E1200D3AC94 /* Products */,
);
sourceTree = "<group>";
};
BD0B6A0C1F8F4E1200D3AC94 /* Products */ = {
isa = PBXGroup;
children = (
BD0B6A0B1F8F4E1200D3AC94 /* MTSlideToOpen.app */,
);
name = Products;
sourceTree = "<group>";
};
BD0B6A0D1F8F4E1200D3AC94 /* MTSlideToOpen */ = {
isa = PBXGroup;
children = (
BD392E541F8F5790005F0194 /* Source */,
BD0B6A0E1F8F4E1200D3AC94 /* AppDelegate.swift */,
BD0B6A101F8F4E1200D3AC94 /* ViewController.swift */,
BD0B6A121F8F4E1200D3AC94 /* Main.storyboard */,
BD0B6A151F8F4E1200D3AC94 /* Assets.xcassets */,
BD0B6A171F8F4E1200D3AC94 /* LaunchScreen.storyboard */,
BD0B6A1A1F8F4E1200D3AC94 /* Info.plist */,
);
path = MTSlideToOpen;
sourceTree = "<group>";
};
BD392E541F8F5790005F0194 /* Source */ = {
isa = PBXGroup;
children = (
BD392E551F8F5835005F0194 /* MTSlideToOpenView.swift */,
);
path = Source;
sourceTree = SOURCE_ROOT;
};
/* End PBXGroup section */
/* Begin PBXNativeTarget section */
BD0B6A0A1F8F4E1200D3AC94 /* MTSlideToOpen */ = {
isa = PBXNativeTarget;
buildConfigurationList = BD0B6A1D1F8F4E1200D3AC94 /* Build configuration list for PBXNativeTarget "MTSlideToOpen" */;
buildPhases = (
BD0B6A071F8F4E1200D3AC94 /* Sources */,
BD0B6A081F8F4E1200D3AC94 /* Frameworks */,
BD0B6A091F8F4E1200D3AC94 /* Resources */,
);
buildRules = (
);
dependencies = (
);
name = MTSlideToOpen;
productName = MTSlideToOpen;
productReference = BD0B6A0B1F8F4E1200D3AC94 /* MTSlideToOpen.app */;
productType = "com.apple.product-type.application";
};
/* End PBXNativeTarget section */
/* Begin PBXProject section */
BD0B6A031F8F4E1200D3AC94 /* Project object */ = {
isa = PBXProject;
attributes = {
LastSwiftUpdateCheck = 0900;
LastUpgradeCheck = 1000;
ORGANIZATIONNAME = "Martin Le";
TargetAttributes = {
BD0B6A0A1F8F4E1200D3AC94 = {
CreatedOnToolsVersion = 9.0;
LastSwiftMigration = 1000;
ProvisioningStyle = Automatic;
};
};
};
buildConfigurationList = BD0B6A061F8F4E1200D3AC94 /* Build configuration list for PBXProject "MTSlideToOpen" */;
compatibilityVersion = "Xcode 8.0";
developmentRegion = en;
hasScannedForEncodings = 0;
knownRegions = (
en,
Base,
);
mainGroup = BD0B6A021F8F4E1200D3AC94;
productRefGroup = BD0B6A0C1F8F4E1200D3AC94 /* Products */;
projectDirPath = "";
projectRoot = "";
targets = (
BD0B6A0A1F8F4E1200D3AC94 /* MTSlideToOpen */,
);
};
/* End PBXProject section */
/* Begin PBXResourcesBuildPhase section */
BD0B6A091F8F4E1200D3AC94 /* Resources */ = {
isa = PBXResourcesBuildPhase;
buildActionMask = 2147483647;
files = (
BD0B6A191F8F4E1200D3AC94 /* LaunchScreen.storyboard in Resources */,
BD0B6A161F8F4E1200D3AC94 /* Assets.xcassets in Resources */,
BD0B6A141F8F4E1200D3AC94 /* Main.storyboard in Resources */,
);
runOnlyForDeploymentPostprocessing = 0;
};
/* End PBXResourcesBuildPhase section */
/* Begin PBXSourcesBuildPhase section */
BD0B6A071F8F4E1200D3AC94 /* Sources */ = {
isa = PBXSourcesBuildPhase;
buildActionMask = 2147483647;
files = (
BD0B6A111F8F4E1200D3AC94 /* ViewController.swift in Sources */,
BD392E561F8F5835005F0194 /* MTSlideToOpenView.swift in Sources */,
BD0B6A0F1F8F4E1200D3AC94 /* AppDelegate.swift in Sources */,
);
runOnlyForDeploymentPostprocessing = 0;
};
/* End PBXSourcesBuildPhase section */
/* Begin PBXVariantGroup section */
BD0B6A121F8F4E1200D3AC94 /* Main.storyboard */ = {
isa = PBXVariantGroup;
children = (
BD0B6A131F8F4E1200D3AC94 /* Base */,
);
name = Main.storyboard;
sourceTree = "<group>";
};
BD0B6A171F8F4E1200D3AC94 /* LaunchScreen.storyboard */ = {
isa = PBXVariantGroup;
children = (
BD0B6A181F8F4E1200D3AC94 /* Base */,
);
name = LaunchScreen.storyboard;
sourceTree = "<group>";
};
/* End PBXVariantGroup section */
/* Begin XCBuildConfiguration section */
BD0B6A1B1F8F4E1200D3AC94 /* Debug */ = {
isa = XCBuildConfiguration;
buildSettings = {
ALWAYS_SEARCH_USER_PATHS = NO;
CLANG_ANALYZER_NONNULL = YES;
CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
CLANG_CXX_LIBRARY = "libc++";
CLANG_ENABLE_MODULES = YES;
CLANG_ENABLE_OBJC_ARC = YES;
CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
CLANG_WARN_BOOL_CONVERSION = YES;
CLANG_WARN_COMMA = YES;
CLANG_WARN_CONSTANT_CONVERSION = YES;
CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
CLANG_WARN_EMPTY_BODY = YES;
CLANG_WARN_ENUM_CONVERSION = YES;
CLANG_WARN_INFINITE_RECURSION = YES;
CLANG_WARN_INT_CONVERSION = YES;
CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
CLANG_WARN_STRICT_PROTOTYPES = YES;
CLANG_WARN_SUSPICIOUS_MOVE = YES;
CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
CLANG_WARN_UNREACHABLE_CODE = YES;
CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
CODE_SIGN_IDENTITY = "iPhone Developer";
COPY_PHASE_STRIP = NO;
DEBUG_INFORMATION_FORMAT = dwarf;
ENABLE_STRICT_OBJC_MSGSEND = YES;
ENABLE_TESTABILITY = YES;
GCC_C_LANGUAGE_STANDARD = gnu11;
GCC_DYNAMIC_NO_PIC = NO;
GCC_NO_COMMON_BLOCKS = YES;
GCC_OPTIMIZATION_LEVEL = 0;
GCC_PREPROCESSOR_DEFINITIONS = (
"DEBUG=1",
"$(inherited)",
);
GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
GCC_WARN_UNDECLARED_SELECTOR = YES;
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
GCC_WARN_UNUSED_FUNCTION = YES;
GCC_WARN_UNUSED_VARIABLE = YES;
IPHONEOS_DEPLOYMENT_TARGET = 9.0;
MTL_ENABLE_DEBUG_INFO = YES;
ONLY_ACTIVE_ARCH = YES;
SDKROOT = iphoneos;
SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG;
SWIFT_OPTIMIZATION_LEVEL = "-Onone";
SWIFT_VERSION = 4.0;
};
name = Debug;
};
BD0B6A1C1F8F4E1200D3AC94 /* Release */ = {
isa = XCBuildConfiguration;
buildSettings = {
ALWAYS_SEARCH_USER_PATHS = NO;
CLANG_ANALYZER_NONNULL = YES;
CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
CLANG_CXX_LIBRARY = "libc++";
CLANG_ENABLE_MODULES = YES;
CLANG_ENABLE_OBJC_ARC = YES;
CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
CLANG_WARN_BOOL_CONVERSION = YES;
CLANG_WARN_COMMA = YES;
CLANG_WARN_CONSTANT_CONVERSION = YES;
CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
CLANG_WARN_EMPTY_BODY = YES;
CLANG_WARN_ENUM_CONVERSION = YES;
CLANG_WARN_INFINITE_RECURSION = YES;
CLANG_WARN_INT_CONVERSION = YES;
CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
CLANG_WARN_STRICT_PROTOTYPES = YES;
CLANG_WARN_SUSPICIOUS_MOVE = YES;
CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
CLANG_WARN_UNREACHABLE_CODE = YES;
CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
CODE_SIGN_IDENTITY = "iPhone Developer";
COPY_PHASE_STRIP = NO;
DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
ENABLE_NS_ASSERTIONS = NO;
ENABLE_STRICT_OBJC_MSGSEND = YES;
GCC_C_LANGUAGE_STANDARD = gnu11;
GCC_NO_COMMON_BLOCKS = YES;
GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
GCC_WARN_UNDECLARED_SELECTOR = YES;
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
GCC_WARN_UNUSED_FUNCTION = YES;
GCC_WARN_UNUSED_VARIABLE = YES;
IPHONEOS_DEPLOYMENT_TARGET = 9.0;
MTL_ENABLE_DEBUG_INFO = NO;
SDKROOT = iphoneos;
SWIFT_OPTIMIZATION_LEVEL = "-Owholemodule";
SWIFT_VERSION = 4.0;
VALIDATE_PRODUCT = YES;
};
name = Release;
};
BD0B6A1E1F8F4E1200D3AC94 /* Debug */ = {
isa = XCBuildConfiguration;
buildSettings = {
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CODE_SIGN_STYLE = Automatic;
DEVELOPMENT_TEAM = 4Y74WWZQUR;
INFOPLIST_FILE = MTSlideToOpen/Info.plist;
IPHONEOS_DEPLOYMENT_TARGET = 9.0;
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
PRODUCT_BUNDLE_IDENTIFIER = "Martin-Le.MTSlideToOpen";
PRODUCT_NAME = "$(TARGET_NAME)";
SWIFT_VERSION = 5.0;
TARGETED_DEVICE_FAMILY = "1,2";
};
name = Debug;
};
BD0B6A1F1F8F4E1200D3AC94 /* Release */ = {
isa = XCBuildConfiguration;
buildSettings = {
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CODE_SIGN_STYLE = Automatic;
DEVELOPMENT_TEAM = 4Y74WWZQUR;
INFOPLIST_FILE = MTSlideToOpen/Info.plist;
IPHONEOS_DEPLOYMENT_TARGET = 9.0;
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
PRODUCT_BUNDLE_IDENTIFIER = "Martin-Le.MTSlideToOpen";
PRODUCT_NAME = "$(TARGET_NAME)";
SWIFT_VERSION = 5.0;
TARGETED_DEVICE_FAMILY = "1,2";
};
name = Release;
};
/* End XCBuildConfiguration section */
/* Begin XCConfigurationList section */
BD0B6A061F8F4E1200D3AC94 /* Build configuration list for PBXProject "MTSlideToOpen" */ = {
isa = XCConfigurationList;
buildConfigurations = (
BD0B6A1B1F8F4E1200D3AC94 /* Debug */,
BD0B6A1C1F8F4E1200D3AC94 /* Release */,
);
defaultConfigurationIsVisible = 0;
defaultConfigurationName = Release;
};
BD0B6A1D1F8F4E1200D3AC94 /* Build configuration list for PBXNativeTarget "MTSlideToOpen" */ = {
isa = XCConfigurationList;
buildConfigurations = (
BD0B6A1E1F8F4E1200D3AC94 /* Debug */,
BD0B6A1F1F8F4E1200D3AC94 /* Release */,
);
defaultConfigurationIsVisible = 0;
defaultConfigurationName = Release;
};
/* End XCConfigurationList section */
};
rootObject = BD0B6A031F8F4E1200D3AC94 /* Project object */;
}
================================================
FILE: MTSlideToOpen.xcodeproj/project.xcworkspace/contents.xcworkspacedata
================================================
<?xml version="1.0" encoding="UTF-8"?>
<Workspace
version = "1.0">
<FileRef
location = "self:MTSlideToOpen.xcodeproj">
</FileRef>
</Workspace>
================================================
FILE: README.md
================================================
# MTSlideToOpen
A simple SlideToUnlock iOS UI component
A simple SlideToUnlock iOS UI component. Support both **Left-To-Right** and **Right-To-Left** languages.
<p float="left">
<a href="url"><img src="https://raw.githubusercontent.com/lemanhtien/MTSlideToOpen/master/Screenshot.png" align="center" height="500" ></a>
<a href="url"><img src="https://raw.githubusercontent.com/lemanhtien/MTSlideToOpen/master/Right-To-Left.png" align="center" height="500" ></a>
</p>
## Requirements
* Swift 5.0
* iOS 9.0 or later
## Installation
#### Using CocoaPod
Just add to your Pod file
> pod 'MTSlideToOpen'
#### Manual install
Drag and drop folder `Source` to your project. Drag and drop to folder.
## Usage
```
let slide = MTSlideToOpenView(frame: CGRect(x: 26, y: 400, width: 317, height: 56))
slide.sliderViewTopDistance = 6
slide.sliderCornerRadious = 22
slide.delegate = self
slide.defaultLabelText = "Slide To Unlock"
slide.thumnailImageView.image = ic_arrow
```
## SwiftUI version
I built another version using SwiftUI. You can check it here [MTSlideToOpen-SwiftUI](https://github.com/lemanhtien/MTSlideToOpen-SwiftUI).
## License
This project is licensed under the MIT License - see the [LICENSE.md](LICENSE.md) file for details
================================================
FILE: Source/MTSlideToOpenView.swift
================================================
//
// MTSlideToOpenControl.swift
// MTSlideToOpen
//
// Created by Martin Lee on 10/12/17.
// Copyright © 2017 Martin Le. All rights reserved.
//
import UIKit
@objc public protocol MTSlideToOpenDelegate {
func mtSlideToOpenDelegateDidFinish(_ sender: MTSlideToOpenView)
}
@objcMembers public class MTSlideToOpenView: UIView {
// MARK: All Views
public let textLabel: UILabel = {
let label = UILabel.init()
return label
}()
public let sliderTextLabel: UILabel = {
let label = UILabel()
return label
}()
public let thumnailImageView: UIImageView = {
let view = MTRoundImageView()
view.isUserInteractionEnabled = true
view.contentMode = .center
return view
}()
public let sliderHolderView: UIView = {
let view = UIView()
return view
}()
public let draggedView: UIView = {
let view = UIView()
return view
}()
public let view: UIView = {
let view = UIView()
return view
}()
// MARK: Public properties
public weak var delegate: MTSlideToOpenDelegate?
public var animationVelocity: Double = 0.2
public var sliderViewTopDistance: CGFloat = 8.0 {
didSet {
topSliderConstraint?.constant = sliderViewTopDistance
layoutIfNeeded()
}
}
public var thumbnailViewTopDistance: CGFloat = 0.0 {
didSet {
topThumbnailViewConstraint?.constant = thumbnailViewTopDistance
layoutIfNeeded()
}
}
public var thumbnailViewStartingDistance: CGFloat = 0.0 {
didSet {
leadingThumbnailViewConstraint?.constant = thumbnailViewStartingDistance
trailingDraggedViewConstraint?.constant = thumbnailViewStartingDistance
setNeedsLayout()
}
}
public var textLabelLeadingDistance: CGFloat = 0 {
didSet {
leadingTextLabelConstraint?.constant = textLabelLeadingDistance
setNeedsLayout()
}
}
public var isEnabled:Bool = true {
didSet {
animationChangedEnabledBlock?(isEnabled)
}
}
public var showSliderText:Bool = false {
didSet {
sliderTextLabel.isHidden = !showSliderText
}
}
public var animationChangedEnabledBlock:((Bool) -> Void)?
// MARK: Default styles
public var sliderCornerRadius: CGFloat = 30.0 {
didSet {
sliderHolderView.layer.cornerRadius = sliderCornerRadius
draggedView.layer.cornerRadius = sliderCornerRadius
}
}
public var sliderBackgroundColor: UIColor = UIColor(red:0.1, green:0.61, blue:0.84, alpha:0.1) {
didSet {
sliderHolderView.backgroundColor = sliderBackgroundColor
sliderTextLabel.textColor = sliderBackgroundColor
}
}
public var textColor:UIColor = UIColor(red:25.0/255, green:155.0/255, blue:215.0/255, alpha:0.7) {
didSet {
textLabel.textColor = textColor
}
}
public var slidingColor:UIColor = UIColor(red:25.0/255, green:155.0/255, blue:215.0/255, alpha:0.7) {
didSet {
draggedView.backgroundColor = slidingColor
}
}
public var thumbnailColor:UIColor = UIColor(red:25.0/255, green:155.0/255, blue:215.0/255, alpha:1) {
didSet {
thumnailImageView.backgroundColor = thumbnailColor
}
}
public var labelText: String = "Swipe to open" {
didSet {
textLabel.text = labelText
sliderTextLabel.text = labelText
}
}
public var textFont: UIFont = UIFont.systemFont(ofSize: 15.0) {
didSet {
textLabel.font = textFont
sliderTextLabel.font = textFont
}
}
// MARK: Private Properties
private var leadingThumbnailViewConstraint: NSLayoutConstraint?
private var leadingTextLabelConstraint: NSLayoutConstraint?
private var topSliderConstraint: NSLayoutConstraint?
private var topThumbnailViewConstraint: NSLayoutConstraint?
private var trailingDraggedViewConstraint: NSLayoutConstraint?
private var xPositionInThumbnailView: CGFloat = 0
private var xEndingPoint: CGFloat {
get {
return (self.view.frame.maxX - thumnailImageView.bounds.width - thumbnailViewStartingDistance)
}
}
private var isFinished: Bool = false
override public init(frame: CGRect) {
super.init(frame: frame)
setupView()
}
private var panGestureRecognizer: UIPanGestureRecognizer!
required public init?(coder aDecoder: NSCoder) {
super.init(coder: aDecoder)!
setupView()
}
private func setupView() {
self.addSubview(view)
view.addSubview(thumnailImageView)
view.addSubview(sliderHolderView)
view.addSubview(draggedView)
draggedView.addSubview(sliderTextLabel)
sliderHolderView.addSubview(textLabel)
view.bringSubviewToFront(self.thumnailImageView)
setupConstraint()
setStyle()
// Add pan gesture
panGestureRecognizer = UIPanGestureRecognizer(target: self, action: #selector(self.handlePanGesture(_:)))
panGestureRecognizer.minimumNumberOfTouches = 1
thumnailImageView.addGestureRecognizer(panGestureRecognizer)
}
private func setupConstraint() {
view.translatesAutoresizingMaskIntoConstraints = false
thumnailImageView.translatesAutoresizingMaskIntoConstraints = false
sliderHolderView.translatesAutoresizingMaskIntoConstraints = false
textLabel.translatesAutoresizingMaskIntoConstraints = false
sliderTextLabel.translatesAutoresizingMaskIntoConstraints = false
draggedView.translatesAutoresizingMaskIntoConstraints = false
// Setup for view
view.leadingAnchor.constraint(equalTo: self.leadingAnchor).isActive = true
view.trailingAnchor.constraint(equalTo: self.trailingAnchor).isActive = true
view.topAnchor.constraint(equalTo: self.topAnchor).isActive = true
view.bottomAnchor.constraint(equalTo: self.bottomAnchor).isActive = true
// Setup for circle View
leadingThumbnailViewConstraint = thumnailImageView.leadingAnchor.constraint(equalTo: view.leadingAnchor)
leadingThumbnailViewConstraint?.isActive = true
topThumbnailViewConstraint = thumnailImageView.topAnchor.constraint(equalTo: view.topAnchor, constant: thumbnailViewTopDistance)
topThumbnailViewConstraint?.isActive = true
thumnailImageView.centerYAnchor.constraint(equalTo: view.centerYAnchor).isActive = true
thumnailImageView.heightAnchor.constraint(equalTo: thumnailImageView.widthAnchor).isActive = true
// Setup for slider holder view
topSliderConstraint = sliderHolderView.topAnchor.constraint(equalTo: view.topAnchor, constant: sliderViewTopDistance)
topSliderConstraint?.isActive = true
sliderHolderView.centerYAnchor.constraint(equalTo: view.centerYAnchor).isActive = true
sliderHolderView.leadingAnchor.constraint(equalTo: view.leadingAnchor).isActive = true
sliderHolderView.centerXAnchor.constraint(equalTo: view.centerXAnchor).isActive = true
// Setup for textLabel
textLabel.topAnchor.constraint(equalTo: sliderHolderView.topAnchor).isActive = true
textLabel.centerYAnchor.constraint(equalTo: sliderHolderView.centerYAnchor).isActive = true
leadingTextLabelConstraint = textLabel.leadingAnchor.constraint(equalTo: sliderHolderView.leadingAnchor, constant: textLabelLeadingDistance)
leadingTextLabelConstraint?.isActive = true
textLabel.trailingAnchor.constraint(equalTo: view.trailingAnchor, constant: CGFloat(-8)).isActive = true
// Setup for sliderTextLabel
sliderTextLabel.topAnchor.constraint(equalTo: textLabel.topAnchor).isActive = true
sliderTextLabel.centerYAnchor.constraint(equalTo: textLabel.centerYAnchor).isActive = true
sliderTextLabel.leadingAnchor.constraint(equalTo: textLabel.leadingAnchor).isActive = true
sliderTextLabel.trailingAnchor.constraint(equalTo: textLabel.trailingAnchor).isActive = true
// Setup for Dragged View
draggedView.leadingAnchor.constraint(equalTo: sliderHolderView.leadingAnchor).isActive = true
draggedView.topAnchor.constraint(equalTo: sliderHolderView.topAnchor).isActive = true
draggedView.centerYAnchor.constraint(equalTo: sliderHolderView.centerYAnchor).isActive = true
trailingDraggedViewConstraint = draggedView.trailingAnchor.constraint(equalTo: thumnailImageView.trailingAnchor, constant: thumbnailViewStartingDistance)
trailingDraggedViewConstraint?.isActive = true
}
private func setStyle() {
thumnailImageView.backgroundColor = thumbnailColor
textLabel.text = labelText
textLabel.font = textFont
textLabel.textColor = textColor
textLabel.textAlignment = .center
sliderTextLabel.text = labelText
sliderTextLabel.font = textFont
sliderTextLabel.textColor = sliderBackgroundColor
sliderTextLabel.textAlignment = .center
sliderTextLabel.isHidden = !showSliderText
if isOnRightToLeftLanguage() {
textLabel.mt_flipView()
sliderTextLabel.mt_flipView()
}
sliderHolderView.backgroundColor = sliderBackgroundColor
sliderHolderView.layer.cornerRadius = sliderCornerRadius
draggedView.backgroundColor = slidingColor
draggedView.layer.cornerRadius = sliderCornerRadius
draggedView.clipsToBounds = true
draggedView.layer.masksToBounds = true
}
private func isTapOnThumbnailViewWithPoint(_ point: CGPoint) -> Bool{
return self.thumnailImageView.frame.contains(point)
}
private func updateThumbnailXPosition(_ x: CGFloat) {
leadingThumbnailViewConstraint?.constant = x
setNeedsLayout()
}
// MARK: UIPanGestureRecognizer
@objc private func handlePanGesture(_ sender: UIPanGestureRecognizer) {
if isFinished || !isEnabled {
return
}
let translatedPoint = sender.translation(in: view).x * (self.isOnRightToLeftLanguage() ? -1 : 1)
switch sender.state {
case .began:
break
case .changed:
if translatedPoint >= xEndingPoint {
updateThumbnailXPosition(xEndingPoint)
return
}
if translatedPoint <= thumbnailViewStartingDistance {
textLabel.alpha = 1
updateThumbnailXPosition(thumbnailViewStartingDistance)
return
}
updateThumbnailXPosition(translatedPoint)
textLabel.alpha = (xEndingPoint - translatedPoint) / xEndingPoint
break
case .ended:
if translatedPoint >= xEndingPoint {
textLabel.alpha = 0
updateThumbnailXPosition(xEndingPoint)
// Finish action
isFinished = true
delegate?.mtSlideToOpenDelegateDidFinish(self)
return
}
if translatedPoint <= thumbnailViewStartingDistance {
textLabel.alpha = 1
updateThumbnailXPosition(thumbnailViewStartingDistance)
return
}
UIView.animate(withDuration: animationVelocity) {
self.leadingThumbnailViewConstraint?.constant = self.thumbnailViewStartingDistance
self.textLabel.alpha = 1
self.layoutIfNeeded()
}
break
default:
break
}
}
// Others
public func resetStateWithAnimation(_ animated: Bool) {
let action = {
self.leadingThumbnailViewConstraint?.constant = self.thumbnailViewStartingDistance
self.textLabel.alpha = 1
self.layoutIfNeeded()
//
self.isFinished = false
}
if animated {
UIView.animate(withDuration: animationVelocity) {
action()
}
} else {
action()
}
}
// MARK: Helpers
func isOnRightToLeftLanguage() -> Bool {
return UIApplication.shared.userInterfaceLayoutDirection == .rightToLeft
}
}
extension UIView {
func mt_flipView() {
self.transform = CGAffineTransform(scaleX: -1.0, y: 1.0)
}
}
class MTRoundImageView: UIImageView {
override func layoutSubviews() {
super.layoutSubviews()
let radius: CGFloat = self.bounds.size.width / 2.0
self.layer.cornerRadius = radius
}
}
gitextract_dmy5_76p/
├── .gitignore
├── .swift-version
├── LICENSE
├── MTSlideToOpen/
│ ├── AppDelegate.swift
│ ├── Assets.xcassets/
│ │ ├── AppIcon.appiconset/
│ │ │ └── Contents.json
│ │ ├── Contents.json
│ │ └── ic_arrow.imageset/
│ │ └── Contents.json
│ ├── Base.lproj/
│ │ ├── LaunchScreen.storyboard
│ │ └── Main.storyboard
│ ├── Info.plist
│ └── ViewController.swift
├── MTSlideToOpen.podspec
├── MTSlideToOpen.xcodeproj/
│ ├── project.pbxproj
│ └── project.xcworkspace/
│ └── contents.xcworkspacedata
├── README.md
└── Source/
└── MTSlideToOpenView.swift
Condensed preview — 16 files, each showing path, character count, and a content snippet. Download the .json file or copy for the full structured content (49K chars).
[
{
"path": ".gitignore",
"chars": 376,
"preview": "## Build generated\nbuild/\nDerivedData\nbuild.xcarchive\n\n## Various settings\n*.pbxuser\n!default.pbxuser\n*.mode1v3\n!default"
},
{
"path": ".swift-version",
"chars": 4,
"preview": "5.0\n"
},
{
"path": "LICENSE",
"chars": 1074,
"preview": "The MIT License (MIT)\n\nCopyright (c) 2017 Tien Le\n\nPermission is hereby granted, free of charge, to any person obtaining"
},
{
"path": "MTSlideToOpen/AppDelegate.swift",
"chars": 2175,
"preview": "//\n// AppDelegate.swift\n// MTSlideToOpen\n//\n// Created by Martin Lee on 10/12/17.\n// Copyright © 2017 Martin Le. All"
},
{
"path": "MTSlideToOpen/Assets.xcassets/AppIcon.appiconset/Contents.json",
"chars": 1590,
"preview": "{\n \"images\" : [\n {\n \"idiom\" : \"iphone\",\n \"size\" : \"20x20\",\n \"scale\" : \"2x\"\n },\n {\n \"idiom\""
},
{
"path": "MTSlideToOpen/Assets.xcassets/Contents.json",
"chars": 62,
"preview": "{\n \"info\" : {\n \"version\" : 1,\n \"author\" : \"xcode\"\n }\n}"
},
{
"path": "MTSlideToOpen/Assets.xcassets/ic_arrow.imageset/Contents.json",
"chars": 305,
"preview": "{\n \"images\" : [\n {\n \"idiom\" : \"universal\",\n \"scale\" : \"1x\"\n },\n {\n \"idiom\" : \"universal\",\n "
},
{
"path": "MTSlideToOpen/Base.lproj/LaunchScreen.storyboard",
"chars": 1681,
"preview": "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\n<document type=\"com.apple.InterfaceBuilder3.CocoaTouch.Storyboard"
},
{
"path": "MTSlideToOpen/Base.lproj/Main.storyboard",
"chars": 1706,
"preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<document type=\"com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB\" version=\"3"
},
{
"path": "MTSlideToOpen/Info.plist",
"chars": 1463,
"preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/P"
},
{
"path": "MTSlideToOpen/ViewController.swift",
"chars": 4699,
"preview": "//\n// ViewController.swift\n// MTSlideToOpen\n//\n// Created by Martin Lee on 10/12/17.\n// Copyright © 2017 Martin Le. "
},
{
"path": "MTSlideToOpen.podspec",
"chars": 1582,
"preview": "Pod::Spec.new do |s|\n\n # ――― Spec Metadata ―――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #\n #\n\n s.name"
},
{
"path": "MTSlideToOpen.xcodeproj/project.pbxproj",
"chars": 13175,
"preview": "// !$*UTF8*$!\n{\n\tarchiveVersion = 1;\n\tclasses = {\n\t};\n\tobjectVersion = 48;\n\tobjects = {\n\n/* Begin PBXBuildFile section *"
},
{
"path": "MTSlideToOpen.xcodeproj/project.xcworkspace/contents.xcworkspacedata",
"chars": 158,
"preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<Workspace\n version = \"1.0\">\n <FileRef\n location = \"self:MTSlideToOpen.x"
},
{
"path": "README.md",
"chars": 1257,
"preview": "# MTSlideToOpen\nA simple SlideToUnlock iOS UI component\n\nA simple SlideToUnlock iOS UI component. Support both **Left-To"
},
{
"path": "Source/MTSlideToOpenView.swift",
"chars": 12808,
"preview": "//\n// MTSlideToOpenControl.swift\n// MTSlideToOpen\n//\n// Created by Martin Lee on 10/12/17.\n// Copyright © 2017 Marti"
}
]
About this extraction
This page contains the full source code of the lemanhtien/MTSlideToOpen GitHub repository, extracted and formatted as plain text for AI agents and large language models (LLMs). The extraction includes 16 files (43.1 KB), approximately 12.8k tokens. Use this with OpenClaw, Claude, ChatGPT, Cursor, Windsurf, or any other AI tool that accepts text input. You can copy the full output to your clipboard or download it as a .txt file.
Extracted by GitExtract — free GitHub repo to text converter for AI. Built by Nikandr Surkov.