device-kit data:image/s3,"s3://crabby-images/67aad/67aad24db041f8e850d074e0216eaf8ecbf7fa20" alt="Awesome"
data:image/s3,"s3://crabby-images/fd432/fd43213bb59a161ac6c4afe58ccd16987c6acfd9" alt="License"
Last Update: 04/January/2020.
data:image/s3,"s3://crabby-images/1591f/1591f28f161fd8878e70c462b1f596e85cd25020" alt=""
If you like the project, please give it a star ⭐ It will show the creator your appreciation and help others to discover the repo.
✍️ About
📱 Framework that allows to get extended information about an iOS
device.
📚 Features
- Device Type information
- Easily get a device’s
identifier
- Determine if an app running on a
simulator
or on an actual device
- Includes information about an each
iOS
device
- Device Storage status such as:
Total
space
Free
space
Used
space
- You can format the data using various
units
(by using ByteCountFormatter.Units
)
- Device Orientation information
- Check whether the device is in
.portrait
or .landscape
orientation without the need to make boilerplate UIDevice.current.orientation
calls & if/else
checks
- You can use
isPortrait
property if you’d like
- Device’s Internet Connection status
- Super easily check whether your device is connected to the internet
- You can get the reachability status as well
✈️ Usage
Getting device’s identifier:
let identifiers = UIDevice.current.deviceType
// `identifiers` will hold the corresponding devices' identifiers depending on your `iOS` model
Determing how much storage has left:
UIDevice.current.storageStatus.getFreeSpace(.useMB)
// Will print something like this:
// 139,197.3 MB
UIDevice.current.storageStatus.getFreeSpace(.useGB)
// Or you can change the unit type to Gigabytes:
// 139.16 GB
UIDevice.current.storageStatus.getFreeSpace(.useGB, includeUnitPostfix: false)
// If you don't want to get GB, MB postfixes then specify an optional parameter for `includeUnitPostfix`:
// 139.16
Checking the device’s orientation:
let orienation = UIDevice.current.deviceOrientation
switch orientation {
case .portrait:
showDrawerView()
case .landscape:
hideDrawerView()
}
Getting the internet connection status:
let internet = UIDevice.current.internetConnection
guard internet.connection == .open else {
throw NetworkError.isNotAvailabe("Missing internet connection")
}
sendRequest()
🏗 Installation
Swift Package Manager
Xcode 11+
- Open
MenuBar
→ File
→ Swift Packages
→ Add Package Dependency...
- Paste the package repository url
https://github.com/jVirus/device-kit
and hit Next
.
- Select the installment rules.
After specifying which version do you want to install, the package will be downloaded and attached to your project.
Package.swift
If you already have a Package.swift
or you are building your own package simply add a new dependency:
dependencies: [
.package(url: "https://github.com/jVirus/device-kit", from: "1.0.0")
]
Manual
You can always use copy-paste the sources method 😄. Or you can compile the framework and include it with your project.
📝 ToDo
🙋♀️🙋♂️Contributing
- There is just one main rule for contributors - please include your extensions in separete files. It’s important since such extension can be more easily referenced and reused.
- The other
soft
rule is - please include unit tests
with your extensions.
👨💻 Author
Astemir Eleev
🔖 Licence
The project is available under MIT licence
device-kitdata:image/s3,"s3://crabby-images/67aad/67aad24db041f8e850d074e0216eaf8ecbf7fa20" alt="Awesome"
Last Update: 04/January/2020.
If you like the project, please give it a star ⭐ It will show the creator your appreciation and help others to discover the repo.
✍️ About
📱 Framework that allows to get extended information about an
iOS
device.📚 Features
identifier
simulator
or on an actual deviceiOS
deviceTotal
spaceFree
spaceUsed
spaceunits
(by usingByteCountFormatter.Units
).portrait
or.landscape
orientation without the need to make boilerplateUIDevice.current.orientation
calls &if/else
checksisPortrait
property if you’d like✈️ Usage
Getting device’s identifier:
Determing how much storage has left:
Checking the device’s orientation:
Getting the internet connection status:
🏗 Installation
Swift Package Manager
Xcode 11+
MenuBar
→File
→Swift Packages
→Add Package Dependency...
https://github.com/jVirus/device-kit
and hitNext
.After specifying which version do you want to install, the package will be downloaded and attached to your project.
Package.swift
If you already have a
Package.swift
or you are building your own package simply add a new dependency:Manual
You can always use copy-paste the sources method 😄. Or you can compile the framework and include it with your project.
📝 ToDo
Network
reachability (withNotificationCenter
support or more safer approach in observing changes)NotificationCenter
observer supportorientation
NotificationCenter
observer supportorientation
NotificationCenter
observer support🙋♀️🙋♂️Contributing
soft
rule is - please includeunit tests
with your extensions.👨💻 Author
Astemir Eleev
🔖 Licence
The project is available under MIT licence