ios-oss

Kickstarter for iOS. Bring new ideas to life, anywhere.

Github stars Tracking Chart







Circle CI

Welcome to Kickstarter’s open source iOS app! Come on in, take your shoes off,
stay a while—explore how Kickstarter’s native squad has built and continues to
build the app.

We’ve also open sourced our Android app,
and read more about our journey to open source here.

Getting Started

  1. Install Xcode.
  2. Clone this repository.
  3. Run make bootstrap to install tools and dependencies.
  4. Run make test-all to build and run tests on all platforms.

* To provide a mock version that serves up hard-coded data immediately, set KsApi.Secrets.isOSS = true.

Some fun things to explore

If you’re just looking for a quick glance at a few things we’re particularly
proud of, look no further:

  • The Screenshots
    directory holds nearly 500 screenshots of various screens in every language,
    device and edge-case state that we like to make sure stays true. For example,
    a backer viewing a project in French
    here
    , or a creator looking at their dashboard in German and on an iPad
    here.

  • We use Swift Playgrounds for iterative development and styling.
    Most major screens in the app get a corresponding playground where we can see a
    wide variety of devices, languages and data in real time. Browse our collection of
    playgrounds here.

  • We use view models as
    a lightweight way to isolate side effects and embrace a functional core. We
    write these
    as a pure mapping of input signals to output signals, and test
    them heavily, including tests for localization, accessibility and event
    tracking.

Documentation

While we’re at it, why not share our docs? Check out the
native docs we have written so far
for more documentation.

Dependencies

We make heavy use of the following projects, and so it can be helpful to be
familiar with them:

1st party

  • Circle CI
    Prelude: Foundation of
    types and functions we feel are missing from the Swift standard library.

  • Circle CI
    ReactiveExtensions:
    A collection of operators we like to add to ReactiveCocoa.

3rd party

Notices for 3rd party libraries in this repository are contained in
NOTICE.md.

Contributing

We intend for this project to be an educational resource: we are excited to
share our wins, mistakes, and methodology of iOS development as we work
in the open. Our primary focus is to continue improving the app for our users in
line with our roadmap.

The best way to submit feedback and report bugs is to open a GitHub issue.
Please be sure to include your operating system, device, version number, and
steps to reproduce reported bugs. Keep in mind that all participants will be
expected to follow our code of conduct.

Code of Conduct

We aim to share our knowledge and findings as we work daily to improve our
product, for our community, in a safe and open space. We work as we live, as
kind and considerate human beings who learn and grow from giving and receiving
positive, constructive feedback. We reserve the right to delete or ban any
behavior violating this base foundation of respect.

Find this interesting?

We do too, and we’re hiring!

License

Copyright 2019 Kickstarter, PBC.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

Main metrics

Overview
Name With Ownerkickstarter/ios-oss
Primary LanguageSwift
Program languageSwift (Language Count: 4)
Platform
License:Apache License 2.0
所有者活动
Created At2016-12-02 21:24:40
Pushed At2025-05-20 19:24:09
Last Commit At
Release Count100
Last Release Name5.24.1 (Posted on 2025-04-21 13:46:31)
First Release Name3.0.0-147943569 (Posted on )
用户参与
Stargazers Count8.6k
Watchers Count211
Fork Count1.2k
Commits Count3.1k
Has Issues Enabled
Issues Count98
Issue Open Count4
Pull Requests Count2170
Pull Requests Open Count5
Pull Requests Close Count164
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private