Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/amantaneja/PTEventView
An Event View based on Apple's Event Detail View. Written in Swift 3. Supports ARC, Autolayout and editing via StoryBoard.
https://github.com/amantaneja/PTEventView
apple-event autolayout calandar calendar calendar-component calendar-events calendar-view calendar-widget calendars calendarview calender cocoa-touch cocoapod cocoapods eventview ibdesignable pteventview storyboard swift swift3
Last synced: 3 months ago
JSON representation
An Event View based on Apple's Event Detail View. Written in Swift 3. Supports ARC, Autolayout and editing via StoryBoard.
- Host: GitHub
- URL: https://github.com/amantaneja/PTEventView
- Owner: amantaneja
- License: mit
- Created: 2017-08-20T10:42:39.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2020-05-07T06:57:14.000Z (over 4 years ago)
- Last Synced: 2024-08-14T20:41:23.502Z (3 months ago)
- Topics: apple-event, autolayout, calandar, calendar, calendar-component, calendar-events, calendar-view, calendar-widget, calendars, calendarview, calender, cocoa-touch, cocoapod, cocoapods, eventview, ibdesignable, pteventview, storyboard, swift, swift3
- Language: Ruby
- Size: 501 KB
- Stars: 35
- Watchers: 4
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ios - PTEventView - An Event View based on Apple's Event Detail View within Calender.Supports ARC, Autolayout and editing via StoryBoard. (UI / Calendar)
- awesome-ios-star - PTEventView - An Event View based on Apple's Event Detail View within Calender.Supports ARC, Autolayout and editing via StoryBoard. (UI / Calendar)
README
An Event View based on Apple's Event Detail View. Written in Swift 3. Supports ARC, Autolayout and editing via StoryBoard.![License](https://img.shields.io/badge/License-MIT-lightgrey.svg)
![Platform](https://img.shields.io/badge/Platforms-iOS-red.svg)
![Swift 3.x](https://img.shields.io/badge/Swift-3.x-blue.svg)
![MadeWithLove](https://img.shields.io/badge/Made%20with%20%E2%9D%A4-India-green.svg)# Installation
### CocoaPods
**PTEventView** is available through [CocoaPods](http://cocoapods.org). To install it, simply add the following line to your Podfile:```swift
pod 'PTEventView'
```### Manual
You can drag and drop the Files from [here](https://github.com/amantaneja/PTEventView/tree/master/Demo/PTEventViewDemo/PTEventView) into your projects directly.# Setup
### Adding PTEventView```swift
fileprivate weak var myCalenderView: PTEventView!
```
```swift
// In loadView or viewDidLoad
let ptEventView = Bundle.main.loadNibNamed("PTEventView", owner: nil, options: nil)![0] as? PTEventView
ptEventView?.delegate = self
ptEventView?.setup(frame: myCalenderView.frame)
self.view.addSubview(ptEventView!)
```### Data Model
PTEventView supports both 12 hour and 24 hour format as data model. The input can be received from the API or Database(Core Data, Realm, SQLite) in the form of Array of `Event Object`.
The Event Object should have:
- Start Time (12 hour or 24 hour)
- End Time (12 hour or 24 hour)
- Name of the Event
**Note**: Incase of 12 hour, suffix time with AM or PM.**Example**
```swift
let dataModel12hour = [["10AM","11AM","Swift Meetup '17"],["12AM","3PM","WWDC KickOff"]]
let dataModel24hour = [["10","11","Swift Meetup '17"],["12","15","WWDC KickOff"]]
```
Use Bool to switch between Time Formats
```swift
ptEventView?.is24HourFormat = true
```
```swift
for event in dataModel12hour{
let eventModel = PTEventViewModel()
eventModel.startTime = event[0]
eventModel.endTime = event[1]
eventModel.eventName = event[2]
ptEventView?.EventViewdataModel.append(eventModel)
}
```# StoryBoard
Supports IBDesignable to alter `Border Width`, `Corner Radius` and `Border Color`### Customization
You can customize the view parameters for designing your own view:`borderColor` **- Border Color** *Default is Black*
`borderWidth` **- Border Width** *Default is 1.0*
`cornerRadius` **- Corner Radius** *Default is 6.0*
`eventColor` **- Event Color** *Default is as given in Demo Gif*
`eventTextColor` **- Event Text Color** *Default is white. Try to make it contrasting with eventColor*
# ToDo[s]
- [x] Add support for PM and AM via 24 hour format
- [ ] Orientation Support. Currently supports UI for Portrait.
- [x] Add delegation for callbacks
- [ ] Implement AutoLayout for CalenderView
- [ ] Support Events on the same day
- [ ] Add IBInspectable for Row Color of Event## Requirement
- iOS 8.0+ (CocoaPods with Swift support will only work on iOS 8.0+. Alternatively, you will have to import library manually to your project)
- Xcode 8.0+, Swift 3.0+## License
PTEventView is released under the MIT license. See [LICENSE](https://github.com/amantaneja/PTEventView/blob/master/LICENSE) for details.
[**★Star**](#) this repo.
http://culturestreet.com/depot/620--auto--uploads-2013-12-Daily-quotes-5-December.jpg