Skip to content

peakresponse/peak-ios-icd10kit

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commit
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ICD10Kit

ICD10Kit is a library for embedding ICD-10-CM codes as a Realm database. The example application included with the library can be run on a Mac OS desktop to read ICD-10-CM code files and generate a compacted Realm database that can be bundled into an iOS app.

Generate a database file

  1. Download ICD-10-CM source files from CMS (latest 2022 edition as of time of writing):

https://www.cms.gov/files/zip/2022-code-tables-tabular-and-index.zip

https://www.cms.gov/medicare/icd-10/2022-icd-10-cm

  1. To run the example project, clone the repo, and run pod install from the Example directory first.

  2. Then, open the Example/ICD10Kit.xcworkspace in Xcode. Change the build target to My Mac and run.

  3. Click on Import in the toolbar. Find the icd10cm-tabular-2022.xml in the file browser and click on Open.

  4. Wait as the file is parsed and imported into a Realm database, until the spinner disappears and the Export option is enabled in the toolbar.

  5. Click on Export, and select a destination for the Realm database file.

Installation

  1. Include ICD10Kit in your iOS app project using CocoaPods. To install it, simply add the following line to your Podfile:
pod 'ICD10Kit'
  1. Add the exported Realm database file generated previously to your iOS app project.

  2. Initialize the library with the Realm file, for example in your AppDelegate didFinishLaunchingWithOptions function.

import ICD10Kit
...
class AppDelegate: UIResponder, UIApplicationDelegate {
    ...
    func application(_ application: UIApplication,
                     didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
        ...
        CMRealm.configure(url: Bundle.main.url(forResource: "ICD10CM", withExtension: "realm"), isReadOnly: true)
    }
    ...
}
  1. Use as with any Realm database model. For example, in a table view controller (see https://docs.mongodb.com/realm/sdk/swift/examples/react-to-changes/#register-a-collection-change-listener):
class CodesViewController: UITableViewController {    
    var results: Results<CMCode>?
    ...
    func viewDidLoad() {
      ...
      results = CMRealm.open().objects(CMCode.self).sorted(byKeyPath: "name", ascending: true)
    }
    ...      
}

Author

Francis Li, francis@peakresponse.net

License

ICD10Kit
Copyright (C) 2022 Peak Response Inc.

This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version.

This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published