diff --git a/Configurations/application.xcconfig b/Configurations/application.xcconfig index fb130d5..16d052c 100644 --- a/Configurations/application.xcconfig +++ b/Configurations/application.xcconfig @@ -1,2 +1,2 @@ -APPLICATION_VERSION=1.0.7 -APPLICATION_BUILD=19012802 +APPLICATION_VERSION=1.0.8 +APPLICATION_BUILD=19021103 diff --git a/DevelopPods/MnemonicsView/.gitignore b/DevelopPods/MnemonicsView/.gitignore new file mode 100644 index 0000000..93c86d3 --- /dev/null +++ b/DevelopPods/MnemonicsView/.gitignore @@ -0,0 +1,37 @@ +# OS X +.DS_Store + +# Xcode +build/ +*.pbxuser +!default.pbxuser +*.mode1v3 +!default.mode1v3 +*.mode2v3 +!default.mode2v3 +*.perspectivev3 +!default.perspectivev3 +xcuserdata/ +*.xccheckout +profile +*.moved-aside +DerivedData +*.hmap +*.ipa + +# Bundler +.bundle + +# Add this line if you want to avoid checking in source code from Carthage dependencies. +# Carthage/Checkouts + +Carthage/Build + +# We recommend against adding the Pods directory to your .gitignore. However +# you should judge for yourself, the pros and cons are mentioned at: +# https://guides.cocoapods.org/using/using-cocoapods.html#should-i-ignore-the-pods-directory-in-source-control +# +# Note: if you ignore the Pods directory, make sure to uncomment +# `pod install` in .travis.yml +# +# Pods/ diff --git a/DevelopPods/MnemonicsView/.travis.yml b/DevelopPods/MnemonicsView/.travis.yml new file mode 100644 index 0000000..bf7bdd7 --- /dev/null +++ b/DevelopPods/MnemonicsView/.travis.yml @@ -0,0 +1,14 @@ +# references: +# * https://www.objc.io/issues/6-build-tools/travis-ci/ +# * https://github.com/supermarin/xcpretty#usage + +osx_image: xcode7.3 +language: objective-c +# cache: cocoapods +# podfile: Example/Podfile +# before_install: +# - gem install cocoapods # Since Travis is not always on latest version +# - pod install --project-directory=Example +script: +- set -o pipefail && xcodebuild test -enableCodeCoverage YES -workspace Example/MnemonicsView.xcworkspace -scheme MnemonicsView-Example -sdk iphonesimulator9.3 ONLY_ACTIVE_ARCH=NO | xcpretty +- pod lib lint diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView.xcodeproj/project.pbxproj b/DevelopPods/MnemonicsView/Example/MnemonicsView.xcodeproj/project.pbxproj new file mode 100644 index 0000000..7b32bef --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView.xcodeproj/project.pbxproj @@ -0,0 +1,625 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 46; + objects = { + +/* Begin PBXBuildFile section */ + 5B92B3590303C1AC6EC82CED /* Pods_MnemonicsView_Tests.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 3D6CDA666572C550B6439C6C /* Pods_MnemonicsView_Tests.framework */; }; + 6003F58E195388D20070C39A /* Foundation.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 6003F58D195388D20070C39A /* Foundation.framework */; }; + 6003F590195388D20070C39A /* CoreGraphics.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 6003F58F195388D20070C39A /* CoreGraphics.framework */; }; + 6003F592195388D20070C39A /* UIKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 6003F591195388D20070C39A /* UIKit.framework */; }; + 6003F598195388D20070C39A /* InfoPlist.strings in Resources */ = {isa = PBXBuildFile; fileRef = 6003F596195388D20070C39A /* InfoPlist.strings */; }; + 6003F59A195388D20070C39A /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 6003F599195388D20070C39A /* main.m */; }; + 6003F59E195388D20070C39A /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 6003F59D195388D20070C39A /* AppDelegate.m */; }; + 6003F5A7195388D20070C39A /* ViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = 6003F5A6195388D20070C39A /* ViewController.m */; }; + 6003F5A9195388D20070C39A /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 6003F5A8195388D20070C39A /* Images.xcassets */; }; + 6003F5B0195388D20070C39A /* XCTest.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 6003F5AF195388D20070C39A /* XCTest.framework */; }; + 6003F5B1195388D20070C39A /* Foundation.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 6003F58D195388D20070C39A /* Foundation.framework */; }; + 6003F5B2195388D20070C39A /* UIKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 6003F591195388D20070C39A /* UIKit.framework */; }; + 6003F5BA195388D20070C39A /* InfoPlist.strings in Resources */ = {isa = PBXBuildFile; fileRef = 6003F5B8195388D20070C39A /* InfoPlist.strings */; }; + 6003F5BC195388D20070C39A /* Tests.m in Sources */ = {isa = PBXBuildFile; fileRef = 6003F5BB195388D20070C39A /* Tests.m */; }; + 71719F9F1E33DC2100824A3D /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 71719F9D1E33DC2100824A3D /* LaunchScreen.storyboard */; }; + 873B8AEB1B1F5CCA007FD442 /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 873B8AEA1B1F5CCA007FD442 /* Main.storyboard */; }; + A891F0115DF118B40E04825C /* Pods_MnemonicsView_Example.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = CAEF3D0F0F0DA4B3366FC702 /* Pods_MnemonicsView_Example.framework */; }; +/* End PBXBuildFile section */ + +/* Begin PBXContainerItemProxy section */ + 6003F5B3195388D20070C39A /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 6003F582195388D10070C39A /* Project object */; + proxyType = 1; + remoteGlobalIDString = 6003F589195388D20070C39A; + remoteInfo = MnemonicsView; + }; +/* End PBXContainerItemProxy section */ + +/* Begin PBXFileReference section */ + 09EDD63B9EDA6FA00558AF3E /* README.md */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = net.daringfireball.markdown; name = README.md; path = ../README.md; sourceTree = ""; }; + 3D6CDA666572C550B6439C6C /* Pods_MnemonicsView_Tests.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_MnemonicsView_Tests.framework; sourceTree = BUILT_PRODUCTS_DIR; }; + 465095FA410AEB71D8770CF2 /* Pods-MnemonicsView_Example.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-MnemonicsView_Example.debug.xcconfig"; path = "Pods/Target Support Files/Pods-MnemonicsView_Example/Pods-MnemonicsView_Example.debug.xcconfig"; sourceTree = ""; }; + 47D6ACD098C05C8F49BA3481 /* Pods-MnemonicsView_Tests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-MnemonicsView_Tests.release.xcconfig"; path = "Pods/Target Support Files/Pods-MnemonicsView_Tests/Pods-MnemonicsView_Tests.release.xcconfig"; sourceTree = ""; }; + 6003F58A195388D20070C39A /* MnemonicsView_Example.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = MnemonicsView_Example.app; sourceTree = BUILT_PRODUCTS_DIR; }; + 6003F58D195388D20070C39A /* Foundation.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Foundation.framework; path = System/Library/Frameworks/Foundation.framework; sourceTree = SDKROOT; }; + 6003F58F195388D20070C39A /* CoreGraphics.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreGraphics.framework; path = System/Library/Frameworks/CoreGraphics.framework; sourceTree = SDKROOT; }; + 6003F591195388D20070C39A /* UIKit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = UIKit.framework; path = System/Library/Frameworks/UIKit.framework; sourceTree = SDKROOT; }; + 6003F595195388D20070C39A /* MnemonicsView-Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = "MnemonicsView-Info.plist"; sourceTree = ""; }; + 6003F597195388D20070C39A /* en */ = {isa = PBXFileReference; lastKnownFileType = text.plist.strings; name = en; path = en.lproj/InfoPlist.strings; sourceTree = ""; }; + 6003F599195388D20070C39A /* main.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = main.m; sourceTree = ""; }; + 6003F59B195388D20070C39A /* MnemonicsView-Prefix.pch */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "MnemonicsView-Prefix.pch"; sourceTree = ""; }; + 6003F59C195388D20070C39A /* AppDelegate.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = AppDelegate.h; sourceTree = ""; }; + 6003F59D195388D20070C39A /* AppDelegate.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = AppDelegate.m; sourceTree = ""; }; + 6003F5A5195388D20070C39A /* ViewController.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = ViewController.h; sourceTree = ""; }; + 6003F5A6195388D20070C39A /* ViewController.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = ViewController.m; sourceTree = ""; }; + 6003F5A8195388D20070C39A /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Images.xcassets; sourceTree = ""; }; + 6003F5AE195388D20070C39A /* MnemonicsView_Tests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = MnemonicsView_Tests.xctest; sourceTree = BUILT_PRODUCTS_DIR; }; + 6003F5AF195388D20070C39A /* XCTest.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = XCTest.framework; path = Library/Frameworks/XCTest.framework; sourceTree = DEVELOPER_DIR; }; + 6003F5B7195388D20070C39A /* Tests-Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = "Tests-Info.plist"; sourceTree = ""; }; + 6003F5B9195388D20070C39A /* en */ = {isa = PBXFileReference; lastKnownFileType = text.plist.strings; name = en; path = en.lproj/InfoPlist.strings; sourceTree = ""; }; + 6003F5BB195388D20070C39A /* Tests.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = Tests.m; sourceTree = ""; }; + 606FC2411953D9B200FFA9A0 /* Tests-Prefix.pch */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "Tests-Prefix.pch"; sourceTree = ""; }; + 71719F9E1E33DC2100824A3D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = ""; }; + 873B8AEA1B1F5CCA007FD442 /* Main.storyboard */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.storyboard; name = Main.storyboard; path = Base.lproj/Main.storyboard; sourceTree = ""; }; + A2418010382B14659CB6A9A7 /* Pods-MnemonicsView_Example.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-MnemonicsView_Example.release.xcconfig"; path = "Pods/Target Support Files/Pods-MnemonicsView_Example/Pods-MnemonicsView_Example.release.xcconfig"; sourceTree = ""; }; + CAEF3D0F0F0DA4B3366FC702 /* Pods_MnemonicsView_Example.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_MnemonicsView_Example.framework; sourceTree = BUILT_PRODUCTS_DIR; }; + E1BFE1B4E258CBBBF4B3D4B3 /* MnemonicsView.podspec */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text; name = MnemonicsView.podspec; path = ../MnemonicsView.podspec; sourceTree = ""; xcLanguageSpecificationIdentifier = xcode.lang.ruby; }; + E32680466EA02086FB76F4B7 /* LICENSE */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text; name = LICENSE; path = ../LICENSE; sourceTree = ""; }; + F5F45A36DF525E63009E7FEB /* Pods-MnemonicsView_Tests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-MnemonicsView_Tests.debug.xcconfig"; path = "Pods/Target Support Files/Pods-MnemonicsView_Tests/Pods-MnemonicsView_Tests.debug.xcconfig"; sourceTree = ""; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + 6003F587195388D20070C39A /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + 6003F590195388D20070C39A /* CoreGraphics.framework in Frameworks */, + 6003F592195388D20070C39A /* UIKit.framework in Frameworks */, + 6003F58E195388D20070C39A /* Foundation.framework in Frameworks */, + A891F0115DF118B40E04825C /* Pods_MnemonicsView_Example.framework in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 6003F5AB195388D20070C39A /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + 6003F5B0195388D20070C39A /* XCTest.framework in Frameworks */, + 6003F5B2195388D20070C39A /* UIKit.framework in Frameworks */, + 6003F5B1195388D20070C39A /* Foundation.framework in Frameworks */, + 5B92B3590303C1AC6EC82CED /* Pods_MnemonicsView_Tests.framework in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + 5193C448638E299990E7B203 /* Pods */ = { + isa = PBXGroup; + children = ( + 465095FA410AEB71D8770CF2 /* Pods-MnemonicsView_Example.debug.xcconfig */, + A2418010382B14659CB6A9A7 /* Pods-MnemonicsView_Example.release.xcconfig */, + F5F45A36DF525E63009E7FEB /* Pods-MnemonicsView_Tests.debug.xcconfig */, + 47D6ACD098C05C8F49BA3481 /* Pods-MnemonicsView_Tests.release.xcconfig */, + ); + name = Pods; + sourceTree = ""; + }; + 6003F581195388D10070C39A = { + isa = PBXGroup; + children = ( + 60FF7A9C1954A5C5007DD14C /* Podspec Metadata */, + 6003F593195388D20070C39A /* Example for MnemonicsView */, + 6003F5B5195388D20070C39A /* Tests */, + 6003F58C195388D20070C39A /* Frameworks */, + 6003F58B195388D20070C39A /* Products */, + 5193C448638E299990E7B203 /* Pods */, + ); + sourceTree = ""; + }; + 6003F58B195388D20070C39A /* Products */ = { + isa = PBXGroup; + children = ( + 6003F58A195388D20070C39A /* MnemonicsView_Example.app */, + 6003F5AE195388D20070C39A /* MnemonicsView_Tests.xctest */, + ); + name = Products; + sourceTree = ""; + }; + 6003F58C195388D20070C39A /* Frameworks */ = { + isa = PBXGroup; + children = ( + 6003F58D195388D20070C39A /* Foundation.framework */, + 6003F58F195388D20070C39A /* CoreGraphics.framework */, + 6003F591195388D20070C39A /* UIKit.framework */, + 6003F5AF195388D20070C39A /* XCTest.framework */, + CAEF3D0F0F0DA4B3366FC702 /* Pods_MnemonicsView_Example.framework */, + 3D6CDA666572C550B6439C6C /* Pods_MnemonicsView_Tests.framework */, + ); + name = Frameworks; + sourceTree = ""; + }; + 6003F593195388D20070C39A /* Example for MnemonicsView */ = { + isa = PBXGroup; + children = ( + 6003F59C195388D20070C39A /* AppDelegate.h */, + 6003F59D195388D20070C39A /* AppDelegate.m */, + 873B8AEA1B1F5CCA007FD442 /* Main.storyboard */, + 6003F5A5195388D20070C39A /* ViewController.h */, + 6003F5A6195388D20070C39A /* ViewController.m */, + 71719F9D1E33DC2100824A3D /* LaunchScreen.storyboard */, + 6003F5A8195388D20070C39A /* Images.xcassets */, + 6003F594195388D20070C39A /* Supporting Files */, + ); + name = "Example for MnemonicsView"; + path = MnemonicsView; + sourceTree = ""; + }; + 6003F594195388D20070C39A /* Supporting Files */ = { + isa = PBXGroup; + children = ( + 6003F595195388D20070C39A /* MnemonicsView-Info.plist */, + 6003F596195388D20070C39A /* InfoPlist.strings */, + 6003F599195388D20070C39A /* main.m */, + 6003F59B195388D20070C39A /* MnemonicsView-Prefix.pch */, + ); + name = "Supporting Files"; + sourceTree = ""; + }; + 6003F5B5195388D20070C39A /* Tests */ = { + isa = PBXGroup; + children = ( + 6003F5BB195388D20070C39A /* Tests.m */, + 6003F5B6195388D20070C39A /* Supporting Files */, + ); + path = Tests; + sourceTree = ""; + }; + 6003F5B6195388D20070C39A /* Supporting Files */ = { + isa = PBXGroup; + children = ( + 6003F5B7195388D20070C39A /* Tests-Info.plist */, + 6003F5B8195388D20070C39A /* InfoPlist.strings */, + 606FC2411953D9B200FFA9A0 /* Tests-Prefix.pch */, + ); + name = "Supporting Files"; + sourceTree = ""; + }; + 60FF7A9C1954A5C5007DD14C /* Podspec Metadata */ = { + isa = PBXGroup; + children = ( + E1BFE1B4E258CBBBF4B3D4B3 /* MnemonicsView.podspec */, + 09EDD63B9EDA6FA00558AF3E /* README.md */, + E32680466EA02086FB76F4B7 /* LICENSE */, + ); + name = "Podspec Metadata"; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXNativeTarget section */ + 6003F589195388D20070C39A /* MnemonicsView_Example */ = { + isa = PBXNativeTarget; + buildConfigurationList = 6003F5BF195388D20070C39A /* Build configuration list for PBXNativeTarget "MnemonicsView_Example" */; + buildPhases = ( + E57D5C63DEAF94CC47890481 /* [CP] Check Pods Manifest.lock */, + 6003F586195388D20070C39A /* Sources */, + 6003F587195388D20070C39A /* Frameworks */, + 6003F588195388D20070C39A /* Resources */, + B655363977E63B96286EEAD1 /* [CP] Embed Pods Frameworks */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = MnemonicsView_Example; + productName = MnemonicsView; + productReference = 6003F58A195388D20070C39A /* MnemonicsView_Example.app */; + productType = "com.apple.product-type.application"; + }; + 6003F5AD195388D20070C39A /* MnemonicsView_Tests */ = { + isa = PBXNativeTarget; + buildConfigurationList = 6003F5C2195388D20070C39A /* Build configuration list for PBXNativeTarget "MnemonicsView_Tests" */; + buildPhases = ( + 749AB415822936BCD27C4F99 /* [CP] Check Pods Manifest.lock */, + 6003F5AA195388D20070C39A /* Sources */, + 6003F5AB195388D20070C39A /* Frameworks */, + 6003F5AC195388D20070C39A /* Resources */, + D86F0493CEB9664CA43EF20C /* [CP] Embed Pods Frameworks */, + ); + buildRules = ( + ); + dependencies = ( + 6003F5B4195388D20070C39A /* PBXTargetDependency */, + ); + name = MnemonicsView_Tests; + productName = MnemonicsViewTests; + productReference = 6003F5AE195388D20070C39A /* MnemonicsView_Tests.xctest */; + productType = "com.apple.product-type.bundle.unit-test"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + 6003F582195388D10070C39A /* Project object */ = { + isa = PBXProject; + attributes = { + CLASSPREFIX = ""; + LastUpgradeCheck = 0720; + ORGANIZATIONNAME = "Mikhail Nikanorov"; + TargetAttributes = { + 6003F5AD195388D20070C39A = { + TestTargetID = 6003F589195388D20070C39A; + }; + }; + }; + buildConfigurationList = 6003F585195388D10070C39A /* Build configuration list for PBXProject "MnemonicsView" */; + compatibilityVersion = "Xcode 3.2"; + developmentRegion = English; + hasScannedForEncodings = 0; + knownRegions = ( + en, + Base, + ); + mainGroup = 6003F581195388D10070C39A; + productRefGroup = 6003F58B195388D20070C39A /* Products */; + projectDirPath = ""; + projectRoot = ""; + targets = ( + 6003F589195388D20070C39A /* MnemonicsView_Example */, + 6003F5AD195388D20070C39A /* MnemonicsView_Tests */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXResourcesBuildPhase section */ + 6003F588195388D20070C39A /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 873B8AEB1B1F5CCA007FD442 /* Main.storyboard in Resources */, + 71719F9F1E33DC2100824A3D /* LaunchScreen.storyboard in Resources */, + 6003F5A9195388D20070C39A /* Images.xcassets in Resources */, + 6003F598195388D20070C39A /* InfoPlist.strings in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 6003F5AC195388D20070C39A /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 6003F5BA195388D20070C39A /* InfoPlist.strings in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXResourcesBuildPhase section */ + +/* Begin PBXShellScriptBuildPhase section */ + 749AB415822936BCD27C4F99 /* [CP] Check Pods Manifest.lock */ = { + isa = PBXShellScriptBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + inputFileListPaths = ( + ); + inputPaths = ( + "${PODS_PODFILE_DIR_PATH}/Podfile.lock", + "${PODS_ROOT}/Manifest.lock", + ); + name = "[CP] Check Pods Manifest.lock"; + outputFileListPaths = ( + ); + outputPaths = ( + "$(DERIVED_FILE_DIR)/Pods-MnemonicsView_Tests-checkManifestLockResult.txt", + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n"; + showEnvVarsInLog = 0; + }; + B655363977E63B96286EEAD1 /* [CP] Embed Pods Frameworks */ = { + isa = PBXShellScriptBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + inputFileListPaths = ( + ); + inputPaths = ( + "${SRCROOT}/Pods/Target Support Files/Pods-MnemonicsView_Example/Pods-MnemonicsView_Example-frameworks.sh", + "${BUILT_PRODUCTS_DIR}/MnemonicsView/MnemonicsView.framework", + ); + name = "[CP] Embed Pods Frameworks"; + outputFileListPaths = ( + ); + outputPaths = ( + "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/MnemonicsView.framework", + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "\"${SRCROOT}/Pods/Target Support Files/Pods-MnemonicsView_Example/Pods-MnemonicsView_Example-frameworks.sh\"\n"; + showEnvVarsInLog = 0; + }; + D86F0493CEB9664CA43EF20C /* [CP] Embed Pods Frameworks */ = { + isa = PBXShellScriptBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + inputFileListPaths = ( + ); + inputPaths = ( + "${SRCROOT}/Pods/Target Support Files/Pods-MnemonicsView_Tests/Pods-MnemonicsView_Tests-frameworks.sh", + "${BUILT_PRODUCTS_DIR}/FBSnapshotTestCase/FBSnapshotTestCase.framework", + ); + name = "[CP] Embed Pods Frameworks"; + outputFileListPaths = ( + ); + outputPaths = ( + "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/FBSnapshotTestCase.framework", + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "\"${SRCROOT}/Pods/Target Support Files/Pods-MnemonicsView_Tests/Pods-MnemonicsView_Tests-frameworks.sh\"\n"; + showEnvVarsInLog = 0; + }; + E57D5C63DEAF94CC47890481 /* [CP] Check Pods Manifest.lock */ = { + isa = PBXShellScriptBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + inputFileListPaths = ( + ); + inputPaths = ( + "${PODS_PODFILE_DIR_PATH}/Podfile.lock", + "${PODS_ROOT}/Manifest.lock", + ); + name = "[CP] Check Pods Manifest.lock"; + outputFileListPaths = ( + ); + outputPaths = ( + "$(DERIVED_FILE_DIR)/Pods-MnemonicsView_Example-checkManifestLockResult.txt", + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n"; + showEnvVarsInLog = 0; + }; +/* End PBXShellScriptBuildPhase section */ + +/* Begin PBXSourcesBuildPhase section */ + 6003F586195388D20070C39A /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 6003F59E195388D20070C39A /* AppDelegate.m in Sources */, + 6003F5A7195388D20070C39A /* ViewController.m in Sources */, + 6003F59A195388D20070C39A /* main.m in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 6003F5AA195388D20070C39A /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 6003F5BC195388D20070C39A /* Tests.m in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin PBXTargetDependency section */ + 6003F5B4195388D20070C39A /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = 6003F589195388D20070C39A /* MnemonicsView_Example */; + targetProxy = 6003F5B3195388D20070C39A /* PBXContainerItemProxy */; + }; +/* End PBXTargetDependency section */ + +/* Begin PBXVariantGroup section */ + 6003F596195388D20070C39A /* InfoPlist.strings */ = { + isa = PBXVariantGroup; + children = ( + 6003F597195388D20070C39A /* en */, + ); + name = InfoPlist.strings; + sourceTree = ""; + }; + 6003F5B8195388D20070C39A /* InfoPlist.strings */ = { + isa = PBXVariantGroup; + children = ( + 6003F5B9195388D20070C39A /* en */, + ); + name = InfoPlist.strings; + sourceTree = ""; + }; + 71719F9D1E33DC2100824A3D /* LaunchScreen.storyboard */ = { + isa = PBXVariantGroup; + children = ( + 71719F9E1E33DC2100824A3D /* Base */, + ); + name = LaunchScreen.storyboard; + sourceTree = ""; + }; +/* End PBXVariantGroup section */ + +/* Begin XCBuildConfiguration section */ + 6003F5BD195388D20070C39A /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_SYMBOLS_PRIVATE_EXTERN = NO; + 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.3; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Debug; + }; + 6003F5BE195388D20070C39A /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = YES; + ENABLE_NS_ASSERTIONS = NO; + GCC_C_LANGUAGE_STANDARD = gnu99; + 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.3; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VALIDATE_PRODUCT = YES; + }; + name = Release; + }; + 6003F5C0195388D20070C39A /* Debug */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 465095FA410AEB71D8770CF2 /* Pods-MnemonicsView_Example.debug.xcconfig */; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + GCC_PRECOMPILE_PREFIX_HEADER = YES; + GCC_PREFIX_HEADER = "MnemonicsView/MnemonicsView-Prefix.pch"; + INFOPLIST_FILE = "MnemonicsView/MnemonicsView-Info.plist"; + MODULE_NAME = ExampleApp; + PRODUCT_BUNDLE_IDENTIFIER = "org.cocoapods.demo.${PRODUCT_NAME:rfc1034identifier}"; + PRODUCT_NAME = "$(TARGET_NAME)"; + WRAPPER_EXTENSION = app; + }; + name = Debug; + }; + 6003F5C1195388D20070C39A /* Release */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = A2418010382B14659CB6A9A7 /* Pods-MnemonicsView_Example.release.xcconfig */; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + GCC_PRECOMPILE_PREFIX_HEADER = YES; + GCC_PREFIX_HEADER = "MnemonicsView/MnemonicsView-Prefix.pch"; + INFOPLIST_FILE = "MnemonicsView/MnemonicsView-Info.plist"; + MODULE_NAME = ExampleApp; + PRODUCT_BUNDLE_IDENTIFIER = "org.cocoapods.demo.${PRODUCT_NAME:rfc1034identifier}"; + PRODUCT_NAME = "$(TARGET_NAME)"; + WRAPPER_EXTENSION = app; + }; + name = Release; + }; + 6003F5C3195388D20070C39A /* Debug */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = F5F45A36DF525E63009E7FEB /* Pods-MnemonicsView_Tests.debug.xcconfig */; + buildSettings = { + BUNDLE_LOADER = "$(TEST_HOST)"; + FRAMEWORK_SEARCH_PATHS = ( + "$(SDKROOT)/Developer/Library/Frameworks", + "$(inherited)", + "$(DEVELOPER_FRAMEWORKS_DIR)", + ); + GCC_PRECOMPILE_PREFIX_HEADER = YES; + GCC_PREFIX_HEADER = "Tests/Tests-Prefix.pch"; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + INFOPLIST_FILE = "Tests/Tests-Info.plist"; + PRODUCT_BUNDLE_IDENTIFIER = "org.cocoapods.demo.${PRODUCT_NAME:rfc1034identifier}"; + PRODUCT_NAME = "$(TARGET_NAME)"; + TEST_HOST = "$(BUILT_PRODUCTS_DIR)/MnemonicsView_Example.app/MnemonicsView_Example"; + WRAPPER_EXTENSION = xctest; + }; + name = Debug; + }; + 6003F5C4195388D20070C39A /* Release */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 47D6ACD098C05C8F49BA3481 /* Pods-MnemonicsView_Tests.release.xcconfig */; + buildSettings = { + BUNDLE_LOADER = "$(TEST_HOST)"; + FRAMEWORK_SEARCH_PATHS = ( + "$(SDKROOT)/Developer/Library/Frameworks", + "$(inherited)", + "$(DEVELOPER_FRAMEWORKS_DIR)", + ); + GCC_PRECOMPILE_PREFIX_HEADER = YES; + GCC_PREFIX_HEADER = "Tests/Tests-Prefix.pch"; + INFOPLIST_FILE = "Tests/Tests-Info.plist"; + PRODUCT_BUNDLE_IDENTIFIER = "org.cocoapods.demo.${PRODUCT_NAME:rfc1034identifier}"; + PRODUCT_NAME = "$(TARGET_NAME)"; + TEST_HOST = "$(BUILT_PRODUCTS_DIR)/MnemonicsView_Example.app/MnemonicsView_Example"; + WRAPPER_EXTENSION = xctest; + }; + name = Release; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 6003F585195388D10070C39A /* Build configuration list for PBXProject "MnemonicsView" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 6003F5BD195388D20070C39A /* Debug */, + 6003F5BE195388D20070C39A /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 6003F5BF195388D20070C39A /* Build configuration list for PBXNativeTarget "MnemonicsView_Example" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 6003F5C0195388D20070C39A /* Debug */, + 6003F5C1195388D20070C39A /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 6003F5C2195388D20070C39A /* Build configuration list for PBXNativeTarget "MnemonicsView_Tests" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 6003F5C3195388D20070C39A /* Debug */, + 6003F5C4195388D20070C39A /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + }; + rootObject = 6003F582195388D10070C39A /* Project object */; +} diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/DevelopPods/MnemonicsView/Example/MnemonicsView.xcodeproj/project.xcworkspace/contents.xcworkspacedata new file mode 100644 index 0000000..07ab5f3 --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView.xcodeproj/project.xcworkspace/contents.xcworkspacedata @@ -0,0 +1,7 @@ + + + + + diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView.xcodeproj/xcshareddata/xcschemes/MnemonicsView-Example.xcscheme b/DevelopPods/MnemonicsView/Example/MnemonicsView.xcodeproj/xcshareddata/xcschemes/MnemonicsView-Example.xcscheme new file mode 100644 index 0000000..a82a40e --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView.xcodeproj/xcshareddata/xcschemes/MnemonicsView-Example.xcscheme @@ -0,0 +1,101 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView.xcworkspace/contents.xcworkspacedata b/DevelopPods/MnemonicsView/Example/MnemonicsView.xcworkspace/contents.xcworkspacedata new file mode 100644 index 0000000..034d693 --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView.xcworkspace/contents.xcworkspacedata @@ -0,0 +1,10 @@ + + + + + + + diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/DevelopPods/MnemonicsView/Example/MnemonicsView.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist new file mode 100644 index 0000000..18d9810 --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist @@ -0,0 +1,8 @@ + + + + + IDEDidComputeMac32BitWarning + + + diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView/AppDelegate.h b/DevelopPods/MnemonicsView/Example/MnemonicsView/AppDelegate.h new file mode 100644 index 0000000..968f9c9 --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView/AppDelegate.h @@ -0,0 +1,15 @@ +// +// AppDelegate.h +// MnemonicsView +// +// Created by Mikhail Nikanorov. +// Copyright (c) 2018 Mikhail Nikanorov. All rights reserved. +// + +@import UIKit; + +@interface AppDelegate : UIResponder + +@property (strong, nonatomic) UIWindow *window; + +@end diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView/AppDelegate.m b/DevelopPods/MnemonicsView/Example/MnemonicsView/AppDelegate.m new file mode 100644 index 0000000..23b1ac7 --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView/AppDelegate.m @@ -0,0 +1,46 @@ +// +// AppDelegate.m +// MnemonicsView +// +// Created by Mikhail Nikanorov. +// Copyright (c) 2018 Mikhail Nikanorov. All rights reserved. +// + +#import "AppDelegate.h" + +@implementation AppDelegate + +- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions +{ + // Override point for customization after application launch. + return YES; +} + +- (void)applicationWillResignActive:(UIApplication *)application +{ + // 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 throttle down OpenGL ES frame rates. Games should use this method to pause the game. +} + +- (void)applicationDidEnterBackground:(UIApplication *)application +{ + // 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. +} + +- (void)applicationWillEnterForeground:(UIApplication *)application +{ + // Called as part of the transition from the background to the inactive state; here you can undo many of the changes made on entering the background. +} + +- (void)applicationDidBecomeActive:(UIApplication *)application +{ + // 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. +} + +- (void)applicationWillTerminate:(UIApplication *)application +{ + // Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:. +} + +@end diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView/Base.lproj/LaunchScreen.storyboard b/DevelopPods/MnemonicsView/Example/MnemonicsView/Base.lproj/LaunchScreen.storyboard new file mode 100644 index 0000000..fc810a6 --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView/Base.lproj/LaunchScreen.storyboard @@ -0,0 +1,31 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView/Base.lproj/Main.storyboard b/DevelopPods/MnemonicsView/Example/MnemonicsView/Base.lproj/Main.storyboard new file mode 100644 index 0000000..352290e --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView/Base.lproj/Main.storyboard @@ -0,0 +1,71 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView/Images.xcassets/AppIcon.appiconset/Contents.json b/DevelopPods/MnemonicsView/Example/MnemonicsView/Images.xcassets/AppIcon.appiconset/Contents.json new file mode 100644 index 0000000..b542ec2 --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView/Images.xcassets/AppIcon.appiconset/Contents.json @@ -0,0 +1,98 @@ +{ + "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" + } +} diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView/MnemonicsView-Info.plist b/DevelopPods/MnemonicsView/Example/MnemonicsView/MnemonicsView-Info.plist new file mode 100644 index 0000000..7576a0d --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView/MnemonicsView-Info.plist @@ -0,0 +1,49 @@ + + + + + CFBundleDevelopmentRegion + en + CFBundleDisplayName + ${PRODUCT_NAME} + CFBundleExecutable + ${EXECUTABLE_NAME} + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + ${PRODUCT_NAME} + CFBundlePackageType + APPL + CFBundleShortVersionString + 1.0 + CFBundleSignature + ???? + CFBundleVersion + 1.0 + LSRequiresIPhoneOS + + UILaunchStoryboardName + LaunchScreen + UIMainStoryboardFile + Main + UIRequiredDeviceCapabilities + + armv7 + + UISupportedInterfaceOrientations + + UIInterfaceOrientationPortrait + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + UISupportedInterfaceOrientations~ipad + + UIInterfaceOrientationPortrait + UIInterfaceOrientationPortraitUpsideDown + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + + diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView/MnemonicsView-Prefix.pch b/DevelopPods/MnemonicsView/Example/MnemonicsView/MnemonicsView-Prefix.pch new file mode 100644 index 0000000..7825372 --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView/MnemonicsView-Prefix.pch @@ -0,0 +1,16 @@ +// +// Prefix header +// +// The contents of this file are implicitly included at the beginning of every source file. +// + +#import + +#ifndef __IPHONE_5_0 +#warning "This project uses features only available in iOS SDK 5.0 and later." +#endif + +#ifdef __OBJC__ + @import UIKit; + @import Foundation; +#endif diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView/ViewController.h b/DevelopPods/MnemonicsView/Example/MnemonicsView/ViewController.h new file mode 100644 index 0000000..79da8ce --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView/ViewController.h @@ -0,0 +1,13 @@ +// +// ViewController.h +// MnemonicsView +// +// Created by Mikhail Nikanorov. +// Copyright (c) 2018 Mikhail Nikanorov. All rights reserved. +// + +@import UIKit; + +@interface ViewController : UIViewController + +@end diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView/ViewController.m b/DevelopPods/MnemonicsView/Example/MnemonicsView/ViewController.m new file mode 100644 index 0000000..b3885b2 --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView/ViewController.m @@ -0,0 +1,29 @@ +// +// ViewController.m +// MnemonicsView +// +// Created by Mikhail Nikanorov. +// Copyright (c) 2018 Mikhail Nikanorov. All rights reserved. +// + +#import "ViewController.h" + +@interface ViewController () + +@end + +@implementation ViewController + +- (void)viewDidLoad +{ + [super viewDidLoad]; + // Do any additional setup after loading the view, typically from a nib. +} + +- (void)didReceiveMemoryWarning +{ + [super didReceiveMemoryWarning]; + // Dispose of any resources that can be recreated. +} + +@end diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView/en.lproj/InfoPlist.strings b/DevelopPods/MnemonicsView/Example/MnemonicsView/en.lproj/InfoPlist.strings new file mode 100644 index 0000000..477b28f --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView/en.lproj/InfoPlist.strings @@ -0,0 +1,2 @@ +/* Localized versions of Info.plist keys */ + diff --git a/DevelopPods/MnemonicsView/Example/MnemonicsView/main.m b/DevelopPods/MnemonicsView/Example/MnemonicsView/main.m new file mode 100644 index 0000000..ec90a83 --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/MnemonicsView/main.m @@ -0,0 +1,17 @@ +// +// main.m +// MnemonicsView +// +// Created by Mikhail Nikanorov. +// Copyright (c) 2018 Mikhail Nikanorov. All rights reserved. +// + +@import UIKit; +#import "AppDelegate.h" + +int main(int argc, char * argv[]) +{ + @autoreleasepool { + return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class])); + } +} diff --git a/DevelopPods/MnemonicsView/Example/Podfile b/DevelopPods/MnemonicsView/Example/Podfile new file mode 100644 index 0000000..8fc8a95 --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/Podfile @@ -0,0 +1,13 @@ +use_frameworks! + +platform :ios, '9.0' + +target 'MnemonicsView_Example' do + pod 'MnemonicsView', :path => '../' + + target 'MnemonicsView_Tests' do + inherit! :search_paths + + pod 'FBSnapshotTestCase' + end +end diff --git a/DevelopPods/MnemonicsView/Example/Tests/Tests-Info.plist b/DevelopPods/MnemonicsView/Example/Tests/Tests-Info.plist new file mode 100644 index 0000000..169b6f7 --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/Tests/Tests-Info.plist @@ -0,0 +1,22 @@ + + + + + CFBundleDevelopmentRegion + en + CFBundleExecutable + ${EXECUTABLE_NAME} + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundlePackageType + BNDL + CFBundleShortVersionString + 1.0 + CFBundleSignature + ???? + CFBundleVersion + 1 + + diff --git a/DevelopPods/MnemonicsView/Example/Tests/Tests-Prefix.pch b/DevelopPods/MnemonicsView/Example/Tests/Tests-Prefix.pch new file mode 100644 index 0000000..3cbb902 --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/Tests/Tests-Prefix.pch @@ -0,0 +1,7 @@ +// The contents of this file are implicitly included at the beginning of every test case source file. + +#ifdef __OBJC__ + + @import FBSnapshotTestCase; + +#endif diff --git a/DevelopPods/MnemonicsView/Example/Tests/Tests.m b/DevelopPods/MnemonicsView/Example/Tests/Tests.m new file mode 100644 index 0000000..90a386e --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/Tests/Tests.m @@ -0,0 +1,35 @@ +// +// MnemonicsViewTests.m +// MnemonicsViewTests +// +// Created by Mikhail Nikanorov. +// Copyright (c) 2018 Mikhail Nikanorov. All rights reserved. +// + +@import XCTest; + +@interface Tests : XCTestCase + +@end + +@implementation Tests + +- (void)setUp +{ + [super setUp]; + // Put setup code here. This method is called before the invocation of each test method in the class. +} + +- (void)tearDown +{ + // Put teardown code here. This method is called after the invocation of each test method in the class. + [super tearDown]; +} + +- (void)testExample +{ + XCTFail(@"No implementation for \"%s\"", __PRETTY_FUNCTION__); +} + +@end + diff --git a/DevelopPods/MnemonicsView/Example/Tests/en.lproj/InfoPlist.strings b/DevelopPods/MnemonicsView/Example/Tests/en.lproj/InfoPlist.strings new file mode 100644 index 0000000..477b28f --- /dev/null +++ b/DevelopPods/MnemonicsView/Example/Tests/en.lproj/InfoPlist.strings @@ -0,0 +1,2 @@ +/* Localized versions of Info.plist keys */ + diff --git a/DevelopPods/MnemonicsView/LICENSE b/DevelopPods/MnemonicsView/LICENSE new file mode 100644 index 0000000..568f5c1 --- /dev/null +++ b/DevelopPods/MnemonicsView/LICENSE @@ -0,0 +1,19 @@ +Copyright (c) 2019 + +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. diff --git a/DevelopPods/MnemonicsView/MnemonicsView.podspec b/DevelopPods/MnemonicsView/MnemonicsView.podspec new file mode 100644 index 0000000..9098866 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView.podspec @@ -0,0 +1,39 @@ +# +# Be sure to run `pod lib lint MnemonicsView.podspec' to ensure this is a +# valid spec before submitting. +# +# Any lines starting with a # are optional, but their use is encouraged +# To learn more about a Podspec see https://guides.cocoapods.org/syntax/podspec.html +# + +Pod::Spec.new do |s| + s.name = 'MnemonicsView' + s.version = '0.1.0' + s.summary = 'A short description of MnemonicsView.' + +# This description is used to generate tags and improve search results. +# * Think: What does it do? Why did you write it? What is the focus? +# * Try to keep it short, snappy and to the point. +# * Write the description between the DESC delimiters below. +# * Finally, don't worry about the indent, CocoaPods strips it! + + s.description = <<-DESC +TODO: Add long description of the pod here. + DESC + + s.homepage = 'github link' + # s.screenshots = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2' + s.license = { :type => 'MIT', :file => 'LICENSE' } + s.author = { 'Mikhail Nikanorov' => '' } + s.source = { :git => 'github link', :tag => s.version.to_s } + + s.ios.deployment_target = '9.0' + + s.source_files = 'MnemonicsView/Classes/**/*' + + s.resources = 'MnemonicsView/Assets/**/*.txt' + + # s.public_header_files = 'Pod/Classes/**/*.h' + # s.frameworks = 'UIKit', 'MapKit' + # s.dependency 'AFNetworking', '~> 2.3' +end diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Assets/.gitkeep b/DevelopPods/MnemonicsView/MnemonicsView/Assets/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/chinese_simplified.txt b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/chinese_simplified.txt new file mode 100755 index 0000000..b90f1ed --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/chinese_simplified.txt @@ -0,0 +1,2048 @@ +的 +一 +是 +在 +不 +了 +有 +和 +人 +这 +中 +大 +为 +上 +个 +国 +我 +以 +要 +他 +时 +来 +用 +们 +生 +到 +作 +地 +于 +出 +就 +分 +对 +成 +会 +可 +主 +发 +年 +动 +同 +工 +也 +能 +下 +过 +子 +说 +产 +种 +面 +而 +方 +后 +多 +定 +行 +学 +法 +所 +民 +得 +经 +十 +三 +之 +进 +着 +等 +部 +度 +家 +电 +力 +里 +如 +水 +化 +高 +自 +二 +理 +起 +小 +物 +现 +实 +加 +量 +都 +两 +体 +制 +机 +当 +使 +点 +从 +业 +本 +去 +把 +性 +好 +应 +开 +它 +合 +还 +因 +由 +其 +些 +然 +前 +外 +天 +政 +四 +日 +那 +社 +义 +事 +平 +形 +相 +全 +表 +间 +样 +与 +关 +各 +重 +新 +线 +内 +数 +正 +心 +反 +你 +明 +看 +原 +又 +么 +利 +比 +或 +但 +质 +气 +第 +向 +道 +命 +此 +变 +条 +只 +没 +结 +解 +问 +意 +建 +月 +公 +无 +系 +军 +很 +情 +者 +最 +立 +代 +想 +已 +通 +并 +提 +直 +题 +党 +程 +展 +五 +果 +料 +象 +员 +革 +位 +入 +常 +文 +总 +次 +品 +式 +活 +设 +及 +管 +特 +件 +长 +求 +老 +头 +基 +资 +边 +流 +路 +级 +少 +图 +山 +统 +接 +知 +较 +将 +组 +见 +计 +别 +她 +手 +角 +期 +根 +论 +运 +农 +指 +几 +九 +区 +强 +放 +决 +西 +被 +干 +做 +必 +战 +先 +回 +则 +任 +取 +据 +处 +队 +南 +给 +色 +光 +门 +即 +保 +治 +北 +造 +百 +规 +热 +领 +七 +海 +口 +东 +导 +器 +压 +志 +世 +金 +增 +争 +济 +阶 +油 +思 +术 +极 +交 +受 +联 +什 +认 +六 +共 +权 +收 +证 +改 +清 +美 +再 +采 +转 +更 +单 +风 +切 +打 +白 +教 +速 +花 +带 +安 +场 +身 +车 +例 +真 +务 +具 +万 +每 +目 +至 +达 +走 +积 +示 +议 +声 +报 +斗 +完 +类 +八 +离 +华 +名 +确 +才 +科 +张 +信 +马 +节 +话 +米 +整 +空 +元 +况 +今 +集 +温 +传 +土 +许 +步 +群 +广 +石 +记 +需 +段 +研 +界 +拉 +林 +律 +叫 +且 +究 +观 +越 +织 +装 +影 +算 +低 +持 +音 +众 +书 +布 +复 +容 +儿 +须 +际 +商 +非 +验 +连 +断 +深 +难 +近 +矿 +千 +周 +委 +素 +技 +备 +半 +办 +青 +省 +列 +习 +响 +约 +支 +般 +史 +感 +劳 +便 +团 +往 +酸 +历 +市 +克 +何 +除 +消 +构 +府 +称 +太 +准 +精 +值 +号 +率 +族 +维 +划 +选 +标 +写 +存 +候 +毛 +亲 +快 +效 +斯 +院 +查 +江 +型 +眼 +王 +按 +格 +养 +易 +置 +派 +层 +片 +始 +却 +专 +状 +育 +厂 +京 +识 +适 +属 +圆 +包 +火 +住 +调 +满 +县 +局 +照 +参 +红 +细 +引 +听 +该 +铁 +价 +严 +首 +底 +液 +官 +德 +随 +病 +苏 +失 +尔 +死 +讲 +配 +女 +黄 +推 +显 +谈 +罪 +神 +艺 +呢 +席 +含 +企 +望 +密 +批 +营 +项 +防 +举 +球 +英 +氧 +势 +告 +李 +台 +落 +木 +帮 +轮 +破 +亚 +师 +围 +注 +远 +字 +材 +排 +供 +河 +态 +封 +另 +施 +减 +树 +溶 +怎 +止 +案 +言 +士 +均 +武 +固 +叶 +鱼 +波 +视 +仅 +费 +紧 +爱 +左 +章 +早 +朝 +害 +续 +轻 +服 +试 +食 +充 +兵 +源 +判 +护 +司 +足 +某 +练 +差 +致 +板 +田 +降 +黑 +犯 +负 +击 +范 +继 +兴 +似 +余 +坚 +曲 +输 +修 +故 +城 +夫 +够 +送 +笔 +船 +占 +右 +财 +吃 +富 +春 +职 +觉 +汉 +画 +功 +巴 +跟 +虽 +杂 +飞 +检 +吸 +助 +升 +阳 +互 +初 +创 +抗 +考 +投 +坏 +策 +古 +径 +换 +未 +跑 +留 +钢 +曾 +端 +责 +站 +简 +述 +钱 +副 +尽 +帝 +射 +草 +冲 +承 +独 +令 +限 +阿 +宣 +环 +双 +请 +超 +微 +让 +控 +州 +良 +轴 +找 +否 +纪 +益 +依 +优 +顶 +础 +载 +倒 +房 +突 +坐 +粉 +敌 +略 +客 +袁 +冷 +胜 +绝 +析 +块 +剂 +测 +丝 +协 +诉 +念 +陈 +仍 +罗 +盐 +友 +洋 +错 +苦 +夜 +刑 +移 +频 +逐 +靠 +混 +母 +短 +皮 +终 +聚 +汽 +村 +云 +哪 +既 +距 +卫 +停 +烈 +央 +察 +烧 +迅 +境 +若 +印 +洲 +刻 +括 +激 +孔 +搞 +甚 +室 +待 +核 +校 +散 +侵 +吧 +甲 +游 +久 +菜 +味 +旧 +模 +湖 +货 +损 +预 +阻 +毫 +普 +稳 +乙 +妈 +植 +息 +扩 +银 +语 +挥 +酒 +守 +拿 +序 +纸 +医 +缺 +雨 +吗 +针 +刘 +啊 +急 +唱 +误 +训 +愿 +审 +附 +获 +茶 +鲜 +粮 +斤 +孩 +脱 +硫 +肥 +善 +龙 +演 +父 +渐 +血 +欢 +械 +掌 +歌 +沙 +刚 +攻 +谓 +盾 +讨 +晚 +粒 +乱 +燃 +矛 +乎 +杀 +药 +宁 +鲁 +贵 +钟 +煤 +读 +班 +伯 +香 +介 +迫 +句 +丰 +培 +握 +兰 +担 +弦 +蛋 +沉 +假 +穿 +执 +答 +乐 +谁 +顺 +烟 +缩 +征 +脸 +喜 +松 +脚 +困 +异 +免 +背 +星 +福 +买 +染 +井 +概 +慢 +怕 +磁 +倍 +祖 +皇 +促 +静 +补 +评 +翻 +肉 +践 +尼 +衣 +宽 +扬 +棉 +希 +伤 +操 +垂 +秋 +宜 +氢 +套 +督 +振 +架 +亮 +末 +宪 +庆 +编 +牛 +触 +映 +雷 +销 +诗 +座 +居 +抓 +裂 +胞 +呼 +娘 +景 +威 +绿 +晶 +厚 +盟 +衡 +鸡 +孙 +延 +危 +胶 +屋 +乡 +临 +陆 +顾 +掉 +呀 +灯 +岁 +措 +束 +耐 +剧 +玉 +赵 +跳 +哥 +季 +课 +凯 +胡 +额 +款 +绍 +卷 +齐 +伟 +蒸 +殖 +永 +宗 +苗 +川 +炉 +岩 +弱 +零 +杨 +奏 +沿 +露 +杆 +探 +滑 +镇 +饭 +浓 +航 +怀 +赶 +库 +夺 +伊 +灵 +税 +途 +灭 +赛 +归 +召 +鼓 +播 +盘 +裁 +险 +康 +唯 +录 +菌 +纯 +借 +糖 +盖 +横 +符 +私 +努 +堂 +域 +枪 +润 +幅 +哈 +竟 +熟 +虫 +泽 +脑 +壤 +碳 +欧 +遍 +侧 +寨 +敢 +彻 +虑 +斜 +薄 +庭 +纳 +弹 +饲 +伸 +折 +麦 +湿 +暗 +荷 +瓦 +塞 +床 +筑 +恶 +户 +访 +塔 +奇 +透 +梁 +刀 +旋 +迹 +卡 +氯 +遇 +份 +毒 +泥 +退 +洗 +摆 +灰 +彩 +卖 +耗 +夏 +择 +忙 +铜 +献 +硬 +予 +繁 +圈 +雪 +函 +亦 +抽 +篇 +阵 +阴 +丁 +尺 +追 +堆 +雄 +迎 +泛 +爸 +楼 +避 +谋 +吨 +野 +猪 +旗 +累 +偏 +典 +馆 +索 +秦 +脂 +潮 +爷 +豆 +忽 +托 +惊 +塑 +遗 +愈 +朱 +替 +纤 +粗 +倾 +尚 +痛 +楚 +谢 +奋 +购 +磨 +君 +池 +旁 +碎 +骨 +监 +捕 +弟 +暴 +割 +贯 +殊 +释 +词 +亡 +壁 +顿 +宝 +午 +尘 +闻 +揭 +炮 +残 +冬 +桥 +妇 +警 +综 +招 +吴 +付 +浮 +遭 +徐 +您 +摇 +谷 +赞 +箱 +隔 +订 +男 +吹 +园 +纷 +唐 +败 +宋 +玻 +巨 +耕 +坦 +荣 +闭 +湾 +键 +凡 +驻 +锅 +救 +恩 +剥 +凝 +碱 +齿 +截 +炼 +麻 +纺 +禁 +废 +盛 +版 +缓 +净 +睛 +昌 +婚 +涉 +筒 +嘴 +插 +岸 +朗 +庄 +街 +藏 +姑 +贸 +腐 +奴 +啦 +惯 +乘 +伙 +恢 +匀 +纱 +扎 +辩 +耳 +彪 +臣 +亿 +璃 +抵 +脉 +秀 +萨 +俄 +网 +舞 +店 +喷 +纵 +寸 +汗 +挂 +洪 +贺 +闪 +柬 +爆 +烯 +津 +稻 +墙 +软 +勇 +像 +滚 +厘 +蒙 +芳 +肯 +坡 +柱 +荡 +腿 +仪 +旅 +尾 +轧 +冰 +贡 +登 +黎 +削 +钻 +勒 +逃 +障 +氨 +郭 +峰 +币 +港 +伏 +轨 +亩 +毕 +擦 +莫 +刺 +浪 +秘 +援 +株 +健 +售 +股 +岛 +甘 +泡 +睡 +童 +铸 +汤 +阀 +休 +汇 +舍 +牧 +绕 +炸 +哲 +磷 +绩 +朋 +淡 +尖 +启 +陷 +柴 +呈 +徒 +颜 +泪 +稍 +忘 +泵 +蓝 +拖 +洞 +授 +镜 +辛 +壮 +锋 +贫 +虚 +弯 +摩 +泰 +幼 +廷 +尊 +窗 +纲 +弄 +隶 +疑 +氏 +宫 +姐 +震 +瑞 +怪 +尤 +琴 +循 +描 +膜 +违 +夹 +腰 +缘 +珠 +穷 +森 +枝 +竹 +沟 +催 +绳 +忆 +邦 +剩 +幸 +浆 +栏 +拥 +牙 +贮 +礼 +滤 +钠 +纹 +罢 +拍 +咱 +喊 +袖 +埃 +勤 +罚 +焦 +潜 +伍 +墨 +欲 +缝 +姓 +刊 +饱 +仿 +奖 +铝 +鬼 +丽 +跨 +默 +挖 +链 +扫 +喝 +袋 +炭 +污 +幕 +诸 +弧 +励 +梅 +奶 +洁 +灾 +舟 +鉴 +苯 +讼 +抱 +毁 +懂 +寒 +智 +埔 +寄 +届 +跃 +渡 +挑 +丹 +艰 +贝 +碰 +拔 +爹 +戴 +码 +梦 +芽 +熔 +赤 +渔 +哭 +敬 +颗 +奔 +铅 +仲 +虎 +稀 +妹 +乏 +珍 +申 +桌 +遵 +允 +隆 +螺 +仓 +魏 +锐 +晓 +氮 +兼 +隐 +碍 +赫 +拨 +忠 +肃 +缸 +牵 +抢 +博 +巧 +壳 +兄 +杜 +讯 +诚 +碧 +祥 +柯 +页 +巡 +矩 +悲 +灌 +龄 +伦 +票 +寻 +桂 +铺 +圣 +恐 +恰 +郑 +趣 +抬 +荒 +腾 +贴 +柔 +滴 +猛 +阔 +辆 +妻 +填 +撤 +储 +签 +闹 +扰 +紫 +砂 +递 +戏 +吊 +陶 +伐 +喂 +疗 +瓶 +婆 +抚 +臂 +摸 +忍 +虾 +蜡 +邻 +胸 +巩 +挤 +偶 +弃 +槽 +劲 +乳 +邓 +吉 +仁 +烂 +砖 +租 +乌 +舰 +伴 +瓜 +浅 +丙 +暂 +燥 +橡 +柳 +迷 +暖 +牌 +秧 +胆 +详 +簧 +踏 +瓷 +谱 +呆 +宾 +糊 +洛 +辉 +愤 +竞 +隙 +怒 +粘 +乃 +绪 +肩 +籍 +敏 +涂 +熙 +皆 +侦 +悬 +掘 +享 +纠 +醒 +狂 +锁 +淀 +恨 +牲 +霸 +爬 +赏 +逆 +玩 +陵 +祝 +秒 +浙 +貌 +役 +彼 +悉 +鸭 +趋 +凤 +晨 +畜 +辈 +秩 +卵 +署 +梯 +炎 +滩 +棋 +驱 +筛 +峡 +冒 +啥 +寿 +译 +浸 +泉 +帽 +迟 +硅 +疆 +贷 +漏 +稿 +冠 +嫩 +胁 +芯 +牢 +叛 +蚀 +奥 +鸣 +岭 +羊 +凭 +串 +塘 +绘 +酵 +融 +盆 +锡 +庙 +筹 +冻 +辅 +摄 +袭 +筋 +拒 +僚 +旱 +钾 +鸟 +漆 +沈 +眉 +疏 +添 +棒 +穗 +硝 +韩 +逼 +扭 +侨 +凉 +挺 +碗 +栽 +炒 +杯 +患 +馏 +劝 +豪 +辽 +勃 +鸿 +旦 +吏 +拜 +狗 +埋 +辊 +掩 +饮 +搬 +骂 +辞 +勾 +扣 +估 +蒋 +绒 +雾 +丈 +朵 +姆 +拟 +宇 +辑 +陕 +雕 +偿 +蓄 +崇 +剪 +倡 +厅 +咬 +驶 +薯 +刷 +斥 +番 +赋 +奉 +佛 +浇 +漫 +曼 +扇 +钙 +桃 +扶 +仔 +返 +俗 +亏 +腔 +鞋 +棱 +覆 +框 +悄 +叔 +撞 +骗 +勘 +旺 +沸 +孤 +吐 +孟 +渠 +屈 +疾 +妙 +惜 +仰 +狠 +胀 +谐 +抛 +霉 +桑 +岗 +嘛 +衰 +盗 +渗 +脏 +赖 +涌 +甜 +曹 +阅 +肌 +哩 +厉 +烃 +纬 +毅 +昨 +伪 +症 +煮 +叹 +钉 +搭 +茎 +笼 +酷 +偷 +弓 +锥 +恒 +杰 +坑 +鼻 +翼 +纶 +叙 +狱 +逮 +罐 +络 +棚 +抑 +膨 +蔬 +寺 +骤 +穆 +冶 +枯 +册 +尸 +凸 +绅 +坯 +牺 +焰 +轰 +欣 +晋 +瘦 +御 +锭 +锦 +丧 +旬 +锻 +垄 +搜 +扑 +邀 +亭 +酯 +迈 +舒 +脆 +酶 +闲 +忧 +酚 +顽 +羽 +涨 +卸 +仗 +陪 +辟 +惩 +杭 +姚 +肚 +捉 +飘 +漂 +昆 +欺 +吾 +郎 +烷 +汁 +呵 +饰 +萧 +雅 +邮 +迁 +燕 +撒 +姻 +赴 +宴 +烦 +债 +帐 +斑 +铃 +旨 +醇 +董 +饼 +雏 +姿 +拌 +傅 +腹 +妥 +揉 +贤 +拆 +歪 +葡 +胺 +丢 +浩 +徽 +昂 +垫 +挡 +览 +贪 +慰 +缴 +汪 +慌 +冯 +诺 +姜 +谊 +凶 +劣 +诬 +耀 +昏 +躺 +盈 +骑 +乔 +溪 +丛 +卢 +抹 +闷 +咨 +刮 +驾 +缆 +悟 +摘 +铒 +掷 +颇 +幻 +柄 +惠 +惨 +佳 +仇 +腊 +窝 +涤 +剑 +瞧 +堡 +泼 +葱 +罩 +霍 +捞 +胎 +苍 +滨 +俩 +捅 +湘 +砍 +霞 +邵 +萄 +疯 +淮 +遂 +熊 +粪 +烘 +宿 +档 +戈 +驳 +嫂 +裕 +徙 +箭 +捐 +肠 +撑 +晒 +辨 +殿 +莲 +摊 +搅 +酱 +屏 +疫 +哀 +蔡 +堵 +沫 +皱 +畅 +叠 +阁 +莱 +敲 +辖 +钩 +痕 +坝 +巷 +饿 +祸 +丘 +玄 +溜 +曰 +逻 +彭 +尝 +卿 +妨 +艇 +吞 +韦 +怨 +矮 +歇 diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/chinese_traditional.txt b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/chinese_traditional.txt new file mode 100755 index 0000000..9b02047 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/chinese_traditional.txt @@ -0,0 +1,2048 @@ +的 +一 +是 +在 +不 +了 +有 +和 +人 +這 +中 +大 +為 +上 +個 +國 +我 +以 +要 +他 +時 +來 +用 +們 +生 +到 +作 +地 +於 +出 +就 +分 +對 +成 +會 +可 +主 +發 +年 +動 +同 +工 +也 +能 +下 +過 +子 +說 +產 +種 +面 +而 +方 +後 +多 +定 +行 +學 +法 +所 +民 +得 +經 +十 +三 +之 +進 +著 +等 +部 +度 +家 +電 +力 +裡 +如 +水 +化 +高 +自 +二 +理 +起 +小 +物 +現 +實 +加 +量 +都 +兩 +體 +制 +機 +當 +使 +點 +從 +業 +本 +去 +把 +性 +好 +應 +開 +它 +合 +還 +因 +由 +其 +些 +然 +前 +外 +天 +政 +四 +日 +那 +社 +義 +事 +平 +形 +相 +全 +表 +間 +樣 +與 +關 +各 +重 +新 +線 +內 +數 +正 +心 +反 +你 +明 +看 +原 +又 +麼 +利 +比 +或 +但 +質 +氣 +第 +向 +道 +命 +此 +變 +條 +只 +沒 +結 +解 +問 +意 +建 +月 +公 +無 +系 +軍 +很 +情 +者 +最 +立 +代 +想 +已 +通 +並 +提 +直 +題 +黨 +程 +展 +五 +果 +料 +象 +員 +革 +位 +入 +常 +文 +總 +次 +品 +式 +活 +設 +及 +管 +特 +件 +長 +求 +老 +頭 +基 +資 +邊 +流 +路 +級 +少 +圖 +山 +統 +接 +知 +較 +將 +組 +見 +計 +別 +她 +手 +角 +期 +根 +論 +運 +農 +指 +幾 +九 +區 +強 +放 +決 +西 +被 +幹 +做 +必 +戰 +先 +回 +則 +任 +取 +據 +處 +隊 +南 +給 +色 +光 +門 +即 +保 +治 +北 +造 +百 +規 +熱 +領 +七 +海 +口 +東 +導 +器 +壓 +志 +世 +金 +增 +爭 +濟 +階 +油 +思 +術 +極 +交 +受 +聯 +什 +認 +六 +共 +權 +收 +證 +改 +清 +美 +再 +採 +轉 +更 +單 +風 +切 +打 +白 +教 +速 +花 +帶 +安 +場 +身 +車 +例 +真 +務 +具 +萬 +每 +目 +至 +達 +走 +積 +示 +議 +聲 +報 +鬥 +完 +類 +八 +離 +華 +名 +確 +才 +科 +張 +信 +馬 +節 +話 +米 +整 +空 +元 +況 +今 +集 +溫 +傳 +土 +許 +步 +群 +廣 +石 +記 +需 +段 +研 +界 +拉 +林 +律 +叫 +且 +究 +觀 +越 +織 +裝 +影 +算 +低 +持 +音 +眾 +書 +布 +复 +容 +兒 +須 +際 +商 +非 +驗 +連 +斷 +深 +難 +近 +礦 +千 +週 +委 +素 +技 +備 +半 +辦 +青 +省 +列 +習 +響 +約 +支 +般 +史 +感 +勞 +便 +團 +往 +酸 +歷 +市 +克 +何 +除 +消 +構 +府 +稱 +太 +準 +精 +值 +號 +率 +族 +維 +劃 +選 +標 +寫 +存 +候 +毛 +親 +快 +效 +斯 +院 +查 +江 +型 +眼 +王 +按 +格 +養 +易 +置 +派 +層 +片 +始 +卻 +專 +狀 +育 +廠 +京 +識 +適 +屬 +圓 +包 +火 +住 +調 +滿 +縣 +局 +照 +參 +紅 +細 +引 +聽 +該 +鐵 +價 +嚴 +首 +底 +液 +官 +德 +隨 +病 +蘇 +失 +爾 +死 +講 +配 +女 +黃 +推 +顯 +談 +罪 +神 +藝 +呢 +席 +含 +企 +望 +密 +批 +營 +項 +防 +舉 +球 +英 +氧 +勢 +告 +李 +台 +落 +木 +幫 +輪 +破 +亞 +師 +圍 +注 +遠 +字 +材 +排 +供 +河 +態 +封 +另 +施 +減 +樹 +溶 +怎 +止 +案 +言 +士 +均 +武 +固 +葉 +魚 +波 +視 +僅 +費 +緊 +愛 +左 +章 +早 +朝 +害 +續 +輕 +服 +試 +食 +充 +兵 +源 +判 +護 +司 +足 +某 +練 +差 +致 +板 +田 +降 +黑 +犯 +負 +擊 +范 +繼 +興 +似 +餘 +堅 +曲 +輸 +修 +故 +城 +夫 +夠 +送 +筆 +船 +佔 +右 +財 +吃 +富 +春 +職 +覺 +漢 +畫 +功 +巴 +跟 +雖 +雜 +飛 +檢 +吸 +助 +昇 +陽 +互 +初 +創 +抗 +考 +投 +壞 +策 +古 +徑 +換 +未 +跑 +留 +鋼 +曾 +端 +責 +站 +簡 +述 +錢 +副 +盡 +帝 +射 +草 +衝 +承 +獨 +令 +限 +阿 +宣 +環 +雙 +請 +超 +微 +讓 +控 +州 +良 +軸 +找 +否 +紀 +益 +依 +優 +頂 +礎 +載 +倒 +房 +突 +坐 +粉 +敵 +略 +客 +袁 +冷 +勝 +絕 +析 +塊 +劑 +測 +絲 +協 +訴 +念 +陳 +仍 +羅 +鹽 +友 +洋 +錯 +苦 +夜 +刑 +移 +頻 +逐 +靠 +混 +母 +短 +皮 +終 +聚 +汽 +村 +雲 +哪 +既 +距 +衛 +停 +烈 +央 +察 +燒 +迅 +境 +若 +印 +洲 +刻 +括 +激 +孔 +搞 +甚 +室 +待 +核 +校 +散 +侵 +吧 +甲 +遊 +久 +菜 +味 +舊 +模 +湖 +貨 +損 +預 +阻 +毫 +普 +穩 +乙 +媽 +植 +息 +擴 +銀 +語 +揮 +酒 +守 +拿 +序 +紙 +醫 +缺 +雨 +嗎 +針 +劉 +啊 +急 +唱 +誤 +訓 +願 +審 +附 +獲 +茶 +鮮 +糧 +斤 +孩 +脫 +硫 +肥 +善 +龍 +演 +父 +漸 +血 +歡 +械 +掌 +歌 +沙 +剛 +攻 +謂 +盾 +討 +晚 +粒 +亂 +燃 +矛 +乎 +殺 +藥 +寧 +魯 +貴 +鐘 +煤 +讀 +班 +伯 +香 +介 +迫 +句 +豐 +培 +握 +蘭 +擔 +弦 +蛋 +沉 +假 +穿 +執 +答 +樂 +誰 +順 +煙 +縮 +徵 +臉 +喜 +松 +腳 +困 +異 +免 +背 +星 +福 +買 +染 +井 +概 +慢 +怕 +磁 +倍 +祖 +皇 +促 +靜 +補 +評 +翻 +肉 +踐 +尼 +衣 +寬 +揚 +棉 +希 +傷 +操 +垂 +秋 +宜 +氫 +套 +督 +振 +架 +亮 +末 +憲 +慶 +編 +牛 +觸 +映 +雷 +銷 +詩 +座 +居 +抓 +裂 +胞 +呼 +娘 +景 +威 +綠 +晶 +厚 +盟 +衡 +雞 +孫 +延 +危 +膠 +屋 +鄉 +臨 +陸 +顧 +掉 +呀 +燈 +歲 +措 +束 +耐 +劇 +玉 +趙 +跳 +哥 +季 +課 +凱 +胡 +額 +款 +紹 +卷 +齊 +偉 +蒸 +殖 +永 +宗 +苗 +川 +爐 +岩 +弱 +零 +楊 +奏 +沿 +露 +桿 +探 +滑 +鎮 +飯 +濃 +航 +懷 +趕 +庫 +奪 +伊 +靈 +稅 +途 +滅 +賽 +歸 +召 +鼓 +播 +盤 +裁 +險 +康 +唯 +錄 +菌 +純 +借 +糖 +蓋 +橫 +符 +私 +努 +堂 +域 +槍 +潤 +幅 +哈 +竟 +熟 +蟲 +澤 +腦 +壤 +碳 +歐 +遍 +側 +寨 +敢 +徹 +慮 +斜 +薄 +庭 +納 +彈 +飼 +伸 +折 +麥 +濕 +暗 +荷 +瓦 +塞 +床 +築 +惡 +戶 +訪 +塔 +奇 +透 +梁 +刀 +旋 +跡 +卡 +氯 +遇 +份 +毒 +泥 +退 +洗 +擺 +灰 +彩 +賣 +耗 +夏 +擇 +忙 +銅 +獻 +硬 +予 +繁 +圈 +雪 +函 +亦 +抽 +篇 +陣 +陰 +丁 +尺 +追 +堆 +雄 +迎 +泛 +爸 +樓 +避 +謀 +噸 +野 +豬 +旗 +累 +偏 +典 +館 +索 +秦 +脂 +潮 +爺 +豆 +忽 +托 +驚 +塑 +遺 +愈 +朱 +替 +纖 +粗 +傾 +尚 +痛 +楚 +謝 +奮 +購 +磨 +君 +池 +旁 +碎 +骨 +監 +捕 +弟 +暴 +割 +貫 +殊 +釋 +詞 +亡 +壁 +頓 +寶 +午 +塵 +聞 +揭 +炮 +殘 +冬 +橋 +婦 +警 +綜 +招 +吳 +付 +浮 +遭 +徐 +您 +搖 +谷 +贊 +箱 +隔 +訂 +男 +吹 +園 +紛 +唐 +敗 +宋 +玻 +巨 +耕 +坦 +榮 +閉 +灣 +鍵 +凡 +駐 +鍋 +救 +恩 +剝 +凝 +鹼 +齒 +截 +煉 +麻 +紡 +禁 +廢 +盛 +版 +緩 +淨 +睛 +昌 +婚 +涉 +筒 +嘴 +插 +岸 +朗 +莊 +街 +藏 +姑 +貿 +腐 +奴 +啦 +慣 +乘 +夥 +恢 +勻 +紗 +扎 +辯 +耳 +彪 +臣 +億 +璃 +抵 +脈 +秀 +薩 +俄 +網 +舞 +店 +噴 +縱 +寸 +汗 +掛 +洪 +賀 +閃 +柬 +爆 +烯 +津 +稻 +牆 +軟 +勇 +像 +滾 +厘 +蒙 +芳 +肯 +坡 +柱 +盪 +腿 +儀 +旅 +尾 +軋 +冰 +貢 +登 +黎 +削 +鑽 +勒 +逃 +障 +氨 +郭 +峰 +幣 +港 +伏 +軌 +畝 +畢 +擦 +莫 +刺 +浪 +秘 +援 +株 +健 +售 +股 +島 +甘 +泡 +睡 +童 +鑄 +湯 +閥 +休 +匯 +舍 +牧 +繞 +炸 +哲 +磷 +績 +朋 +淡 +尖 +啟 +陷 +柴 +呈 +徒 +顏 +淚 +稍 +忘 +泵 +藍 +拖 +洞 +授 +鏡 +辛 +壯 +鋒 +貧 +虛 +彎 +摩 +泰 +幼 +廷 +尊 +窗 +綱 +弄 +隸 +疑 +氏 +宮 +姐 +震 +瑞 +怪 +尤 +琴 +循 +描 +膜 +違 +夾 +腰 +緣 +珠 +窮 +森 +枝 +竹 +溝 +催 +繩 +憶 +邦 +剩 +幸 +漿 +欄 +擁 +牙 +貯 +禮 +濾 +鈉 +紋 +罷 +拍 +咱 +喊 +袖 +埃 +勤 +罰 +焦 +潛 +伍 +墨 +欲 +縫 +姓 +刊 +飽 +仿 +獎 +鋁 +鬼 +麗 +跨 +默 +挖 +鏈 +掃 +喝 +袋 +炭 +污 +幕 +諸 +弧 +勵 +梅 +奶 +潔 +災 +舟 +鑑 +苯 +訟 +抱 +毀 +懂 +寒 +智 +埔 +寄 +屆 +躍 +渡 +挑 +丹 +艱 +貝 +碰 +拔 +爹 +戴 +碼 +夢 +芽 +熔 +赤 +漁 +哭 +敬 +顆 +奔 +鉛 +仲 +虎 +稀 +妹 +乏 +珍 +申 +桌 +遵 +允 +隆 +螺 +倉 +魏 +銳 +曉 +氮 +兼 +隱 +礙 +赫 +撥 +忠 +肅 +缸 +牽 +搶 +博 +巧 +殼 +兄 +杜 +訊 +誠 +碧 +祥 +柯 +頁 +巡 +矩 +悲 +灌 +齡 +倫 +票 +尋 +桂 +鋪 +聖 +恐 +恰 +鄭 +趣 +抬 +荒 +騰 +貼 +柔 +滴 +猛 +闊 +輛 +妻 +填 +撤 +儲 +簽 +鬧 +擾 +紫 +砂 +遞 +戲 +吊 +陶 +伐 +餵 +療 +瓶 +婆 +撫 +臂 +摸 +忍 +蝦 +蠟 +鄰 +胸 +鞏 +擠 +偶 +棄 +槽 +勁 +乳 +鄧 +吉 +仁 +爛 +磚 +租 +烏 +艦 +伴 +瓜 +淺 +丙 +暫 +燥 +橡 +柳 +迷 +暖 +牌 +秧 +膽 +詳 +簧 +踏 +瓷 +譜 +呆 +賓 +糊 +洛 +輝 +憤 +競 +隙 +怒 +粘 +乃 +緒 +肩 +籍 +敏 +塗 +熙 +皆 +偵 +懸 +掘 +享 +糾 +醒 +狂 +鎖 +淀 +恨 +牲 +霸 +爬 +賞 +逆 +玩 +陵 +祝 +秒 +浙 +貌 +役 +彼 +悉 +鴨 +趨 +鳳 +晨 +畜 +輩 +秩 +卵 +署 +梯 +炎 +灘 +棋 +驅 +篩 +峽 +冒 +啥 +壽 +譯 +浸 +泉 +帽 +遲 +矽 +疆 +貸 +漏 +稿 +冠 +嫩 +脅 +芯 +牢 +叛 +蝕 +奧 +鳴 +嶺 +羊 +憑 +串 +塘 +繪 +酵 +融 +盆 +錫 +廟 +籌 +凍 +輔 +攝 +襲 +筋 +拒 +僚 +旱 +鉀 +鳥 +漆 +沈 +眉 +疏 +添 +棒 +穗 +硝 +韓 +逼 +扭 +僑 +涼 +挺 +碗 +栽 +炒 +杯 +患 +餾 +勸 +豪 +遼 +勃 +鴻 +旦 +吏 +拜 +狗 +埋 +輥 +掩 +飲 +搬 +罵 +辭 +勾 +扣 +估 +蔣 +絨 +霧 +丈 +朵 +姆 +擬 +宇 +輯 +陝 +雕 +償 +蓄 +崇 +剪 +倡 +廳 +咬 +駛 +薯 +刷 +斥 +番 +賦 +奉 +佛 +澆 +漫 +曼 +扇 +鈣 +桃 +扶 +仔 +返 +俗 +虧 +腔 +鞋 +棱 +覆 +框 +悄 +叔 +撞 +騙 +勘 +旺 +沸 +孤 +吐 +孟 +渠 +屈 +疾 +妙 +惜 +仰 +狠 +脹 +諧 +拋 +黴 +桑 +崗 +嘛 +衰 +盜 +滲 +臟 +賴 +湧 +甜 +曹 +閱 +肌 +哩 +厲 +烴 +緯 +毅 +昨 +偽 +症 +煮 +嘆 +釘 +搭 +莖 +籠 +酷 +偷 +弓 +錐 +恆 +傑 +坑 +鼻 +翼 +綸 +敘 +獄 +逮 +罐 +絡 +棚 +抑 +膨 +蔬 +寺 +驟 +穆 +冶 +枯 +冊 +屍 +凸 +紳 +坯 +犧 +焰 +轟 +欣 +晉 +瘦 +禦 +錠 +錦 +喪 +旬 +鍛 +壟 +搜 +撲 +邀 +亭 +酯 +邁 +舒 +脆 +酶 +閒 +憂 +酚 +頑 +羽 +漲 +卸 +仗 +陪 +闢 +懲 +杭 +姚 +肚 +捉 +飄 +漂 +昆 +欺 +吾 +郎 +烷 +汁 +呵 +飾 +蕭 +雅 +郵 +遷 +燕 +撒 +姻 +赴 +宴 +煩 +債 +帳 +斑 +鈴 +旨 +醇 +董 +餅 +雛 +姿 +拌 +傅 +腹 +妥 +揉 +賢 +拆 +歪 +葡 +胺 +丟 +浩 +徽 +昂 +墊 +擋 +覽 +貪 +慰 +繳 +汪 +慌 +馮 +諾 +姜 +誼 +兇 +劣 +誣 +耀 +昏 +躺 +盈 +騎 +喬 +溪 +叢 +盧 +抹 +悶 +諮 +刮 +駕 +纜 +悟 +摘 +鉺 +擲 +頗 +幻 +柄 +惠 +慘 +佳 +仇 +臘 +窩 +滌 +劍 +瞧 +堡 +潑 +蔥 +罩 +霍 +撈 +胎 +蒼 +濱 +倆 +捅 +湘 +砍 +霞 +邵 +萄 +瘋 +淮 +遂 +熊 +糞 +烘 +宿 +檔 +戈 +駁 +嫂 +裕 +徙 +箭 +捐 +腸 +撐 +曬 +辨 +殿 +蓮 +攤 +攪 +醬 +屏 +疫 +哀 +蔡 +堵 +沫 +皺 +暢 +疊 +閣 +萊 +敲 +轄 +鉤 +痕 +壩 +巷 +餓 +禍 +丘 +玄 +溜 +曰 +邏 +彭 +嘗 +卿 +妨 +艇 +吞 +韋 +怨 +矮 +歇 diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/english.txt b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/english.txt new file mode 100755 index 0000000..942040e --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/english.txt @@ -0,0 +1,2048 @@ +abandon +ability +able +about +above +absent +absorb +abstract +absurd +abuse +access +accident +account +accuse +achieve +acid +acoustic +acquire +across +act +action +actor +actress +actual +adapt +add +addict +address +adjust +admit +adult +advance +advice +aerobic +affair +afford +afraid +again +age +agent +agree +ahead +aim +air +airport +aisle +alarm +album +alcohol +alert +alien +all +alley +allow +almost +alone +alpha +already +also +alter +always +amateur +amazing +among +amount +amused +analyst +anchor +ancient +anger +angle +angry +animal +ankle +announce +annual +another +answer +antenna +antique +anxiety +any +apart +apology +appear +apple +approve +april +arch +arctic +area +arena +argue +arm +armed +armor +army +around +arrange +arrest +arrive +arrow +art +artefact +artist +artwork +ask +aspect +assault +asset +assist +assume +asthma +athlete +atom +attack +attend +attitude +attract +auction +audit +august +aunt +author +auto +autumn +average +avocado +avoid +awake +aware +away +awesome +awful +awkward +axis +baby +bachelor +bacon +badge +bag +balance +balcony +ball +bamboo +banana +banner +bar +barely +bargain +barrel +base +basic +basket +battle +beach +bean +beauty +because +become +beef +before +begin +behave +behind +believe +below +belt +bench +benefit +best +betray +better +between +beyond +bicycle +bid +bike +bind +biology +bird +birth +bitter +black +blade +blame +blanket +blast +bleak +bless +blind +blood +blossom +blouse +blue +blur +blush +board +boat +body +boil +bomb +bone +bonus +book +boost +border +boring +borrow +boss +bottom +bounce +box +boy +bracket +brain +brand +brass +brave +bread +breeze +brick +bridge +brief +bright +bring +brisk +broccoli +broken +bronze +broom +brother +brown +brush +bubble +buddy +budget +buffalo +build +bulb +bulk +bullet +bundle +bunker +burden +burger +burst +bus +business +busy +butter +buyer +buzz +cabbage +cabin +cable +cactus +cage +cake +call +calm +camera +camp +can +canal +cancel +candy +cannon +canoe +canvas +canyon +capable +capital +captain +car +carbon +card +cargo +carpet +carry +cart +case +cash +casino +castle +casual +cat +catalog +catch +category +cattle +caught +cause +caution +cave +ceiling +celery +cement +census +century +cereal +certain +chair +chalk +champion +change +chaos +chapter +charge +chase +chat +cheap +check +cheese +chef +cherry +chest +chicken +chief +child +chimney +choice +choose +chronic +chuckle +chunk +churn +cigar +cinnamon +circle +citizen +city +civil +claim +clap +clarify +claw +clay +clean +clerk +clever +click +client +cliff +climb +clinic +clip +clock +clog +close +cloth +cloud +clown +club +clump +cluster +clutch +coach +coast +coconut +code +coffee +coil +coin +collect +color +column +combine +come +comfort +comic +common +company +concert +conduct +confirm +congress +connect +consider +control +convince +cook +cool +copper +copy +coral +core +corn +correct +cost +cotton +couch +country +couple +course +cousin +cover +coyote +crack +cradle +craft +cram +crane +crash +crater +crawl +crazy +cream +credit +creek +crew +cricket +crime +crisp +critic +crop +cross +crouch +crowd +crucial +cruel +cruise +crumble +crunch +crush +cry +crystal +cube +culture +cup +cupboard +curious +current +curtain +curve +cushion +custom +cute +cycle +dad +damage +damp +dance +danger +daring +dash +daughter +dawn +day +deal +debate +debris +decade +december +decide +decline +decorate +decrease +deer +defense +define +defy +degree +delay +deliver +demand +demise +denial +dentist +deny +depart +depend +deposit +depth +deputy +derive +describe +desert +design +desk +despair +destroy +detail +detect +develop +device +devote +diagram +dial +diamond +diary +dice +diesel +diet +differ +digital +dignity +dilemma +dinner +dinosaur +direct +dirt +disagree +discover +disease +dish +dismiss +disorder +display +distance +divert +divide +divorce +dizzy +doctor +document +dog +doll +dolphin +domain +donate +donkey +donor +door +dose +double +dove +draft +dragon +drama +drastic +draw +dream +dress +drift +drill +drink +drip +drive +drop +drum +dry +duck +dumb +dune +during +dust +dutch +duty +dwarf +dynamic +eager +eagle +early +earn +earth +easily +east +easy +echo +ecology +economy +edge +edit +educate +effort +egg +eight +either +elbow +elder +electric +elegant +element +elephant +elevator +elite +else +embark +embody +embrace +emerge +emotion +employ +empower +empty +enable +enact +end +endless +endorse +enemy +energy +enforce +engage +engine +enhance +enjoy +enlist +enough +enrich +enroll +ensure +enter +entire +entry +envelope +episode +equal +equip +era +erase +erode +erosion +error +erupt +escape +essay +essence +estate +eternal +ethics +evidence +evil +evoke +evolve +exact +example +excess +exchange +excite +exclude +excuse +execute +exercise +exhaust +exhibit +exile +exist +exit +exotic +expand +expect +expire +explain +expose +express +extend +extra +eye +eyebrow +fabric +face +faculty +fade +faint +faith +fall +false +fame +family +famous +fan +fancy +fantasy +farm +fashion +fat +fatal +father +fatigue +fault +favorite +feature +february +federal +fee +feed +feel +female +fence +festival +fetch +fever +few +fiber +fiction +field +figure +file +film +filter +final +find +fine +finger +finish +fire +firm +first +fiscal +fish +fit +fitness +fix +flag +flame +flash +flat +flavor +flee +flight +flip +float +flock +floor +flower +fluid +flush +fly +foam +focus +fog +foil +fold +follow +food +foot +force +forest +forget +fork +fortune +forum +forward +fossil +foster +found +fox +fragile +frame +frequent +fresh +friend +fringe +frog +front +frost +frown +frozen +fruit +fuel +fun +funny +furnace +fury +future +gadget +gain +galaxy +gallery +game +gap +garage +garbage +garden +garlic +garment +gas +gasp +gate +gather +gauge +gaze +general +genius +genre +gentle +genuine +gesture +ghost +giant +gift +giggle +ginger +giraffe +girl +give +glad +glance +glare +glass +glide +glimpse +globe +gloom +glory +glove +glow +glue +goat +goddess +gold +good +goose +gorilla +gospel +gossip +govern +gown +grab +grace +grain +grant +grape +grass +gravity +great +green +grid +grief +grit +grocery +group +grow +grunt +guard +guess +guide +guilt +guitar +gun +gym +habit +hair +half +hammer +hamster +hand +happy +harbor +hard +harsh +harvest +hat +have +hawk +hazard +head +health +heart +heavy +hedgehog +height +hello +helmet +help +hen +hero +hidden +high +hill +hint +hip +hire +history +hobby +hockey +hold +hole +holiday +hollow +home +honey +hood +hope +horn +horror +horse +hospital +host +hotel +hour +hover +hub +huge +human +humble +humor +hundred +hungry +hunt +hurdle +hurry +hurt +husband +hybrid +ice +icon +idea +identify +idle +ignore +ill +illegal +illness +image +imitate +immense +immune +impact +impose +improve +impulse +inch +include +income +increase +index +indicate +indoor +industry +infant +inflict +inform +inhale +inherit +initial +inject +injury +inmate +inner +innocent +input +inquiry +insane +insect +inside +inspire +install +intact +interest +into +invest +invite +involve +iron +island +isolate +issue +item +ivory +jacket +jaguar +jar +jazz +jealous +jeans +jelly +jewel +job +join +joke +journey +joy +judge +juice +jump +jungle +junior +junk +just +kangaroo +keen +keep +ketchup +key +kick +kid +kidney +kind +kingdom +kiss +kit +kitchen +kite +kitten +kiwi +knee +knife +knock +know +lab +label +labor +ladder +lady +lake +lamp +language +laptop +large +later +latin +laugh +laundry +lava +law +lawn +lawsuit +layer +lazy +leader +leaf +learn +leave +lecture +left +leg +legal +legend +leisure +lemon +lend +length +lens +leopard +lesson +letter +level +liar +liberty +library +license +life +lift +light +like +limb +limit +link +lion +liquid +list +little +live +lizard +load +loan +lobster +local +lock +logic +lonely +long +loop +lottery +loud +lounge +love +loyal +lucky +luggage +lumber +lunar +lunch +luxury +lyrics +machine +mad +magic +magnet +maid +mail +main +major +make +mammal +man +manage +mandate +mango +mansion +manual +maple +marble +march +margin +marine +market +marriage +mask +mass +master +match +material +math +matrix +matter +maximum +maze +meadow +mean +measure +meat +mechanic +medal +media +melody +melt +member +memory +mention +menu +mercy +merge +merit +merry +mesh +message +metal +method +middle +midnight +milk +million +mimic +mind +minimum +minor +minute +miracle +mirror +misery +miss +mistake +mix +mixed +mixture +mobile +model +modify +mom +moment +monitor +monkey +monster +month +moon +moral +more +morning +mosquito +mother +motion +motor +mountain +mouse +move +movie +much +muffin +mule +multiply +muscle +museum +mushroom +music +must +mutual +myself +mystery +myth +naive +name +napkin +narrow +nasty +nation +nature +near +neck +need +negative +neglect +neither +nephew +nerve +nest +net +network +neutral +never +news +next +nice +night +noble +noise +nominee +noodle +normal +north +nose +notable +note +nothing +notice +novel +now +nuclear +number +nurse +nut +oak +obey +object +oblige +obscure +observe +obtain +obvious +occur +ocean +october +odor +off +offer +office +often +oil +okay +old +olive +olympic +omit +once +one +onion +online +only +open +opera +opinion +oppose +option +orange +orbit +orchard +order +ordinary +organ +orient +original +orphan +ostrich +other +outdoor +outer +output +outside +oval +oven +over +own +owner +oxygen +oyster +ozone +pact +paddle +page +pair +palace +palm +panda +panel +panic +panther +paper +parade +parent +park +parrot +party +pass +patch +path +patient +patrol +pattern +pause +pave +payment +peace +peanut +pear +peasant +pelican +pen +penalty +pencil +people +pepper +perfect +permit +person +pet +phone +photo +phrase +physical +piano +picnic +picture +piece +pig +pigeon +pill +pilot +pink +pioneer +pipe +pistol +pitch +pizza +place +planet +plastic +plate +play +please +pledge +pluck +plug +plunge +poem +poet +point +polar +pole +police +pond +pony +pool +popular +portion +position +possible +post +potato +pottery +poverty +powder +power +practice +praise +predict +prefer +prepare +present +pretty +prevent +price +pride +primary +print +priority +prison +private +prize +problem +process +produce +profit +program +project +promote +proof +property +prosper +protect +proud +provide +public +pudding +pull +pulp +pulse +pumpkin +punch +pupil +puppy +purchase +purity +purpose +purse +push +put +puzzle +pyramid +quality +quantum +quarter +question +quick +quit +quiz +quote +rabbit +raccoon +race +rack +radar +radio +rail +rain +raise +rally +ramp +ranch +random +range +rapid +rare +rate +rather +raven +raw +razor +ready +real +reason +rebel +rebuild +recall +receive +recipe +record +recycle +reduce +reflect +reform +refuse +region +regret +regular +reject +relax +release +relief +rely +remain +remember +remind +remove +render +renew +rent +reopen +repair +repeat +replace +report +require +rescue +resemble +resist +resource +response +result +retire +retreat +return +reunion +reveal +review +reward +rhythm +rib +ribbon +rice +rich +ride +ridge +rifle +right +rigid +ring +riot +ripple +risk +ritual +rival +river +road +roast +robot +robust +rocket +romance +roof +rookie +room +rose +rotate +rough +round +route +royal +rubber +rude +rug +rule +run +runway +rural +sad +saddle +sadness +safe +sail +salad +salmon +salon +salt +salute +same +sample +sand +satisfy +satoshi +sauce +sausage +save +say +scale +scan +scare +scatter +scene +scheme +school +science +scissors +scorpion +scout +scrap +screen +script +scrub +sea +search +season +seat +second +secret +section +security +seed +seek +segment +select +sell +seminar +senior +sense +sentence +series +service +session +settle +setup +seven +shadow +shaft +shallow +share +shed +shell +sheriff +shield +shift +shine +ship +shiver +shock +shoe +shoot +shop +short +shoulder +shove +shrimp +shrug +shuffle +shy +sibling +sick +side +siege +sight +sign +silent +silk +silly +silver +similar +simple +since +sing +siren +sister +situate +six +size +skate +sketch +ski +skill +skin +skirt +skull +slab +slam +sleep +slender +slice +slide +slight +slim +slogan +slot +slow +slush +small +smart +smile +smoke +smooth +snack +snake +snap +sniff +snow +soap +soccer +social +sock +soda +soft +solar +soldier +solid +solution +solve +someone +song +soon +sorry +sort +soul +sound +soup +source +south +space +spare +spatial +spawn +speak +special +speed +spell +spend +sphere +spice +spider +spike +spin +spirit +split +spoil +sponsor +spoon +sport +spot +spray +spread +spring +spy +square +squeeze +squirrel +stable +stadium +staff +stage +stairs +stamp +stand +start +state +stay +steak +steel +stem +step +stereo +stick +still +sting +stock +stomach +stone +stool +story +stove +strategy +street +strike +strong +struggle +student +stuff +stumble +style +subject +submit +subway +success +such +sudden +suffer +sugar +suggest +suit +summer +sun +sunny +sunset +super +supply +supreme +sure +surface +surge +surprise +surround +survey +suspect +sustain +swallow +swamp +swap +swarm +swear +sweet +swift +swim +swing +switch +sword +symbol +symptom +syrup +system +table +tackle +tag +tail +talent +talk +tank +tape +target +task +taste +tattoo +taxi +teach +team +tell +ten +tenant +tennis +tent +term +test +text +thank +that +theme +then +theory +there +they +thing +this +thought +three +thrive +throw +thumb +thunder +ticket +tide +tiger +tilt +timber +time +tiny +tip +tired +tissue +title +toast +tobacco +today +toddler +toe +together +toilet +token +tomato +tomorrow +tone +tongue +tonight +tool +tooth +top +topic +topple +torch +tornado +tortoise +toss +total +tourist +toward +tower +town +toy +track +trade +traffic +tragic +train +transfer +trap +trash +travel +tray +treat +tree +trend +trial +tribe +trick +trigger +trim +trip +trophy +trouble +truck +true +truly +trumpet +trust +truth +try +tube +tuition +tumble +tuna +tunnel +turkey +turn +turtle +twelve +twenty +twice +twin +twist +two +type +typical +ugly +umbrella +unable +unaware +uncle +uncover +under +undo +unfair +unfold +unhappy +uniform +unique +unit +universe +unknown +unlock +until +unusual +unveil +update +upgrade +uphold +upon +upper +upset +urban +urge +usage +use +used +useful +useless +usual +utility +vacant +vacuum +vague +valid +valley +valve +van +vanish +vapor +various +vast +vault +vehicle +velvet +vendor +venture +venue +verb +verify +version +very +vessel +veteran +viable +vibrant +vicious +victory +video +view +village +vintage +violin +virtual +virus +visa +visit +visual +vital +vivid +vocal +voice +void +volcano +volume +vote +voyage +wage +wagon +wait +walk +wall +walnut +want +warfare +warm +warrior +wash +wasp +waste +water +wave +way +wealth +weapon +wear +weasel +weather +web +wedding +weekend +weird +welcome +west +wet +whale +what +wheat +wheel +when +where +whip +whisper +wide +width +wife +wild +will +win +window +wine +wing +wink +winner +winter +wire +wisdom +wise +wish +witness +wolf +woman +wonder +wood +wool +word +work +world +worry +worth +wrap +wreck +wrestle +wrist +write +wrong +yard +year +yellow +you +young +youth +zebra +zero +zone +zoo diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/french.txt b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/french.txt new file mode 100755 index 0000000..1d74990 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/french.txt @@ -0,0 +1,2048 @@ +abaisser +abandon +abdiquer +abeille +abolir +aborder +aboutir +aboyer +abrasif +abreuver +abriter +abroger +abrupt +absence +absolu +absurde +abusif +abyssal +académie +acajou +acarien +accabler +accepter +acclamer +accolade +accroche +accuser +acerbe +achat +acheter +aciduler +acier +acompte +acquérir +acronyme +acteur +actif +actuel +adepte +adéquat +adhésif +adjectif +adjuger +admettre +admirer +adopter +adorer +adoucir +adresse +adroit +adulte +adverbe +aérer +aéronef +affaire +affecter +affiche +affreux +affubler +agacer +agencer +agile +agiter +agrafer +agréable +agrume +aider +aiguille +ailier +aimable +aisance +ajouter +ajuster +alarmer +alchimie +alerte +algèbre +algue +aliéner +aliment +alléger +alliage +allouer +allumer +alourdir +alpaga +altesse +alvéole +amateur +ambigu +ambre +aménager +amertume +amidon +amiral +amorcer +amour +amovible +amphibie +ampleur +amusant +analyse +anaphore +anarchie +anatomie +ancien +anéantir +angle +angoisse +anguleux +animal +annexer +annonce +annuel +anodin +anomalie +anonyme +anormal +antenne +antidote +anxieux +apaiser +apéritif +aplanir +apologie +appareil +appeler +apporter +appuyer +aquarium +aqueduc +arbitre +arbuste +ardeur +ardoise +argent +arlequin +armature +armement +armoire +armure +arpenter +arracher +arriver +arroser +arsenic +artériel +article +aspect +asphalte +aspirer +assaut +asservir +assiette +associer +assurer +asticot +astre +astuce +atelier +atome +atrium +atroce +attaque +attentif +attirer +attraper +aubaine +auberge +audace +audible +augurer +aurore +automne +autruche +avaler +avancer +avarice +avenir +averse +aveugle +aviateur +avide +avion +aviser +avoine +avouer +avril +axial +axiome +badge +bafouer +bagage +baguette +baignade +balancer +balcon +baleine +balisage +bambin +bancaire +bandage +banlieue +bannière +banquier +barbier +baril +baron +barque +barrage +bassin +bastion +bataille +bateau +batterie +baudrier +bavarder +belette +bélier +belote +bénéfice +berceau +berger +berline +bermuda +besace +besogne +bétail +beurre +biberon +bicycle +bidule +bijou +bilan +bilingue +billard +binaire +biologie +biopsie +biotype +biscuit +bison +bistouri +bitume +bizarre +blafard +blague +blanchir +blessant +blinder +blond +bloquer +blouson +bobard +bobine +boire +boiser +bolide +bonbon +bondir +bonheur +bonifier +bonus +bordure +borne +botte +boucle +boueux +bougie +boulon +bouquin +bourse +boussole +boutique +boxeur +branche +brasier +brave +brebis +brèche +breuvage +bricoler +brigade +brillant +brioche +brique +brochure +broder +bronzer +brousse +broyeur +brume +brusque +brutal +bruyant +buffle +buisson +bulletin +bureau +burin +bustier +butiner +butoir +buvable +buvette +cabanon +cabine +cachette +cadeau +cadre +caféine +caillou +caisson +calculer +calepin +calibre +calmer +calomnie +calvaire +camarade +caméra +camion +campagne +canal +caneton +canon +cantine +canular +capable +caporal +caprice +capsule +capter +capuche +carabine +carbone +caresser +caribou +carnage +carotte +carreau +carton +cascade +casier +casque +cassure +causer +caution +cavalier +caverne +caviar +cédille +ceinture +céleste +cellule +cendrier +censurer +central +cercle +cérébral +cerise +cerner +cerveau +cesser +chagrin +chaise +chaleur +chambre +chance +chapitre +charbon +chasseur +chaton +chausson +chavirer +chemise +chenille +chéquier +chercher +cheval +chien +chiffre +chignon +chimère +chiot +chlorure +chocolat +choisir +chose +chouette +chrome +chute +cigare +cigogne +cimenter +cinéma +cintrer +circuler +cirer +cirque +citerne +citoyen +citron +civil +clairon +clameur +claquer +classe +clavier +client +cligner +climat +clivage +cloche +clonage +cloporte +cobalt +cobra +cocasse +cocotier +coder +codifier +coffre +cogner +cohésion +coiffer +coincer +colère +colibri +colline +colmater +colonel +combat +comédie +commande +compact +concert +conduire +confier +congeler +connoter +consonne +contact +convexe +copain +copie +corail +corbeau +cordage +corniche +corpus +correct +cortège +cosmique +costume +coton +coude +coupure +courage +couteau +couvrir +coyote +crabe +crainte +cravate +crayon +créature +créditer +crémeux +creuser +crevette +cribler +crier +cristal +critère +croire +croquer +crotale +crucial +cruel +crypter +cubique +cueillir +cuillère +cuisine +cuivre +culminer +cultiver +cumuler +cupide +curatif +curseur +cyanure +cycle +cylindre +cynique +daigner +damier +danger +danseur +dauphin +débattre +débiter +déborder +débrider +débutant +décaler +décembre +déchirer +décider +déclarer +décorer +décrire +décupler +dédale +déductif +déesse +défensif +défiler +défrayer +dégager +dégivrer +déglutir +dégrafer +déjeuner +délice +déloger +demander +demeurer +démolir +dénicher +dénouer +dentelle +dénuder +départ +dépenser +déphaser +déplacer +déposer +déranger +dérober +désastre +descente +désert +désigner +désobéir +dessiner +destrier +détacher +détester +détourer +détresse +devancer +devenir +deviner +devoir +diable +dialogue +diamant +dicter +différer +digérer +digital +digne +diluer +dimanche +diminuer +dioxyde +directif +diriger +discuter +disposer +dissiper +distance +divertir +diviser +docile +docteur +dogme +doigt +domaine +domicile +dompter +donateur +donjon +donner +dopamine +dortoir +dorure +dosage +doseur +dossier +dotation +douanier +double +douceur +douter +doyen +dragon +draper +dresser +dribbler +droiture +duperie +duplexe +durable +durcir +dynastie +éblouir +écarter +écharpe +échelle +éclairer +éclipse +éclore +écluse +école +économie +écorce +écouter +écraser +écrémer +écrivain +écrou +écume +écureuil +édifier +éduquer +effacer +effectif +effigie +effort +effrayer +effusion +égaliser +égarer +éjecter +élaborer +élargir +électron +élégant +éléphant +élève +éligible +élitisme +éloge +élucider +éluder +emballer +embellir +embryon +émeraude +émission +emmener +émotion +émouvoir +empereur +employer +emporter +emprise +émulsion +encadrer +enchère +enclave +encoche +endiguer +endosser +endroit +enduire +énergie +enfance +enfermer +enfouir +engager +engin +englober +énigme +enjamber +enjeu +enlever +ennemi +ennuyeux +enrichir +enrobage +enseigne +entasser +entendre +entier +entourer +entraver +énumérer +envahir +enviable +envoyer +enzyme +éolien +épaissir +épargne +épatant +épaule +épicerie +épidémie +épier +épilogue +épine +épisode +épitaphe +époque +épreuve +éprouver +épuisant +équerre +équipe +ériger +érosion +erreur +éruption +escalier +espadon +espèce +espiègle +espoir +esprit +esquiver +essayer +essence +essieu +essorer +estime +estomac +estrade +étagère +étaler +étanche +étatique +éteindre +étendoir +éternel +éthanol +éthique +ethnie +étirer +étoffer +étoile +étonnant +étourdir +étrange +étroit +étude +euphorie +évaluer +évasion +éventail +évidence +éviter +évolutif +évoquer +exact +exagérer +exaucer +exceller +excitant +exclusif +excuse +exécuter +exemple +exercer +exhaler +exhorter +exigence +exiler +exister +exotique +expédier +explorer +exposer +exprimer +exquis +extensif +extraire +exulter +fable +fabuleux +facette +facile +facture +faiblir +falaise +fameux +famille +farceur +farfelu +farine +farouche +fasciner +fatal +fatigue +faucon +fautif +faveur +favori +fébrile +féconder +fédérer +félin +femme +fémur +fendoir +féodal +fermer +féroce +ferveur +festival +feuille +feutre +février +fiasco +ficeler +fictif +fidèle +figure +filature +filetage +filière +filleul +filmer +filou +filtrer +financer +finir +fiole +firme +fissure +fixer +flairer +flamme +flasque +flatteur +fléau +flèche +fleur +flexion +flocon +flore +fluctuer +fluide +fluvial +folie +fonderie +fongible +fontaine +forcer +forgeron +formuler +fortune +fossile +foudre +fougère +fouiller +foulure +fourmi +fragile +fraise +franchir +frapper +frayeur +frégate +freiner +frelon +frémir +frénésie +frère +friable +friction +frisson +frivole +froid +fromage +frontal +frotter +fruit +fugitif +fuite +fureur +furieux +furtif +fusion +futur +gagner +galaxie +galerie +gambader +garantir +gardien +garnir +garrigue +gazelle +gazon +géant +gélatine +gélule +gendarme +général +génie +genou +gentil +géologie +géomètre +géranium +germe +gestuel +geyser +gibier +gicler +girafe +givre +glace +glaive +glisser +globe +gloire +glorieux +golfeur +gomme +gonfler +gorge +gorille +goudron +gouffre +goulot +goupille +gourmand +goutte +graduel +graffiti +graine +grand +grappin +gratuit +gravir +grenat +griffure +griller +grimper +grogner +gronder +grotte +groupe +gruger +grutier +gruyère +guépard +guerrier +guide +guimauve +guitare +gustatif +gymnaste +gyrostat +habitude +hachoir +halte +hameau +hangar +hanneton +haricot +harmonie +harpon +hasard +hélium +hématome +herbe +hérisson +hermine +héron +hésiter +heureux +hiberner +hibou +hilarant +histoire +hiver +homard +hommage +homogène +honneur +honorer +honteux +horde +horizon +horloge +hormone +horrible +houleux +housse +hublot +huileux +humain +humble +humide +humour +hurler +hydromel +hygiène +hymne +hypnose +idylle +ignorer +iguane +illicite +illusion +image +imbiber +imiter +immense +immobile +immuable +impact +impérial +implorer +imposer +imprimer +imputer +incarner +incendie +incident +incliner +incolore +indexer +indice +inductif +inédit +ineptie +inexact +infini +infliger +informer +infusion +ingérer +inhaler +inhiber +injecter +injure +innocent +inoculer +inonder +inscrire +insecte +insigne +insolite +inspirer +instinct +insulter +intact +intense +intime +intrigue +intuitif +inutile +invasion +inventer +inviter +invoquer +ironique +irradier +irréel +irriter +isoler +ivoire +ivresse +jaguar +jaillir +jambe +janvier +jardin +jauger +jaune +javelot +jetable +jeton +jeudi +jeunesse +joindre +joncher +jongler +joueur +jouissif +journal +jovial +joyau +joyeux +jubiler +jugement +junior +jupon +juriste +justice +juteux +juvénile +kayak +kimono +kiosque +label +labial +labourer +lacérer +lactose +lagune +laine +laisser +laitier +lambeau +lamelle +lampe +lanceur +langage +lanterne +lapin +largeur +larme +laurier +lavabo +lavoir +lecture +légal +léger +légume +lessive +lettre +levier +lexique +lézard +liasse +libérer +libre +licence +licorne +liège +lièvre +ligature +ligoter +ligue +limer +limite +limonade +limpide +linéaire +lingot +lionceau +liquide +lisière +lister +lithium +litige +littoral +livreur +logique +lointain +loisir +lombric +loterie +louer +lourd +loutre +louve +loyal +lubie +lucide +lucratif +lueur +lugubre +luisant +lumière +lunaire +lundi +luron +lutter +luxueux +machine +magasin +magenta +magique +maigre +maillon +maintien +mairie +maison +majorer +malaxer +maléfice +malheur +malice +mallette +mammouth +mandater +maniable +manquant +manteau +manuel +marathon +marbre +marchand +mardi +maritime +marqueur +marron +marteler +mascotte +massif +matériel +matière +matraque +maudire +maussade +mauve +maximal +méchant +méconnu +médaille +médecin +méditer +méduse +meilleur +mélange +mélodie +membre +mémoire +menacer +mener +menhir +mensonge +mentor +mercredi +mérite +merle +messager +mesure +métal +météore +méthode +métier +meuble +miauler +microbe +miette +mignon +migrer +milieu +million +mimique +mince +minéral +minimal +minorer +minute +miracle +miroiter +missile +mixte +mobile +moderne +moelleux +mondial +moniteur +monnaie +monotone +monstre +montagne +monument +moqueur +morceau +morsure +mortier +moteur +motif +mouche +moufle +moulin +mousson +mouton +mouvant +multiple +munition +muraille +murène +murmure +muscle +muséum +musicien +mutation +muter +mutuel +myriade +myrtille +mystère +mythique +nageur +nappe +narquois +narrer +natation +nation +nature +naufrage +nautique +navire +nébuleux +nectar +néfaste +négation +négliger +négocier +neige +nerveux +nettoyer +neurone +neutron +neveu +niche +nickel +nitrate +niveau +noble +nocif +nocturne +noirceur +noisette +nomade +nombreux +nommer +normatif +notable +notifier +notoire +nourrir +nouveau +novateur +novembre +novice +nuage +nuancer +nuire +nuisible +numéro +nuptial +nuque +nutritif +obéir +objectif +obliger +obscur +observer +obstacle +obtenir +obturer +occasion +occuper +océan +octobre +octroyer +octupler +oculaire +odeur +odorant +offenser +officier +offrir +ogive +oiseau +oisillon +olfactif +olivier +ombrage +omettre +onctueux +onduler +onéreux +onirique +opale +opaque +opérer +opinion +opportun +opprimer +opter +optique +orageux +orange +orbite +ordonner +oreille +organe +orgueil +orifice +ornement +orque +ortie +osciller +osmose +ossature +otarie +ouragan +ourson +outil +outrager +ouvrage +ovation +oxyde +oxygène +ozone +paisible +palace +palmarès +palourde +palper +panache +panda +pangolin +paniquer +panneau +panorama +pantalon +papaye +papier +papoter +papyrus +paradoxe +parcelle +paresse +parfumer +parler +parole +parrain +parsemer +partager +parure +parvenir +passion +pastèque +paternel +patience +patron +pavillon +pavoiser +payer +paysage +peigne +peintre +pelage +pélican +pelle +pelouse +peluche +pendule +pénétrer +pénible +pensif +pénurie +pépite +péplum +perdrix +perforer +période +permuter +perplexe +persil +perte +peser +pétale +petit +pétrir +peuple +pharaon +phobie +phoque +photon +phrase +physique +piano +pictural +pièce +pierre +pieuvre +pilote +pinceau +pipette +piquer +pirogue +piscine +piston +pivoter +pixel +pizza +placard +plafond +plaisir +planer +plaque +plastron +plateau +pleurer +plexus +pliage +plomb +plonger +pluie +plumage +pochette +poésie +poète +pointe +poirier +poisson +poivre +polaire +policier +pollen +polygone +pommade +pompier +ponctuel +pondérer +poney +portique +position +posséder +posture +potager +poteau +potion +pouce +poulain +poumon +pourpre +poussin +pouvoir +prairie +pratique +précieux +prédire +préfixe +prélude +prénom +présence +prétexte +prévoir +primitif +prince +prison +priver +problème +procéder +prodige +profond +progrès +proie +projeter +prologue +promener +propre +prospère +protéger +prouesse +proverbe +prudence +pruneau +psychose +public +puceron +puiser +pulpe +pulsar +punaise +punitif +pupitre +purifier +puzzle +pyramide +quasar +querelle +question +quiétude +quitter +quotient +racine +raconter +radieux +ragondin +raideur +raisin +ralentir +rallonge +ramasser +rapide +rasage +ratisser +ravager +ravin +rayonner +réactif +réagir +réaliser +réanimer +recevoir +réciter +réclamer +récolter +recruter +reculer +recycler +rédiger +redouter +refaire +réflexe +réformer +refrain +refuge +régalien +région +réglage +régulier +réitérer +rejeter +rejouer +relatif +relever +relief +remarque +remède +remise +remonter +remplir +remuer +renard +renfort +renifler +renoncer +rentrer +renvoi +replier +reporter +reprise +reptile +requin +réserve +résineux +résoudre +respect +rester +résultat +rétablir +retenir +réticule +retomber +retracer +réunion +réussir +revanche +revivre +révolte +révulsif +richesse +rideau +rieur +rigide +rigoler +rincer +riposter +risible +risque +rituel +rival +rivière +rocheux +romance +rompre +ronce +rondin +roseau +rosier +rotatif +rotor +rotule +rouge +rouille +rouleau +routine +royaume +ruban +rubis +ruche +ruelle +rugueux +ruiner +ruisseau +ruser +rustique +rythme +sabler +saboter +sabre +sacoche +safari +sagesse +saisir +salade +salive +salon +saluer +samedi +sanction +sanglier +sarcasme +sardine +saturer +saugrenu +saumon +sauter +sauvage +savant +savonner +scalpel +scandale +scélérat +scénario +sceptre +schéma +science +scinder +score +scrutin +sculpter +séance +sécable +sécher +secouer +sécréter +sédatif +séduire +seigneur +séjour +sélectif +semaine +sembler +semence +séminal +sénateur +sensible +sentence +séparer +séquence +serein +sergent +sérieux +serrure +sérum +service +sésame +sévir +sevrage +sextuple +sidéral +siècle +siéger +siffler +sigle +signal +silence +silicium +simple +sincère +sinistre +siphon +sirop +sismique +situer +skier +social +socle +sodium +soigneux +soldat +soleil +solitude +soluble +sombre +sommeil +somnoler +sonde +songeur +sonnette +sonore +sorcier +sortir +sosie +sottise +soucieux +soudure +souffle +soulever +soupape +source +soutirer +souvenir +spacieux +spatial +spécial +sphère +spiral +stable +station +sternum +stimulus +stipuler +strict +studieux +stupeur +styliste +sublime +substrat +subtil +subvenir +succès +sucre +suffixe +suggérer +suiveur +sulfate +superbe +supplier +surface +suricate +surmener +surprise +sursaut +survie +suspect +syllabe +symbole +symétrie +synapse +syntaxe +système +tabac +tablier +tactile +tailler +talent +talisman +talonner +tambour +tamiser +tangible +tapis +taquiner +tarder +tarif +tartine +tasse +tatami +tatouage +taupe +taureau +taxer +témoin +temporel +tenaille +tendre +teneur +tenir +tension +terminer +terne +terrible +tétine +texte +thème +théorie +thérapie +thorax +tibia +tiède +timide +tirelire +tiroir +tissu +titane +titre +tituber +toboggan +tolérant +tomate +tonique +tonneau +toponyme +torche +tordre +tornade +torpille +torrent +torse +tortue +totem +toucher +tournage +tousser +toxine +traction +trafic +tragique +trahir +train +trancher +travail +trèfle +tremper +trésor +treuil +triage +tribunal +tricoter +trilogie +triomphe +tripler +triturer +trivial +trombone +tronc +tropical +troupeau +tuile +tulipe +tumulte +tunnel +turbine +tuteur +tutoyer +tuyau +tympan +typhon +typique +tyran +ubuesque +ultime +ultrason +unanime +unifier +union +unique +unitaire +univers +uranium +urbain +urticant +usage +usine +usuel +usure +utile +utopie +vacarme +vaccin +vagabond +vague +vaillant +vaincre +vaisseau +valable +valise +vallon +valve +vampire +vanille +vapeur +varier +vaseux +vassal +vaste +vecteur +vedette +végétal +véhicule +veinard +véloce +vendredi +vénérer +venger +venimeux +ventouse +verdure +vérin +vernir +verrou +verser +vertu +veston +vétéran +vétuste +vexant +vexer +viaduc +viande +victoire +vidange +vidéo +vignette +vigueur +vilain +village +vinaigre +violon +vipère +virement +virtuose +virus +visage +viseur +vision +visqueux +visuel +vital +vitesse +viticole +vitrine +vivace +vivipare +vocation +voguer +voile +voisin +voiture +volaille +volcan +voltiger +volume +vorace +vortex +voter +vouloir +voyage +voyelle +wagon +xénon +yacht +zèbre +zénith +zeste +zoologie diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/italian.txt b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/italian.txt new file mode 100755 index 0000000..c47370f --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/italian.txt @@ -0,0 +1,2048 @@ +abaco +abbaglio +abbinato +abete +abisso +abolire +abrasivo +abrogato +accadere +accenno +accusato +acetone +achille +acido +acqua +acre +acrilico +acrobata +acuto +adagio +addebito +addome +adeguato +aderire +adipe +adottare +adulare +affabile +affetto +affisso +affranto +aforisma +afoso +africano +agave +agente +agevole +aggancio +agire +agitare +agonismo +agricolo +agrumeto +aguzzo +alabarda +alato +albatro +alberato +albo +albume +alce +alcolico +alettone +alfa +algebra +aliante +alibi +alimento +allagato +allegro +allievo +allodola +allusivo +almeno +alogeno +alpaca +alpestre +altalena +alterno +alticcio +altrove +alunno +alveolo +alzare +amalgama +amanita +amarena +ambito +ambrato +ameba +america +ametista +amico +ammasso +ammenda +ammirare +ammonito +amore +ampio +ampliare +amuleto +anacardo +anagrafe +analista +anarchia +anatra +anca +ancella +ancora +andare +andrea +anello +angelo +angolare +angusto +anima +annegare +annidato +anno +annuncio +anonimo +anticipo +anzi +apatico +apertura +apode +apparire +appetito +appoggio +approdo +appunto +aprile +arabica +arachide +aragosta +araldica +arancio +aratura +arazzo +arbitro +archivio +ardito +arenile +argento +argine +arguto +aria +armonia +arnese +arredato +arringa +arrosto +arsenico +arso +artefice +arzillo +asciutto +ascolto +asepsi +asettico +asfalto +asino +asola +aspirato +aspro +assaggio +asse +assoluto +assurdo +asta +astenuto +astice +astratto +atavico +ateismo +atomico +atono +attesa +attivare +attorno +attrito +attuale +ausilio +austria +autista +autonomo +autunno +avanzato +avere +avvenire +avviso +avvolgere +azione +azoto +azzimo +azzurro +babele +baccano +bacino +baco +badessa +badilata +bagnato +baita +balcone +baldo +balena +ballata +balzano +bambino +bandire +baraonda +barbaro +barca +baritono +barlume +barocco +basilico +basso +batosta +battuto +baule +bava +bavosa +becco +beffa +belgio +belva +benda +benevole +benigno +benzina +bere +berlina +beta +bibita +bici +bidone +bifido +biga +bilancia +bimbo +binocolo +biologo +bipede +bipolare +birbante +birra +biscotto +bisesto +bisnonno +bisonte +bisturi +bizzarro +blando +blatta +bollito +bonifico +bordo +bosco +botanico +bottino +bozzolo +braccio +bradipo +brama +branca +bravura +bretella +brevetto +brezza +briglia +brillante +brindare +broccolo +brodo +bronzina +brullo +bruno +bubbone +buca +budino +buffone +buio +bulbo +buono +burlone +burrasca +bussola +busta +cadetto +caduco +calamaro +calcolo +calesse +calibro +calmo +caloria +cambusa +camerata +camicia +cammino +camola +campale +canapa +candela +cane +canino +canotto +cantina +capace +capello +capitolo +capogiro +cappero +capra +capsula +carapace +carcassa +cardo +carisma +carovana +carretto +cartolina +casaccio +cascata +caserma +caso +cassone +castello +casuale +catasta +catena +catrame +cauto +cavillo +cedibile +cedrata +cefalo +celebre +cellulare +cena +cenone +centesimo +ceramica +cercare +certo +cerume +cervello +cesoia +cespo +ceto +chela +chiaro +chicca +chiedere +chimera +china +chirurgo +chitarra +ciao +ciclismo +cifrare +cigno +cilindro +ciottolo +circa +cirrosi +citrico +cittadino +ciuffo +civetta +civile +classico +clinica +cloro +cocco +codardo +codice +coerente +cognome +collare +colmato +colore +colposo +coltivato +colza +coma +cometa +commando +comodo +computer +comune +conciso +condurre +conferma +congelare +coniuge +connesso +conoscere +consumo +continuo +convegno +coperto +copione +coppia +copricapo +corazza +cordata +coricato +cornice +corolla +corpo +corredo +corsia +cortese +cosmico +costante +cottura +covato +cratere +cravatta +creato +credere +cremoso +crescita +creta +criceto +crinale +crisi +critico +croce +cronaca +crostata +cruciale +crusca +cucire +cuculo +cugino +cullato +cupola +curatore +cursore +curvo +cuscino +custode +dado +daino +dalmata +damerino +daniela +dannoso +danzare +datato +davanti +davvero +debutto +decennio +deciso +declino +decollo +decreto +dedicato +definito +deforme +degno +delegare +delfino +delirio +delta +demenza +denotato +dentro +deposito +derapata +derivare +deroga +descritto +deserto +desiderio +desumere +detersivo +devoto +diametro +dicembre +diedro +difeso +diffuso +digerire +digitale +diluvio +dinamico +dinnanzi +dipinto +diploma +dipolo +diradare +dire +dirotto +dirupo +disagio +discreto +disfare +disgelo +disposto +distanza +disumano +dito +divano +divelto +dividere +divorato +doblone +docente +doganale +dogma +dolce +domato +domenica +dominare +dondolo +dono +dormire +dote +dottore +dovuto +dozzina +drago +druido +dubbio +dubitare +ducale +duna +duomo +duplice +duraturo +ebano +eccesso +ecco +eclissi +economia +edera +edicola +edile +editoria +educare +egemonia +egli +egoismo +egregio +elaborato +elargire +elegante +elencato +eletto +elevare +elfico +elica +elmo +elsa +eluso +emanato +emblema +emesso +emiro +emotivo +emozione +empirico +emulo +endemico +enduro +energia +enfasi +enoteca +entrare +enzima +epatite +epilogo +episodio +epocale +eppure +equatore +erario +erba +erboso +erede +eremita +erigere +ermetico +eroe +erosivo +errante +esagono +esame +esanime +esaudire +esca +esempio +esercito +esibito +esigente +esistere +esito +esofago +esortato +esoso +espanso +espresso +essenza +esso +esteso +estimare +estonia +estroso +esultare +etilico +etnico +etrusco +etto +euclideo +europa +evaso +evidenza +evitato +evoluto +evviva +fabbrica +faccenda +fachiro +falco +famiglia +fanale +fanfara +fango +fantasma +fare +farfalla +farinoso +farmaco +fascia +fastoso +fasullo +faticare +fato +favoloso +febbre +fecola +fede +fegato +felpa +feltro +femmina +fendere +fenomeno +fermento +ferro +fertile +fessura +festivo +fetta +feudo +fiaba +fiducia +fifa +figurato +filo +finanza +finestra +finire +fiore +fiscale +fisico +fiume +flacone +flamenco +flebo +flemma +florido +fluente +fluoro +fobico +focaccia +focoso +foderato +foglio +folata +folclore +folgore +fondente +fonetico +fonia +fontana +forbito +forchetta +foresta +formica +fornaio +foro +fortezza +forzare +fosfato +fosso +fracasso +frana +frassino +fratello +freccetta +frenata +fresco +frigo +frollino +fronde +frugale +frutta +fucilata +fucsia +fuggente +fulmine +fulvo +fumante +fumetto +fumoso +fune +funzione +fuoco +furbo +furgone +furore +fuso +futile +gabbiano +gaffe +galateo +gallina +galoppo +gambero +gamma +garanzia +garbo +garofano +garzone +gasdotto +gasolio +gastrico +gatto +gaudio +gazebo +gazzella +geco +gelatina +gelso +gemello +gemmato +gene +genitore +gennaio +genotipo +gergo +ghepardo +ghiaccio +ghisa +giallo +gilda +ginepro +giocare +gioiello +giorno +giove +girato +girone +gittata +giudizio +giurato +giusto +globulo +glutine +gnomo +gobba +golf +gomito +gommone +gonfio +gonna +governo +gracile +grado +grafico +grammo +grande +grattare +gravoso +grazia +greca +gregge +grifone +grigio +grinza +grotta +gruppo +guadagno +guaio +guanto +guardare +gufo +guidare +ibernato +icona +identico +idillio +idolo +idra +idrico +idrogeno +igiene +ignaro +ignorato +ilare +illeso +illogico +illudere +imballo +imbevuto +imbocco +imbuto +immane +immerso +immolato +impacco +impeto +impiego +importo +impronta +inalare +inarcare +inattivo +incanto +incendio +inchino +incisivo +incluso +incontro +incrocio +incubo +indagine +india +indole +inedito +infatti +infilare +inflitto +ingaggio +ingegno +inglese +ingordo +ingrosso +innesco +inodore +inoltrare +inondato +insano +insetto +insieme +insonnia +insulina +intasato +intero +intonaco +intuito +inumidire +invalido +invece +invito +iperbole +ipnotico +ipotesi +ippica +iride +irlanda +ironico +irrigato +irrorare +isolato +isotopo +isterico +istituto +istrice +italia +iterare +labbro +labirinto +lacca +lacerato +lacrima +lacuna +laddove +lago +lampo +lancetta +lanterna +lardoso +larga +laringe +lastra +latenza +latino +lattuga +lavagna +lavoro +legale +leggero +lembo +lentezza +lenza +leone +lepre +lesivo +lessato +lesto +letterale +leva +levigato +libero +lido +lievito +lilla +limatura +limitare +limpido +lineare +lingua +liquido +lira +lirica +lisca +lite +litigio +livrea +locanda +lode +logica +lombare +londra +longevo +loquace +lorenzo +loto +lotteria +luce +lucidato +lumaca +luminoso +lungo +lupo +luppolo +lusinga +lusso +lutto +macabro +macchina +macero +macinato +madama +magico +maglia +magnete +magro +maiolica +malafede +malgrado +malinteso +malsano +malto +malumore +mana +mancia +mandorla +mangiare +manifesto +mannaro +manovra +mansarda +mantide +manubrio +mappa +maratona +marcire +maretta +marmo +marsupio +maschera +massaia +mastino +materasso +matricola +mattone +maturo +mazurca +meandro +meccanico +mecenate +medesimo +meditare +mega +melassa +melis +melodia +meninge +meno +mensola +mercurio +merenda +merlo +meschino +mese +messere +mestolo +metallo +metodo +mettere +miagolare +mica +micelio +michele +microbo +midollo +miele +migliore +milano +milite +mimosa +minerale +mini +minore +mirino +mirtillo +miscela +missiva +misto +misurare +mitezza +mitigare +mitra +mittente +mnemonico +modello +modifica +modulo +mogano +mogio +mole +molosso +monastero +monco +mondina +monetario +monile +monotono +monsone +montato +monviso +mora +mordere +morsicato +mostro +motivato +motosega +motto +movenza +movimento +mozzo +mucca +mucosa +muffa +mughetto +mugnaio +mulatto +mulinello +multiplo +mummia +munto +muovere +murale +musa +muscolo +musica +mutevole +muto +nababbo +nafta +nanometro +narciso +narice +narrato +nascere +nastrare +naturale +nautica +naviglio +nebulosa +necrosi +negativo +negozio +nemmeno +neofita +neretto +nervo +nessuno +nettuno +neutrale +neve +nevrotico +nicchia +ninfa +nitido +nobile +nocivo +nodo +nome +nomina +nordico +normale +norvegese +nostrano +notare +notizia +notturno +novella +nucleo +nulla +numero +nuovo +nutrire +nuvola +nuziale +oasi +obbedire +obbligo +obelisco +oblio +obolo +obsoleto +occasione +occhio +occidente +occorrere +occultare +ocra +oculato +odierno +odorare +offerta +offrire +offuscato +oggetto +oggi +ognuno +olandese +olfatto +oliato +oliva +ologramma +oltre +omaggio +ombelico +ombra +omega +omissione +ondoso +onere +onice +onnivoro +onorevole +onta +operato +opinione +opposto +oracolo +orafo +ordine +orecchino +orefice +orfano +organico +origine +orizzonte +orma +ormeggio +ornativo +orologio +orrendo +orribile +ortensia +ortica +orzata +orzo +osare +oscurare +osmosi +ospedale +ospite +ossa +ossidare +ostacolo +oste +otite +otre +ottagono +ottimo +ottobre +ovale +ovest +ovino +oviparo +ovocito +ovunque +ovviare +ozio +pacchetto +pace +pacifico +padella +padrone +paese +paga +pagina +palazzina +palesare +pallido +palo +palude +pandoro +pannello +paolo +paonazzo +paprica +parabola +parcella +parere +pargolo +pari +parlato +parola +partire +parvenza +parziale +passivo +pasticca +patacca +patologia +pattume +pavone +peccato +pedalare +pedonale +peggio +peloso +penare +pendice +penisola +pennuto +penombra +pensare +pentola +pepe +pepita +perbene +percorso +perdonato +perforare +pergamena +periodo +permesso +perno +perplesso +persuaso +pertugio +pervaso +pesatore +pesista +peso +pestifero +petalo +pettine +petulante +pezzo +piacere +pianta +piattino +piccino +picozza +piega +pietra +piffero +pigiama +pigolio +pigro +pila +pilifero +pillola +pilota +pimpante +pineta +pinna +pinolo +pioggia +piombo +piramide +piretico +pirite +pirolisi +pitone +pizzico +placebo +planare +plasma +platano +plenario +pochezza +poderoso +podismo +poesia +poggiare +polenta +poligono +pollice +polmonite +polpetta +polso +poltrona +polvere +pomice +pomodoro +ponte +popoloso +porfido +poroso +porpora +porre +portata +posa +positivo +possesso +postulato +potassio +potere +pranzo +prassi +pratica +precluso +predica +prefisso +pregiato +prelievo +premere +prenotare +preparato +presenza +pretesto +prevalso +prima +principe +privato +problema +procura +produrre +profumo +progetto +prolunga +promessa +pronome +proposta +proroga +proteso +prova +prudente +prugna +prurito +psiche +pubblico +pudica +pugilato +pugno +pulce +pulito +pulsante +puntare +pupazzo +pupilla +puro +quadro +qualcosa +quasi +querela +quota +raccolto +raddoppio +radicale +radunato +raffica +ragazzo +ragione +ragno +ramarro +ramingo +ramo +randagio +rantolare +rapato +rapina +rappreso +rasatura +raschiato +rasente +rassegna +rastrello +rata +ravveduto +reale +recepire +recinto +recluta +recondito +recupero +reddito +redimere +regalato +registro +regola +regresso +relazione +remare +remoto +renna +replica +reprimere +reputare +resa +residente +responso +restauro +rete +retina +retorica +rettifica +revocato +riassunto +ribadire +ribelle +ribrezzo +ricarica +ricco +ricevere +riciclato +ricordo +ricreduto +ridicolo +ridurre +rifasare +riflesso +riforma +rifugio +rigare +rigettato +righello +rilassato +rilevato +rimanere +rimbalzo +rimedio +rimorchio +rinascita +rincaro +rinforzo +rinnovo +rinomato +rinsavito +rintocco +rinuncia +rinvenire +riparato +ripetuto +ripieno +riportare +ripresa +ripulire +risata +rischio +riserva +risibile +riso +rispetto +ristoro +risultato +risvolto +ritardo +ritegno +ritmico +ritrovo +riunione +riva +riverso +rivincita +rivolto +rizoma +roba +robotico +robusto +roccia +roco +rodaggio +rodere +roditore +rogito +rollio +romantico +rompere +ronzio +rosolare +rospo +rotante +rotondo +rotula +rovescio +rubizzo +rubrica +ruga +rullino +rumine +rumoroso +ruolo +rupe +russare +rustico +sabato +sabbiare +sabotato +sagoma +salasso +saldatura +salgemma +salivare +salmone +salone +saltare +saluto +salvo +sapere +sapido +saporito +saraceno +sarcasmo +sarto +sassoso +satellite +satira +satollo +saturno +savana +savio +saziato +sbadiglio +sbalzo +sbancato +sbarra +sbattere +sbavare +sbendare +sbirciare +sbloccato +sbocciato +sbrinare +sbruffone +sbuffare +scabroso +scadenza +scala +scambiare +scandalo +scapola +scarso +scatenare +scavato +scelto +scenico +scettro +scheda +schiena +sciarpa +scienza +scindere +scippo +sciroppo +scivolo +sclerare +scodella +scolpito +scomparto +sconforto +scoprire +scorta +scossone +scozzese +scriba +scrollare +scrutinio +scuderia +scultore +scuola +scuro +scusare +sdebitare +sdoganare +seccatura +secondo +sedano +seggiola +segnalato +segregato +seguito +selciato +selettivo +sella +selvaggio +semaforo +sembrare +seme +seminato +sempre +senso +sentire +sepolto +sequenza +serata +serbato +sereno +serio +serpente +serraglio +servire +sestina +setola +settimana +sfacelo +sfaldare +sfamato +sfarzoso +sfaticato +sfera +sfida +sfilato +sfinge +sfocato +sfoderare +sfogo +sfoltire +sforzato +sfratto +sfruttato +sfuggito +sfumare +sfuso +sgabello +sgarbato +sgonfiare +sgorbio +sgrassato +sguardo +sibilo +siccome +sierra +sigla +signore +silenzio +sillaba +simbolo +simpatico +simulato +sinfonia +singolo +sinistro +sino +sintesi +sinusoide +sipario +sisma +sistole +situato +slitta +slogatura +sloveno +smarrito +smemorato +smentito +smeraldo +smilzo +smontare +smottato +smussato +snellire +snervato +snodo +sobbalzo +sobrio +soccorso +sociale +sodale +soffitto +sogno +soldato +solenne +solido +sollazzo +solo +solubile +solvente +somatico +somma +sonda +sonetto +sonnifero +sopire +soppeso +sopra +sorgere +sorpasso +sorriso +sorso +sorteggio +sorvolato +sospiro +sosta +sottile +spada +spalla +spargere +spatola +spavento +spazzola +specie +spedire +spegnere +spelatura +speranza +spessore +spettrale +spezzato +spia +spigoloso +spillato +spinoso +spirale +splendido +sportivo +sposo +spranga +sprecare +spronato +spruzzo +spuntino +squillo +sradicare +srotolato +stabile +stacco +staffa +stagnare +stampato +stantio +starnuto +stasera +statuto +stelo +steppa +sterzo +stiletto +stima +stirpe +stivale +stizzoso +stonato +storico +strappo +stregato +stridulo +strozzare +strutto +stuccare +stufo +stupendo +subentro +succoso +sudore +suggerito +sugo +sultano +suonare +superbo +supporto +surgelato +surrogato +sussurro +sutura +svagare +svedese +sveglio +svelare +svenuto +svezia +sviluppo +svista +svizzera +svolta +svuotare +tabacco +tabulato +tacciare +taciturno +tale +talismano +tampone +tannino +tara +tardivo +targato +tariffa +tarpare +tartaruga +tasto +tattico +taverna +tavolata +tazza +teca +tecnico +telefono +temerario +tempo +temuto +tendone +tenero +tensione +tentacolo +teorema +terme +terrazzo +terzetto +tesi +tesserato +testato +tetro +tettoia +tifare +tigella +timbro +tinto +tipico +tipografo +tiraggio +tiro +titanio +titolo +titubante +tizio +tizzone +toccare +tollerare +tolto +tombola +tomo +tonfo +tonsilla +topazio +topologia +toppa +torba +tornare +torrone +tortora +toscano +tossire +tostatura +totano +trabocco +trachea +trafila +tragedia +tralcio +tramonto +transito +trapano +trarre +trasloco +trattato +trave +treccia +tremolio +trespolo +tributo +tricheco +trifoglio +trillo +trincea +trio +tristezza +triturato +trivella +tromba +trono +troppo +trottola +trovare +truccato +tubatura +tuffato +tulipano +tumulto +tunisia +turbare +turchino +tuta +tutela +ubicato +uccello +uccisore +udire +uditivo +uffa +ufficio +uguale +ulisse +ultimato +umano +umile +umorismo +uncinetto +ungere +ungherese +unicorno +unificato +unisono +unitario +unte +uovo +upupa +uragano +urgenza +urlo +usanza +usato +uscito +usignolo +usuraio +utensile +utilizzo +utopia +vacante +vaccinato +vagabondo +vagliato +valanga +valgo +valico +valletta +valoroso +valutare +valvola +vampata +vangare +vanitoso +vano +vantaggio +vanvera +vapore +varano +varcato +variante +vasca +vedetta +vedova +veduto +vegetale +veicolo +velcro +velina +velluto +veloce +venato +vendemmia +vento +verace +verbale +vergogna +verifica +vero +verruca +verticale +vescica +vessillo +vestale +veterano +vetrina +vetusto +viandante +vibrante +vicenda +vichingo +vicinanza +vidimare +vigilia +vigneto +vigore +vile +villano +vimini +vincitore +viola +vipera +virgola +virologo +virulento +viscoso +visione +vispo +vissuto +visura +vita +vitello +vittima +vivanda +vivido +viziare +voce +voga +volatile +volere +volpe +voragine +vulcano +zampogna +zanna +zappato +zattera +zavorra +zefiro +zelante +zelo +zenzero +zerbino +zibetto +zinco +zircone +zitto +zolla +zotico +zucchero +zufolo +zulu +zuppa diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/japanese.txt b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/japanese.txt new file mode 100755 index 0000000..fb8501a --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/japanese.txt @@ -0,0 +1,2048 @@ +あいこくしん +あいさつ +あいだ +あおぞら +あかちゃん +あきる +あけがた +あける +あこがれる +あさい +あさひ +あしあと +あじわう +あずかる +あずき +あそぶ +あたえる +あたためる +あたりまえ +あたる +あつい +あつかう +あっしゅく +あつまり +あつめる +あてな +あてはまる +あひる +あぶら +あぶる +あふれる +あまい +あまど +あまやかす +あまり +あみもの +あめりか +あやまる +あゆむ +あらいぐま +あらし +あらすじ +あらためる +あらゆる +あらわす +ありがとう +あわせる +あわてる +あんい +あんがい +あんこ +あんぜん +あんてい +あんない +あんまり +いいだす +いおん +いがい +いがく +いきおい +いきなり +いきもの +いきる +いくじ +いくぶん +いけばな +いけん +いこう +いこく +いこつ +いさましい +いさん +いしき +いじゅう +いじょう +いじわる +いずみ +いずれ +いせい +いせえび +いせかい +いせき +いぜん +いそうろう +いそがしい +いだい +いだく +いたずら +いたみ +いたりあ +いちおう +いちじ +いちど +いちば +いちぶ +いちりゅう +いつか +いっしゅん +いっせい +いっそう +いったん +いっち +いってい +いっぽう +いてざ +いてん +いどう +いとこ +いない +いなか +いねむり +いのち +いのる +いはつ +いばる +いはん +いびき +いひん +いふく +いへん +いほう +いみん +いもうと +いもたれ +いもり +いやがる +いやす +いよかん +いよく +いらい +いらすと +いりぐち +いりょう +いれい +いれもの +いれる +いろえんぴつ +いわい +いわう +いわかん +いわば +いわゆる +いんげんまめ +いんさつ +いんしょう +いんよう +うえき +うえる +うおざ +うがい +うかぶ +うかべる +うきわ +うくらいな +うくれれ +うけたまわる +うけつけ +うけとる +うけもつ +うける +うごかす +うごく +うこん +うさぎ +うしなう +うしろがみ +うすい +うすぎ +うすぐらい +うすめる +うせつ +うちあわせ +うちがわ +うちき +うちゅう +うっかり +うつくしい +うったえる +うつる +うどん +うなぎ +うなじ +うなずく +うなる +うねる +うのう +うぶげ +うぶごえ +うまれる +うめる +うもう +うやまう +うよく +うらがえす +うらぐち +うらない +うりあげ +うりきれ +うるさい +うれしい +うれゆき +うれる +うろこ +うわき +うわさ +うんこう +うんちん +うんてん +うんどう +えいえん +えいが +えいきょう +えいご +えいせい +えいぶん +えいよう +えいわ +えおり +えがお +えがく +えきたい +えくせる +えしゃく +えすて +えつらん +えのぐ +えほうまき +えほん +えまき +えもじ +えもの +えらい +えらぶ +えりあ +えんえん +えんかい +えんぎ +えんげき +えんしゅう +えんぜつ +えんそく +えんちょう +えんとつ +おいかける +おいこす +おいしい +おいつく +おうえん +おうさま +おうじ +おうせつ +おうたい +おうふく +おうべい +おうよう +おえる +おおい +おおう +おおどおり +おおや +おおよそ +おかえり +おかず +おがむ +おかわり +おぎなう +おきる +おくさま +おくじょう +おくりがな +おくる +おくれる +おこす +おこなう +おこる +おさえる +おさない +おさめる +おしいれ +おしえる +おじぎ +おじさん +おしゃれ +おそらく +おそわる +おたがい +おたく +おだやか +おちつく +おっと +おつり +おでかけ +おとしもの +おとなしい +おどり +おどろかす +おばさん +おまいり +おめでとう +おもいで +おもう +おもたい +おもちゃ +おやつ +おやゆび +およぼす +おらんだ +おろす +おんがく +おんけい +おんしゃ +おんせん +おんだん +おんちゅう +おんどけい +かあつ +かいが +がいき +がいけん +がいこう +かいさつ +かいしゃ +かいすいよく +かいぜん +かいぞうど +かいつう +かいてん +かいとう +かいふく +がいへき +かいほう +かいよう +がいらい +かいわ +かえる +かおり +かかえる +かがく +かがし +かがみ +かくご +かくとく +かざる +がぞう +かたい +かたち +がちょう +がっきゅう +がっこう +がっさん +がっしょう +かなざわし +かのう +がはく +かぶか +かほう +かほご +かまう +かまぼこ +かめれおん +かゆい +かようび +からい +かるい +かろう +かわく +かわら +がんか +かんけい +かんこう +かんしゃ +かんそう +かんたん +かんち +がんばる +きあい +きあつ +きいろ +ぎいん +きうい +きうん +きえる +きおう +きおく +きおち +きおん +きかい +きかく +きかんしゃ +ききて +きくばり +きくらげ +きけんせい +きこう +きこえる +きこく +きさい +きさく +きさま +きさらぎ +ぎじかがく +ぎしき +ぎじたいけん +ぎじにってい +ぎじゅつしゃ +きすう +きせい +きせき +きせつ +きそう +きぞく +きぞん +きたえる +きちょう +きつえん +ぎっちり +きつつき +きつね +きてい +きどう +きどく +きない +きなが +きなこ +きぬごし +きねん +きのう +きのした +きはく +きびしい +きひん +きふく +きぶん +きぼう +きほん +きまる +きみつ +きむずかしい +きめる +きもだめし +きもち +きもの +きゃく +きやく +ぎゅうにく +きよう +きょうりゅう +きらい +きらく +きりん +きれい +きれつ +きろく +ぎろん +きわめる +ぎんいろ +きんかくじ +きんじょ +きんようび +ぐあい +くいず +くうかん +くうき +くうぐん +くうこう +ぐうせい +くうそう +ぐうたら +くうふく +くうぼ +くかん +くきょう +くげん +ぐこう +くさい +くさき +くさばな +くさる +くしゃみ +くしょう +くすのき +くすりゆび +くせげ +くせん +ぐたいてき +くださる +くたびれる +くちこみ +くちさき +くつした +ぐっすり +くつろぐ +くとうてん +くどく +くなん +くねくね +くのう +くふう +くみあわせ +くみたてる +くめる +くやくしょ +くらす +くらべる +くるま +くれる +くろう +くわしい +ぐんかん +ぐんしょく +ぐんたい +ぐんて +けあな +けいかく +けいけん +けいこ +けいさつ +げいじゅつ +けいたい +げいのうじん +けいれき +けいろ +けおとす +けおりもの +げきか +げきげん +げきだん +げきちん +げきとつ +げきは +げきやく +げこう +げこくじょう +げざい +けさき +げざん +けしき +けしごむ +けしょう +げすと +けたば +けちゃっぷ +けちらす +けつあつ +けつい +けつえき +けっこん +けつじょ +けっせき +けってい +けつまつ +げつようび +げつれい +けつろん +げどく +けとばす +けとる +けなげ +けなす +けなみ +けぬき +げねつ +けねん +けはい +げひん +けぶかい +げぼく +けまり +けみかる +けむし +けむり +けもの +けらい +けろけろ +けわしい +けんい +けんえつ +けんお +けんか +げんき +けんげん +けんこう +けんさく +けんしゅう +けんすう +げんそう +けんちく +けんてい +けんとう +けんない +けんにん +げんぶつ +けんま +けんみん +けんめい +けんらん +けんり +こあくま +こいぬ +こいびと +ごうい +こうえん +こうおん +こうかん +ごうきゅう +ごうけい +こうこう +こうさい +こうじ +こうすい +ごうせい +こうそく +こうたい +こうちゃ +こうつう +こうてい +こうどう +こうない +こうはい +ごうほう +ごうまん +こうもく +こうりつ +こえる +こおり +ごかい +ごがつ +ごかん +こくご +こくさい +こくとう +こくない +こくはく +こぐま +こけい +こける +ここのか +こころ +こさめ +こしつ +こすう +こせい +こせき +こぜん +こそだて +こたい +こたえる +こたつ +こちょう +こっか +こつこつ +こつばん +こつぶ +こてい +こてん +ことがら +ことし +ことば +ことり +こなごな +こねこね +このまま +このみ +このよ +ごはん +こひつじ +こふう +こふん +こぼれる +ごまあぶら +こまかい +ごますり +こまつな +こまる +こむぎこ +こもじ +こもち +こもの +こもん +こやく +こやま +こゆう +こゆび +こよい +こよう +こりる +これくしょん +ころっけ +こわもて +こわれる +こんいん +こんかい +こんき +こんしゅう +こんすい +こんだて +こんとん +こんなん +こんびに +こんぽん +こんまけ +こんや +こんれい +こんわく +ざいえき +さいかい +さいきん +ざいげん +ざいこ +さいしょ +さいせい +ざいたく +ざいちゅう +さいてき +ざいりょう +さうな +さかいし +さがす +さかな +さかみち +さがる +さぎょう +さくし +さくひん +さくら +さこく +さこつ +さずかる +ざせき +さたん +さつえい +ざつおん +ざっか +ざつがく +さっきょく +ざっし +さつじん +ざっそう +さつたば +さつまいも +さてい +さといも +さとう +さとおや +さとし +さとる +さのう +さばく +さびしい +さべつ +さほう +さほど +さます +さみしい +さみだれ +さむけ +さめる +さやえんどう +さゆう +さよう +さよく +さらだ +ざるそば +さわやか +さわる +さんいん +さんか +さんきゃく +さんこう +さんさい +ざんしょ +さんすう +さんせい +さんそ +さんち +さんま +さんみ +さんらん +しあい +しあげ +しあさって +しあわせ +しいく +しいん +しうち +しえい +しおけ +しかい +しかく +じかん +しごと +しすう +じだい +したうけ +したぎ +したて +したみ +しちょう +しちりん +しっかり +しつじ +しつもん +してい +してき +してつ +じてん +じどう +しなぎれ +しなもの +しなん +しねま +しねん +しのぐ +しのぶ +しはい +しばかり +しはつ +しはらい +しはん +しひょう +しふく +じぶん +しへい +しほう +しほん +しまう +しまる +しみん +しむける +じむしょ +しめい +しめる +しもん +しゃいん +しゃうん +しゃおん +じゃがいも +しやくしょ +しゃくほう +しゃけん +しゃこ +しゃざい +しゃしん +しゃせん +しゃそう +しゃたい +しゃちょう +しゃっきん +じゃま +しゃりん +しゃれい +じゆう +じゅうしょ +しゅくはく +じゅしん +しゅっせき +しゅみ +しゅらば +じゅんばん +しょうかい +しょくたく +しょっけん +しょどう +しょもつ +しらせる +しらべる +しんか +しんこう +じんじゃ +しんせいじ +しんちく +しんりん +すあげ +すあし +すあな +ずあん +すいえい +すいか +すいとう +ずいぶん +すいようび +すうがく +すうじつ +すうせん +すおどり +すきま +すくう +すくない +すける +すごい +すこし +ずさん +すずしい +すすむ +すすめる +すっかり +ずっしり +ずっと +すてき +すてる +すねる +すのこ +すはだ +すばらしい +ずひょう +ずぶぬれ +すぶり +すふれ +すべて +すべる +ずほう +すぼん +すまい +すめし +すもう +すやき +すらすら +するめ +すれちがう +すろっと +すわる +すんぜん +すんぽう +せあぶら +せいかつ +せいげん +せいじ +せいよう +せおう +せかいかん +せきにん +せきむ +せきゆ +せきらんうん +せけん +せこう +せすじ +せたい +せたけ +せっかく +せっきゃく +ぜっく +せっけん +せっこつ +せっさたくま +せつぞく +せつだん +せつでん +せっぱん +せつび +せつぶん +せつめい +せつりつ +せなか +せのび +せはば +せびろ +せぼね +せまい +せまる +せめる +せもたれ +せりふ +ぜんあく +せんい +せんえい +せんか +せんきょ +せんく +せんげん +ぜんご +せんさい +せんしゅ +せんすい +せんせい +せんぞ +せんたく +せんちょう +せんてい +せんとう +せんぬき +せんねん +せんぱい +ぜんぶ +ぜんぽう +せんむ +せんめんじょ +せんもん +せんやく +せんゆう +せんよう +ぜんら +ぜんりゃく +せんれい +せんろ +そあく +そいとげる +そいね +そうがんきょう +そうき +そうご +そうしん +そうだん +そうなん +そうび +そうめん +そうり +そえもの +そえん +そがい +そげき +そこう +そこそこ +そざい +そしな +そせい +そせん +そそぐ +そだてる +そつう +そつえん +そっかん +そつぎょう +そっけつ +そっこう +そっせん +そっと +そとがわ +そとづら +そなえる +そなた +そふぼ +そぼく +そぼろ +そまつ +そまる +そむく +そむりえ +そめる +そもそも +そよかぜ +そらまめ +そろう +そんかい +そんけい +そんざい +そんしつ +そんぞく +そんちょう +ぞんび +ぞんぶん +そんみん +たあい +たいいん +たいうん +たいえき +たいおう +だいがく +たいき +たいぐう +たいけん +たいこ +たいざい +だいじょうぶ +だいすき +たいせつ +たいそう +だいたい +たいちょう +たいてい +だいどころ +たいない +たいねつ +たいのう +たいはん +だいひょう +たいふう +たいへん +たいほ +たいまつばな +たいみんぐ +たいむ +たいめん +たいやき +たいよう +たいら +たいりょく +たいる +たいわん +たうえ +たえる +たおす +たおる +たおれる +たかい +たかね +たきび +たくさん +たこく +たこやき +たさい +たしざん +だじゃれ +たすける +たずさわる +たそがれ +たたかう +たたく +ただしい +たたみ +たちばな +だっかい +だっきゃく +だっこ +だっしゅつ +だったい +たてる +たとえる +たなばた +たにん +たぬき +たのしみ +たはつ +たぶん +たべる +たぼう +たまご +たまる +だむる +ためいき +ためす +ためる +たもつ +たやすい +たよる +たらす +たりきほんがん +たりょう +たりる +たると +たれる +たれんと +たろっと +たわむれる +だんあつ +たんい +たんおん +たんか +たんき +たんけん +たんご +たんさん +たんじょうび +だんせい +たんそく +たんたい +だんち +たんてい +たんとう +だんな +たんにん +だんねつ +たんのう +たんぴん +だんぼう +たんまつ +たんめい +だんれつ +だんろ +だんわ +ちあい +ちあん +ちいき +ちいさい +ちえん +ちかい +ちから +ちきゅう +ちきん +ちけいず +ちけん +ちこく +ちさい +ちしき +ちしりょう +ちせい +ちそう +ちたい +ちたん +ちちおや +ちつじょ +ちてき +ちてん +ちぬき +ちぬり +ちのう +ちひょう +ちへいせん +ちほう +ちまた +ちみつ +ちみどろ +ちめいど +ちゃんこなべ +ちゅうい +ちゆりょく +ちょうし +ちょさくけん +ちらし +ちらみ +ちりがみ +ちりょう +ちるど +ちわわ +ちんたい +ちんもく +ついか +ついたち +つうか +つうじょう +つうはん +つうわ +つかう +つかれる +つくね +つくる +つけね +つける +つごう +つたえる +つづく +つつじ +つつむ +つとめる +つながる +つなみ +つねづね +つのる +つぶす +つまらない +つまる +つみき +つめたい +つもり +つもる +つよい +つるぼ +つるみく +つわもの +つわり +てあし +てあて +てあみ +ていおん +ていか +ていき +ていけい +ていこく +ていさつ +ていし +ていせい +ていたい +ていど +ていねい +ていひょう +ていへん +ていぼう +てうち +ておくれ +てきとう +てくび +でこぼこ +てさぎょう +てさげ +てすり +てそう +てちがい +てちょう +てつがく +てつづき +でっぱ +てつぼう +てつや +でぬかえ +てぬき +てぬぐい +てのひら +てはい +てぶくろ +てふだ +てほどき +てほん +てまえ +てまきずし +てみじか +てみやげ +てらす +てれび +てわけ +てわたし +でんあつ +てんいん +てんかい +てんき +てんぐ +てんけん +てんごく +てんさい +てんし +てんすう +でんち +てんてき +てんとう +てんない +てんぷら +てんぼうだい +てんめつ +てんらんかい +でんりょく +でんわ +どあい +といれ +どうかん +とうきゅう +どうぐ +とうし +とうむぎ +とおい +とおか +とおく +とおす +とおる +とかい +とかす +ときおり +ときどき +とくい +とくしゅう +とくてん +とくに +とくべつ +とけい +とける +とこや +とさか +としょかん +とそう +とたん +とちゅう +とっきゅう +とっくん +とつぜん +とつにゅう +とどける +ととのえる +とない +となえる +となり +とのさま +とばす +どぶがわ +とほう +とまる +とめる +ともだち +ともる +どようび +とらえる +とんかつ +どんぶり +ないかく +ないこう +ないしょ +ないす +ないせん +ないそう +なおす +ながい +なくす +なげる +なこうど +なさけ +なたでここ +なっとう +なつやすみ +ななおし +なにごと +なにもの +なにわ +なのか +なふだ +なまいき +なまえ +なまみ +なみだ +なめらか +なめる +なやむ +ならう +ならび +ならぶ +なれる +なわとび +なわばり +にあう +にいがた +にうけ +におい +にかい +にがて +にきび +にくしみ +にくまん +にげる +にさんかたんそ +にしき +にせもの +にちじょう +にちようび +にっか +にっき +にっけい +にっこう +にっさん +にっしょく +にっすう +にっせき +にってい +になう +にほん +にまめ +にもつ +にやり +にゅういん +にりんしゃ +にわとり +にんい +にんか +にんき +にんげん +にんしき +にんずう +にんそう +にんたい +にんち +にんてい +にんにく +にんぷ +にんまり +にんむ +にんめい +にんよう +ぬいくぎ +ぬかす +ぬぐいとる +ぬぐう +ぬくもり +ぬすむ +ぬまえび +ぬめり +ぬらす +ぬんちゃく +ねあげ +ねいき +ねいる +ねいろ +ねぐせ +ねくたい +ねくら +ねこぜ +ねこむ +ねさげ +ねすごす +ねそべる +ねだん +ねつい +ねっしん +ねつぞう +ねったいぎょ +ねぶそく +ねふだ +ねぼう +ねほりはほり +ねまき +ねまわし +ねみみ +ねむい +ねむたい +ねもと +ねらう +ねわざ +ねんいり +ねんおし +ねんかん +ねんきん +ねんぐ +ねんざ +ねんし +ねんちゃく +ねんど +ねんぴ +ねんぶつ +ねんまつ +ねんりょう +ねんれい +のいず +のおづま +のがす +のきなみ +のこぎり +のこす +のこる +のせる +のぞく +のぞむ +のたまう +のちほど +のっく +のばす +のはら +のべる +のぼる +のみもの +のやま +のらいぬ +のらねこ +のりもの +のりゆき +のれん +のんき +ばあい +はあく +ばあさん +ばいか +ばいく +はいけん +はいご +はいしん +はいすい +はいせん +はいそう +はいち +ばいばい +はいれつ +はえる +はおる +はかい +ばかり +はかる +はくしゅ +はけん +はこぶ +はさみ +はさん +はしご +ばしょ +はしる +はせる +ぱそこん +はそん +はたん +はちみつ +はつおん +はっかく +はづき +はっきり +はっくつ +はっけん +はっこう +はっさん +はっしん +はったつ +はっちゅう +はってん +はっぴょう +はっぽう +はなす +はなび +はにかむ +はぶらし +はみがき +はむかう +はめつ +はやい +はやし +はらう +はろうぃん +はわい +はんい +はんえい +はんおん +はんかく +はんきょう +ばんぐみ +はんこ +はんしゃ +はんすう +はんだん +ぱんち +ぱんつ +はんてい +はんとし +はんのう +はんぱ +はんぶん +はんぺん +はんぼうき +はんめい +はんらん +はんろん +ひいき +ひうん +ひえる +ひかく +ひかり +ひかる +ひかん +ひくい +ひけつ +ひこうき +ひこく +ひさい +ひさしぶり +ひさん +びじゅつかん +ひしょ +ひそか +ひそむ +ひたむき +ひだり +ひたる +ひつぎ +ひっこし +ひっし +ひつじゅひん +ひっす +ひつぜん +ぴったり +ぴっちり +ひつよう +ひてい +ひとごみ +ひなまつり +ひなん +ひねる +ひはん +ひびく +ひひょう +ひほう +ひまわり +ひまん +ひみつ +ひめい +ひめじし +ひやけ +ひやす +ひよう +びょうき +ひらがな +ひらく +ひりつ +ひりょう +ひるま +ひるやすみ +ひれい +ひろい +ひろう +ひろき +ひろゆき +ひんかく +ひんけつ +ひんこん +ひんしゅ +ひんそう +ぴんち +ひんぱん +びんぼう +ふあん +ふいうち +ふうけい +ふうせん +ぷうたろう +ふうとう +ふうふ +ふえる +ふおん +ふかい +ふきん +ふくざつ +ふくぶくろ +ふこう +ふさい +ふしぎ +ふじみ +ふすま +ふせい +ふせぐ +ふそく +ぶたにく +ふたん +ふちょう +ふつう +ふつか +ふっかつ +ふっき +ふっこく +ぶどう +ふとる +ふとん +ふのう +ふはい +ふひょう +ふへん +ふまん +ふみん +ふめつ +ふめん +ふよう +ふりこ +ふりる +ふるい +ふんいき +ぶんがく +ぶんぐ +ふんしつ +ぶんせき +ふんそう +ぶんぽう +へいあん +へいおん +へいがい +へいき +へいげん +へいこう +へいさ +へいしゃ +へいせつ +へいそ +へいたく +へいてん +へいねつ +へいわ +へきが +へこむ +べにいろ +べにしょうが +へらす +へんかん +べんきょう +べんごし +へんさい +へんたい +べんり +ほあん +ほいく +ぼうぎょ +ほうこく +ほうそう +ほうほう +ほうもん +ほうりつ +ほえる +ほおん +ほかん +ほきょう +ぼきん +ほくろ +ほけつ +ほけん +ほこう +ほこる +ほしい +ほしつ +ほしゅ +ほしょう +ほせい +ほそい +ほそく +ほたて +ほたる +ぽちぶくろ +ほっきょく +ほっさ +ほったん +ほとんど +ほめる +ほんい +ほんき +ほんけ +ほんしつ +ほんやく +まいにち +まかい +まかせる +まがる +まける +まこと +まさつ +まじめ +ますく +まぜる +まつり +まとめ +まなぶ +まぬけ +まねく +まほう +まもる +まゆげ +まよう +まろやか +まわす +まわり +まわる +まんが +まんきつ +まんぞく +まんなか +みいら +みうち +みえる +みがく +みかた +みかん +みけん +みこん +みじかい +みすい +みすえる +みせる +みっか +みつかる +みつける +みてい +みとめる +みなと +みなみかさい +みねらる +みのう +みのがす +みほん +みもと +みやげ +みらい +みりょく +みわく +みんか +みんぞく +むいか +むえき +むえん +むかい +むかう +むかえ +むかし +むぎちゃ +むける +むげん +むさぼる +むしあつい +むしば +むじゅん +むしろ +むすう +むすこ +むすぶ +むすめ +むせる +むせん +むちゅう +むなしい +むのう +むやみ +むよう +むらさき +むりょう +むろん +めいあん +めいうん +めいえん +めいかく +めいきょく +めいさい +めいし +めいそう +めいぶつ +めいれい +めいわく +めぐまれる +めざす +めした +めずらしい +めだつ +めまい +めやす +めんきょ +めんせき +めんどう +もうしあげる +もうどうけん +もえる +もくし +もくてき +もくようび +もちろん +もどる +もらう +もんく +もんだい +やおや +やける +やさい +やさしい +やすい +やすたろう +やすみ +やせる +やそう +やたい +やちん +やっと +やっぱり +やぶる +やめる +ややこしい +やよい +やわらかい +ゆうき +ゆうびんきょく +ゆうべ +ゆうめい +ゆけつ +ゆしゅつ +ゆせん +ゆそう +ゆたか +ゆちゃく +ゆでる +ゆにゅう +ゆびわ +ゆらい +ゆれる +ようい +ようか +ようきゅう +ようじ +ようす +ようちえん +よかぜ +よかん +よきん +よくせい +よくぼう +よけい +よごれる +よさん +よしゅう +よそう +よそく +よっか +よてい +よどがわく +よねつ +よやく +よゆう +よろこぶ +よろしい +らいう +らくがき +らくご +らくさつ +らくだ +らしんばん +らせん +らぞく +らたい +らっか +られつ +りえき +りかい +りきさく +りきせつ +りくぐん +りくつ +りけん +りこう +りせい +りそう +りそく +りてん +りねん +りゆう +りゅうがく +りよう +りょうり +りょかん +りょくちゃ +りょこう +りりく +りれき +りろん +りんご +るいけい +るいさい +るいじ +るいせき +るすばん +るりがわら +れいかん +れいぎ +れいせい +れいぞうこ +れいとう +れいぼう +れきし +れきだい +れんあい +れんけい +れんこん +れんさい +れんしゅう +れんぞく +れんらく +ろうか +ろうご +ろうじん +ろうそく +ろくが +ろこつ +ろじうら +ろしゅつ +ろせん +ろてん +ろめん +ろれつ +ろんぎ +ろんぱ +ろんぶん +ろんり +わかす +わかめ +わかやま +わかれる +わしつ +わじまし +わすれもの +わらう +われる diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/korean.txt b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/korean.txt new file mode 100755 index 0000000..1acebf7 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/korean.txt @@ -0,0 +1,2048 @@ +가격 +가끔 +가난 +가능 +가득 +가르침 +가뭄 +가방 +가상 +가슴 +가운데 +가을 +가이드 +가입 +가장 +가정 +가족 +가죽 +각오 +각자 +간격 +간부 +간섭 +간장 +간접 +간판 +갈등 +갈비 +갈색 +갈증 +감각 +감기 +감소 +감수성 +감자 +감정 +갑자기 +강남 +강당 +강도 +강력히 +강변 +강북 +강사 +강수량 +강아지 +강원도 +강의 +강제 +강조 +같이 +개구리 +개나리 +개방 +개별 +개선 +개성 +개인 +객관적 +거실 +거액 +거울 +거짓 +거품 +걱정 +건강 +건물 +건설 +건조 +건축 +걸음 +검사 +검토 +게시판 +게임 +겨울 +견해 +결과 +결국 +결론 +결석 +결승 +결심 +결정 +결혼 +경계 +경고 +경기 +경력 +경복궁 +경비 +경상도 +경영 +경우 +경쟁 +경제 +경주 +경찰 +경치 +경향 +경험 +계곡 +계단 +계란 +계산 +계속 +계약 +계절 +계층 +계획 +고객 +고구려 +고궁 +고급 +고등학생 +고무신 +고민 +고양이 +고장 +고전 +고집 +고춧가루 +고통 +고향 +곡식 +골목 +골짜기 +골프 +공간 +공개 +공격 +공군 +공급 +공기 +공동 +공무원 +공부 +공사 +공식 +공업 +공연 +공원 +공장 +공짜 +공책 +공통 +공포 +공항 +공휴일 +과목 +과일 +과장 +과정 +과학 +관객 +관계 +관광 +관념 +관람 +관련 +관리 +관습 +관심 +관점 +관찰 +광경 +광고 +광장 +광주 +괴로움 +굉장히 +교과서 +교문 +교복 +교실 +교양 +교육 +교장 +교직 +교통 +교환 +교훈 +구경 +구름 +구멍 +구별 +구분 +구석 +구성 +구속 +구역 +구입 +구청 +구체적 +국가 +국기 +국내 +국립 +국물 +국민 +국수 +국어 +국왕 +국적 +국제 +국회 +군대 +군사 +군인 +궁극적 +권리 +권위 +권투 +귀국 +귀신 +규정 +규칙 +균형 +그날 +그냥 +그늘 +그러나 +그룹 +그릇 +그림 +그제서야 +그토록 +극복 +극히 +근거 +근교 +근래 +근로 +근무 +근본 +근원 +근육 +근처 +글씨 +글자 +금강산 +금고 +금년 +금메달 +금액 +금연 +금요일 +금지 +긍정적 +기간 +기관 +기념 +기능 +기독교 +기둥 +기록 +기름 +기법 +기본 +기분 +기쁨 +기숙사 +기술 +기억 +기업 +기온 +기운 +기원 +기적 +기준 +기침 +기혼 +기획 +긴급 +긴장 +길이 +김밥 +김치 +김포공항 +깍두기 +깜빡 +깨달음 +깨소금 +껍질 +꼭대기 +꽃잎 +나들이 +나란히 +나머지 +나물 +나침반 +나흘 +낙엽 +난방 +날개 +날씨 +날짜 +남녀 +남대문 +남매 +남산 +남자 +남편 +남학생 +낭비 +낱말 +내년 +내용 +내일 +냄비 +냄새 +냇물 +냉동 +냉면 +냉방 +냉장고 +넥타이 +넷째 +노동 +노란색 +노력 +노인 +녹음 +녹차 +녹화 +논리 +논문 +논쟁 +놀이 +농구 +농담 +농민 +농부 +농업 +농장 +농촌 +높이 +눈동자 +눈물 +눈썹 +뉴욕 +느낌 +늑대 +능동적 +능력 +다방 +다양성 +다음 +다이어트 +다행 +단계 +단골 +단독 +단맛 +단순 +단어 +단위 +단점 +단체 +단추 +단편 +단풍 +달걀 +달러 +달력 +달리 +닭고기 +담당 +담배 +담요 +담임 +답변 +답장 +당근 +당분간 +당연히 +당장 +대규모 +대낮 +대단히 +대답 +대도시 +대략 +대량 +대륙 +대문 +대부분 +대신 +대응 +대장 +대전 +대접 +대중 +대책 +대출 +대충 +대통령 +대학 +대한민국 +대합실 +대형 +덩어리 +데이트 +도대체 +도덕 +도둑 +도망 +도서관 +도심 +도움 +도입 +도자기 +도저히 +도전 +도중 +도착 +독감 +독립 +독서 +독일 +독창적 +동화책 +뒷모습 +뒷산 +딸아이 +마누라 +마늘 +마당 +마라톤 +마련 +마무리 +마사지 +마약 +마요네즈 +마을 +마음 +마이크 +마중 +마지막 +마찬가지 +마찰 +마흔 +막걸리 +막내 +막상 +만남 +만두 +만세 +만약 +만일 +만점 +만족 +만화 +많이 +말기 +말씀 +말투 +맘대로 +망원경 +매년 +매달 +매력 +매번 +매스컴 +매일 +매장 +맥주 +먹이 +먼저 +먼지 +멀리 +메일 +며느리 +며칠 +면담 +멸치 +명단 +명령 +명예 +명의 +명절 +명칭 +명함 +모금 +모니터 +모델 +모든 +모범 +모습 +모양 +모임 +모조리 +모집 +모퉁이 +목걸이 +목록 +목사 +목소리 +목숨 +목적 +목표 +몰래 +몸매 +몸무게 +몸살 +몸속 +몸짓 +몸통 +몹시 +무관심 +무궁화 +무더위 +무덤 +무릎 +무슨 +무엇 +무역 +무용 +무조건 +무지개 +무척 +문구 +문득 +문법 +문서 +문제 +문학 +문화 +물가 +물건 +물결 +물고기 +물론 +물리학 +물음 +물질 +물체 +미국 +미디어 +미사일 +미술 +미역 +미용실 +미움 +미인 +미팅 +미혼 +민간 +민족 +민주 +믿음 +밀가루 +밀리미터 +밑바닥 +바가지 +바구니 +바나나 +바늘 +바닥 +바닷가 +바람 +바이러스 +바탕 +박물관 +박사 +박수 +반대 +반드시 +반말 +반발 +반성 +반응 +반장 +반죽 +반지 +반찬 +받침 +발가락 +발걸음 +발견 +발달 +발레 +발목 +발바닥 +발생 +발음 +발자국 +발전 +발톱 +발표 +밤하늘 +밥그릇 +밥맛 +밥상 +밥솥 +방금 +방면 +방문 +방바닥 +방법 +방송 +방식 +방안 +방울 +방지 +방학 +방해 +방향 +배경 +배꼽 +배달 +배드민턴 +백두산 +백색 +백성 +백인 +백제 +백화점 +버릇 +버섯 +버튼 +번개 +번역 +번지 +번호 +벌금 +벌레 +벌써 +범위 +범인 +범죄 +법률 +법원 +법적 +법칙 +베이징 +벨트 +변경 +변동 +변명 +변신 +변호사 +변화 +별도 +별명 +별일 +병실 +병아리 +병원 +보관 +보너스 +보라색 +보람 +보름 +보상 +보안 +보자기 +보장 +보전 +보존 +보통 +보편적 +보험 +복도 +복사 +복숭아 +복습 +볶음 +본격적 +본래 +본부 +본사 +본성 +본인 +본질 +볼펜 +봉사 +봉지 +봉투 +부근 +부끄러움 +부담 +부동산 +부문 +부분 +부산 +부상 +부엌 +부인 +부작용 +부장 +부정 +부족 +부지런히 +부친 +부탁 +부품 +부회장 +북부 +북한 +분노 +분량 +분리 +분명 +분석 +분야 +분위기 +분필 +분홍색 +불고기 +불과 +불교 +불꽃 +불만 +불법 +불빛 +불안 +불이익 +불행 +브랜드 +비극 +비난 +비닐 +비둘기 +비디오 +비로소 +비만 +비명 +비밀 +비바람 +비빔밥 +비상 +비용 +비율 +비중 +비타민 +비판 +빌딩 +빗물 +빗방울 +빗줄기 +빛깔 +빨간색 +빨래 +빨리 +사건 +사계절 +사나이 +사냥 +사람 +사랑 +사립 +사모님 +사물 +사방 +사상 +사생활 +사설 +사슴 +사실 +사업 +사용 +사월 +사장 +사전 +사진 +사촌 +사춘기 +사탕 +사투리 +사흘 +산길 +산부인과 +산업 +산책 +살림 +살인 +살짝 +삼계탕 +삼국 +삼십 +삼월 +삼촌 +상관 +상금 +상대 +상류 +상반기 +상상 +상식 +상업 +상인 +상자 +상점 +상처 +상추 +상태 +상표 +상품 +상황 +새벽 +색깔 +색연필 +생각 +생명 +생물 +생방송 +생산 +생선 +생신 +생일 +생활 +서랍 +서른 +서명 +서민 +서비스 +서양 +서울 +서적 +서점 +서쪽 +서클 +석사 +석유 +선거 +선물 +선배 +선생 +선수 +선원 +선장 +선전 +선택 +선풍기 +설거지 +설날 +설렁탕 +설명 +설문 +설사 +설악산 +설치 +설탕 +섭씨 +성공 +성당 +성명 +성별 +성인 +성장 +성적 +성질 +성함 +세금 +세미나 +세상 +세월 +세종대왕 +세탁 +센터 +센티미터 +셋째 +소규모 +소극적 +소금 +소나기 +소년 +소득 +소망 +소문 +소설 +소속 +소아과 +소용 +소원 +소음 +소중히 +소지품 +소질 +소풍 +소형 +속담 +속도 +속옷 +손가락 +손길 +손녀 +손님 +손등 +손목 +손뼉 +손실 +손질 +손톱 +손해 +솔직히 +솜씨 +송아지 +송이 +송편 +쇠고기 +쇼핑 +수건 +수년 +수단 +수돗물 +수동적 +수면 +수명 +수박 +수상 +수석 +수술 +수시로 +수업 +수염 +수영 +수입 +수준 +수집 +수출 +수컷 +수필 +수학 +수험생 +수화기 +숙녀 +숙소 +숙제 +순간 +순서 +순수 +순식간 +순위 +숟가락 +술병 +술집 +숫자 +스님 +스물 +스스로 +스승 +스웨터 +스위치 +스케이트 +스튜디오 +스트레스 +스포츠 +슬쩍 +슬픔 +습관 +습기 +승객 +승리 +승부 +승용차 +승진 +시각 +시간 +시골 +시금치 +시나리오 +시댁 +시리즈 +시멘트 +시민 +시부모 +시선 +시설 +시스템 +시아버지 +시어머니 +시월 +시인 +시일 +시작 +시장 +시절 +시점 +시중 +시즌 +시집 +시청 +시합 +시험 +식구 +식기 +식당 +식량 +식료품 +식물 +식빵 +식사 +식생활 +식초 +식탁 +식품 +신고 +신규 +신념 +신문 +신발 +신비 +신사 +신세 +신용 +신제품 +신청 +신체 +신화 +실감 +실내 +실력 +실례 +실망 +실수 +실습 +실시 +실장 +실정 +실질적 +실천 +실체 +실컷 +실태 +실패 +실험 +실현 +심리 +심부름 +심사 +심장 +심정 +심판 +쌍둥이 +씨름 +씨앗 +아가씨 +아나운서 +아드님 +아들 +아쉬움 +아스팔트 +아시아 +아울러 +아저씨 +아줌마 +아직 +아침 +아파트 +아프리카 +아픔 +아홉 +아흔 +악기 +악몽 +악수 +안개 +안경 +안과 +안내 +안녕 +안동 +안방 +안부 +안주 +알루미늄 +알코올 +암시 +암컷 +압력 +앞날 +앞문 +애인 +애정 +액수 +앨범 +야간 +야단 +야옹 +약간 +약국 +약속 +약수 +약점 +약품 +약혼녀 +양념 +양력 +양말 +양배추 +양주 +양파 +어둠 +어려움 +어른 +어젯밤 +어쨌든 +어쩌다가 +어쩐지 +언니 +언덕 +언론 +언어 +얼굴 +얼른 +얼음 +얼핏 +엄마 +업무 +업종 +업체 +엉덩이 +엉망 +엉터리 +엊그제 +에너지 +에어컨 +엔진 +여건 +여고생 +여관 +여군 +여권 +여대생 +여덟 +여동생 +여든 +여론 +여름 +여섯 +여성 +여왕 +여인 +여전히 +여직원 +여학생 +여행 +역사 +역시 +역할 +연결 +연구 +연극 +연기 +연락 +연설 +연세 +연속 +연습 +연애 +연예인 +연인 +연장 +연주 +연출 +연필 +연합 +연휴 +열기 +열매 +열쇠 +열심히 +열정 +열차 +열흘 +염려 +엽서 +영국 +영남 +영상 +영양 +영역 +영웅 +영원히 +영하 +영향 +영혼 +영화 +옆구리 +옆방 +옆집 +예감 +예금 +예방 +예산 +예상 +예선 +예술 +예습 +예식장 +예약 +예전 +예절 +예정 +예컨대 +옛날 +오늘 +오락 +오랫동안 +오렌지 +오로지 +오른발 +오븐 +오십 +오염 +오월 +오전 +오직 +오징어 +오페라 +오피스텔 +오히려 +옥상 +옥수수 +온갖 +온라인 +온몸 +온종일 +온통 +올가을 +올림픽 +올해 +옷차림 +와이셔츠 +와인 +완성 +완전 +왕비 +왕자 +왜냐하면 +왠지 +외갓집 +외국 +외로움 +외삼촌 +외출 +외침 +외할머니 +왼발 +왼손 +왼쪽 +요금 +요일 +요즘 +요청 +용기 +용서 +용어 +우산 +우선 +우승 +우연히 +우정 +우체국 +우편 +운동 +운명 +운반 +운전 +운행 +울산 +울음 +움직임 +웃어른 +웃음 +워낙 +원고 +원래 +원서 +원숭이 +원인 +원장 +원피스 +월급 +월드컵 +월세 +월요일 +웨이터 +위반 +위법 +위성 +위원 +위험 +위협 +윗사람 +유난히 +유럽 +유명 +유물 +유산 +유적 +유치원 +유학 +유행 +유형 +육군 +육상 +육십 +육체 +은행 +음력 +음료 +음반 +음성 +음식 +음악 +음주 +의견 +의논 +의문 +의복 +의식 +의심 +의외로 +의욕 +의원 +의학 +이것 +이곳 +이념 +이놈 +이달 +이대로 +이동 +이렇게 +이력서 +이론적 +이름 +이민 +이발소 +이별 +이불 +이빨 +이상 +이성 +이슬 +이야기 +이용 +이웃 +이월 +이윽고 +이익 +이전 +이중 +이튿날 +이틀 +이혼 +인간 +인격 +인공 +인구 +인근 +인기 +인도 +인류 +인물 +인생 +인쇄 +인연 +인원 +인재 +인종 +인천 +인체 +인터넷 +인하 +인형 +일곱 +일기 +일단 +일대 +일등 +일반 +일본 +일부 +일상 +일생 +일손 +일요일 +일월 +일정 +일종 +일주일 +일찍 +일체 +일치 +일행 +일회용 +임금 +임무 +입대 +입력 +입맛 +입사 +입술 +입시 +입원 +입장 +입학 +자가용 +자격 +자극 +자동 +자랑 +자부심 +자식 +자신 +자연 +자원 +자율 +자전거 +자정 +자존심 +자판 +작가 +작년 +작성 +작업 +작용 +작은딸 +작품 +잔디 +잔뜩 +잔치 +잘못 +잠깐 +잠수함 +잠시 +잠옷 +잠자리 +잡지 +장관 +장군 +장기간 +장래 +장례 +장르 +장마 +장면 +장모 +장미 +장비 +장사 +장소 +장식 +장애인 +장인 +장점 +장차 +장학금 +재능 +재빨리 +재산 +재생 +재작년 +재정 +재채기 +재판 +재학 +재활용 +저것 +저고리 +저곳 +저녁 +저런 +저렇게 +저번 +저울 +저절로 +저축 +적극 +적당히 +적성 +적용 +적응 +전개 +전공 +전기 +전달 +전라도 +전망 +전문 +전반 +전부 +전세 +전시 +전용 +전자 +전쟁 +전주 +전철 +전체 +전통 +전혀 +전후 +절대 +절망 +절반 +절약 +절차 +점검 +점수 +점심 +점원 +점점 +점차 +접근 +접시 +접촉 +젓가락 +정거장 +정도 +정류장 +정리 +정말 +정면 +정문 +정반대 +정보 +정부 +정비 +정상 +정성 +정오 +정원 +정장 +정지 +정치 +정확히 +제공 +제과점 +제대로 +제목 +제발 +제법 +제삿날 +제안 +제일 +제작 +제주도 +제출 +제품 +제한 +조각 +조건 +조금 +조깅 +조명 +조미료 +조상 +조선 +조용히 +조절 +조정 +조직 +존댓말 +존재 +졸업 +졸음 +종교 +종로 +종류 +종소리 +종업원 +종종 +종합 +좌석 +죄인 +주관적 +주름 +주말 +주머니 +주먹 +주문 +주민 +주방 +주변 +주식 +주인 +주일 +주장 +주전자 +주택 +준비 +줄거리 +줄기 +줄무늬 +중간 +중계방송 +중국 +중년 +중단 +중독 +중반 +중부 +중세 +중소기업 +중순 +중앙 +중요 +중학교 +즉석 +즉시 +즐거움 +증가 +증거 +증권 +증상 +증세 +지각 +지갑 +지경 +지극히 +지금 +지급 +지능 +지름길 +지리산 +지방 +지붕 +지식 +지역 +지우개 +지원 +지적 +지점 +지진 +지출 +직선 +직업 +직원 +직장 +진급 +진동 +진로 +진료 +진리 +진짜 +진찰 +진출 +진통 +진행 +질문 +질병 +질서 +짐작 +집단 +집안 +집중 +짜증 +찌꺼기 +차남 +차라리 +차량 +차림 +차별 +차선 +차츰 +착각 +찬물 +찬성 +참가 +참기름 +참새 +참석 +참여 +참외 +참조 +찻잔 +창가 +창고 +창구 +창문 +창밖 +창작 +창조 +채널 +채점 +책가방 +책방 +책상 +책임 +챔피언 +처벌 +처음 +천국 +천둥 +천장 +천재 +천천히 +철도 +철저히 +철학 +첫날 +첫째 +청년 +청바지 +청소 +청춘 +체계 +체력 +체온 +체육 +체중 +체험 +초등학생 +초반 +초밥 +초상화 +초순 +초여름 +초원 +초저녁 +초점 +초청 +초콜릿 +촛불 +총각 +총리 +총장 +촬영 +최근 +최상 +최선 +최신 +최악 +최종 +추석 +추억 +추진 +추천 +추측 +축구 +축소 +축제 +축하 +출근 +출발 +출산 +출신 +출연 +출입 +출장 +출판 +충격 +충고 +충돌 +충분히 +충청도 +취업 +취직 +취향 +치약 +친구 +친척 +칠십 +칠월 +칠판 +침대 +침묵 +침실 +칫솔 +칭찬 +카메라 +카운터 +칼국수 +캐릭터 +캠퍼스 +캠페인 +커튼 +컨디션 +컬러 +컴퓨터 +코끼리 +코미디 +콘서트 +콜라 +콤플렉스 +콩나물 +쾌감 +쿠데타 +크림 +큰길 +큰딸 +큰소리 +큰아들 +큰어머니 +큰일 +큰절 +클래식 +클럽 +킬로 +타입 +타자기 +탁구 +탁자 +탄생 +태권도 +태양 +태풍 +택시 +탤런트 +터널 +터미널 +테니스 +테스트 +테이블 +텔레비전 +토론 +토마토 +토요일 +통계 +통과 +통로 +통신 +통역 +통일 +통장 +통제 +통증 +통합 +통화 +퇴근 +퇴원 +퇴직금 +튀김 +트럭 +특급 +특별 +특성 +특수 +특징 +특히 +튼튼히 +티셔츠 +파란색 +파일 +파출소 +판결 +판단 +판매 +판사 +팔십 +팔월 +팝송 +패션 +팩스 +팩시밀리 +팬티 +퍼센트 +페인트 +편견 +편의 +편지 +편히 +평가 +평균 +평생 +평소 +평양 +평일 +평화 +포스터 +포인트 +포장 +포함 +표면 +표정 +표준 +표현 +품목 +품질 +풍경 +풍속 +풍습 +프랑스 +프린터 +플라스틱 +피곤 +피망 +피아노 +필름 +필수 +필요 +필자 +필통 +핑계 +하느님 +하늘 +하드웨어 +하룻밤 +하반기 +하숙집 +하순 +하여튼 +하지만 +하천 +하품 +하필 +학과 +학교 +학급 +학기 +학년 +학력 +학번 +학부모 +학비 +학생 +학술 +학습 +학용품 +학원 +학위 +학자 +학점 +한계 +한글 +한꺼번에 +한낮 +한눈 +한동안 +한때 +한라산 +한마디 +한문 +한번 +한복 +한식 +한여름 +한쪽 +할머니 +할아버지 +할인 +함께 +함부로 +합격 +합리적 +항공 +항구 +항상 +항의 +해결 +해군 +해답 +해당 +해물 +해석 +해설 +해수욕장 +해안 +핵심 +핸드백 +햄버거 +햇볕 +햇살 +행동 +행복 +행사 +행운 +행위 +향기 +향상 +향수 +허락 +허용 +헬기 +현관 +현금 +현대 +현상 +현실 +현장 +현재 +현지 +혈액 +협력 +형부 +형사 +형수 +형식 +형제 +형태 +형편 +혜택 +호기심 +호남 +호랑이 +호박 +호텔 +호흡 +혹시 +홀로 +홈페이지 +홍보 +홍수 +홍차 +화면 +화분 +화살 +화요일 +화장 +화학 +확보 +확인 +확장 +확정 +환갑 +환경 +환영 +환율 +환자 +활기 +활동 +활발히 +활용 +활짝 +회견 +회관 +회복 +회색 +회원 +회장 +회전 +횟수 +횡단보도 +효율적 +후반 +후춧가루 +훈련 +훨씬 +휴식 +휴일 +흉내 +흐름 +흑백 +흑인 +흔적 +흔히 +흥미 +흥분 +희곡 +희망 +희생 +흰색 +힘껏 diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/spanish.txt b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/spanish.txt new file mode 100755 index 0000000..fdbc23c --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Assets/bip-0039/spanish.txt @@ -0,0 +1,2048 @@ +ábaco +abdomen +abeja +abierto +abogado +abono +aborto +abrazo +abrir +abuelo +abuso +acabar +academia +acceso +acción +aceite +acelga +acento +aceptar +ácido +aclarar +acné +acoger +acoso +activo +acto +actriz +actuar +acudir +acuerdo +acusar +adicto +admitir +adoptar +adorno +aduana +adulto +aéreo +afectar +afición +afinar +afirmar +ágil +agitar +agonía +agosto +agotar +agregar +agrio +agua +agudo +águila +aguja +ahogo +ahorro +aire +aislar +ajedrez +ajeno +ajuste +alacrán +alambre +alarma +alba +álbum +alcalde +aldea +alegre +alejar +alerta +aleta +alfiler +alga +algodón +aliado +aliento +alivio +alma +almeja +almíbar +altar +alteza +altivo +alto +altura +alumno +alzar +amable +amante +amapola +amargo +amasar +ámbar +ámbito +ameno +amigo +amistad +amor +amparo +amplio +ancho +anciano +ancla +andar +andén +anemia +ángulo +anillo +ánimo +anís +anotar +antena +antiguo +antojo +anual +anular +anuncio +añadir +añejo +año +apagar +aparato +apetito +apio +aplicar +apodo +aporte +apoyo +aprender +aprobar +apuesta +apuro +arado +araña +arar +árbitro +árbol +arbusto +archivo +arco +arder +ardilla +arduo +área +árido +aries +armonía +arnés +aroma +arpa +arpón +arreglo +arroz +arruga +arte +artista +asa +asado +asalto +ascenso +asegurar +aseo +asesor +asiento +asilo +asistir +asno +asombro +áspero +astilla +astro +astuto +asumir +asunto +atajo +ataque +atar +atento +ateo +ático +atleta +átomo +atraer +atroz +atún +audaz +audio +auge +aula +aumento +ausente +autor +aval +avance +avaro +ave +avellana +avena +avestruz +avión +aviso +ayer +ayuda +ayuno +azafrán +azar +azote +azúcar +azufre +azul +baba +babor +bache +bahía +baile +bajar +balanza +balcón +balde +bambú +banco +banda +baño +barba +barco +barniz +barro +báscula +bastón +basura +batalla +batería +batir +batuta +baúl +bazar +bebé +bebida +bello +besar +beso +bestia +bicho +bien +bingo +blanco +bloque +blusa +boa +bobina +bobo +boca +bocina +boda +bodega +boina +bola +bolero +bolsa +bomba +bondad +bonito +bono +bonsái +borde +borrar +bosque +bote +botín +bóveda +bozal +bravo +brazo +brecha +breve +brillo +brinco +brisa +broca +broma +bronce +brote +bruja +brusco +bruto +buceo +bucle +bueno +buey +bufanda +bufón +búho +buitre +bulto +burbuja +burla +burro +buscar +butaca +buzón +caballo +cabeza +cabina +cabra +cacao +cadáver +cadena +caer +café +caída +caimán +caja +cajón +cal +calamar +calcio +caldo +calidad +calle +calma +calor +calvo +cama +cambio +camello +camino +campo +cáncer +candil +canela +canguro +canica +canto +caña +cañón +caoba +caos +capaz +capitán +capote +captar +capucha +cara +carbón +cárcel +careta +carga +cariño +carne +carpeta +carro +carta +casa +casco +casero +caspa +castor +catorce +catre +caudal +causa +cazo +cebolla +ceder +cedro +celda +célebre +celoso +célula +cemento +ceniza +centro +cerca +cerdo +cereza +cero +cerrar +certeza +césped +cetro +chacal +chaleco +champú +chancla +chapa +charla +chico +chiste +chivo +choque +choza +chuleta +chupar +ciclón +ciego +cielo +cien +cierto +cifra +cigarro +cima +cinco +cine +cinta +ciprés +circo +ciruela +cisne +cita +ciudad +clamor +clan +claro +clase +clave +cliente +clima +clínica +cobre +cocción +cochino +cocina +coco +código +codo +cofre +coger +cohete +cojín +cojo +cola +colcha +colegio +colgar +colina +collar +colmo +columna +combate +comer +comida +cómodo +compra +conde +conejo +conga +conocer +consejo +contar +copa +copia +corazón +corbata +corcho +cordón +corona +correr +coser +cosmos +costa +cráneo +cráter +crear +crecer +creído +crema +cría +crimen +cripta +crisis +cromo +crónica +croqueta +crudo +cruz +cuadro +cuarto +cuatro +cubo +cubrir +cuchara +cuello +cuento +cuerda +cuesta +cueva +cuidar +culebra +culpa +culto +cumbre +cumplir +cuna +cuneta +cuota +cupón +cúpula +curar +curioso +curso +curva +cutis +dama +danza +dar +dardo +dátil +deber +débil +década +decir +dedo +defensa +definir +dejar +delfín +delgado +delito +demora +denso +dental +deporte +derecho +derrota +desayuno +deseo +desfile +desnudo +destino +desvío +detalle +detener +deuda +día +diablo +diadema +diamante +diana +diario +dibujo +dictar +diente +dieta +diez +difícil +digno +dilema +diluir +dinero +directo +dirigir +disco +diseño +disfraz +diva +divino +doble +doce +dolor +domingo +don +donar +dorado +dormir +dorso +dos +dosis +dragón +droga +ducha +duda +duelo +dueño +dulce +dúo +duque +durar +dureza +duro +ébano +ebrio +echar +eco +ecuador +edad +edición +edificio +editor +educar +efecto +eficaz +eje +ejemplo +elefante +elegir +elemento +elevar +elipse +élite +elixir +elogio +eludir +embudo +emitir +emoción +empate +empeño +empleo +empresa +enano +encargo +enchufe +encía +enemigo +enero +enfado +enfermo +engaño +enigma +enlace +enorme +enredo +ensayo +enseñar +entero +entrar +envase +envío +época +equipo +erizo +escala +escena +escolar +escribir +escudo +esencia +esfera +esfuerzo +espada +espejo +espía +esposa +espuma +esquí +estar +este +estilo +estufa +etapa +eterno +ética +etnia +evadir +evaluar +evento +evitar +exacto +examen +exceso +excusa +exento +exigir +exilio +existir +éxito +experto +explicar +exponer +extremo +fábrica +fábula +fachada +fácil +factor +faena +faja +falda +fallo +falso +faltar +fama +familia +famoso +faraón +farmacia +farol +farsa +fase +fatiga +fauna +favor +fax +febrero +fecha +feliz +feo +feria +feroz +fértil +fervor +festín +fiable +fianza +fiar +fibra +ficción +ficha +fideo +fiebre +fiel +fiera +fiesta +figura +fijar +fijo +fila +filete +filial +filtro +fin +finca +fingir +finito +firma +flaco +flauta +flecha +flor +flota +fluir +flujo +flúor +fobia +foca +fogata +fogón +folio +folleto +fondo +forma +forro +fortuna +forzar +fosa +foto +fracaso +frágil +franja +frase +fraude +freír +freno +fresa +frío +frito +fruta +fuego +fuente +fuerza +fuga +fumar +función +funda +furgón +furia +fusil +fútbol +futuro +gacela +gafas +gaita +gajo +gala +galería +gallo +gamba +ganar +gancho +ganga +ganso +garaje +garza +gasolina +gastar +gato +gavilán +gemelo +gemir +gen +género +genio +gente +geranio +gerente +germen +gesto +gigante +gimnasio +girar +giro +glaciar +globo +gloria +gol +golfo +goloso +golpe +goma +gordo +gorila +gorra +gota +goteo +gozar +grada +gráfico +grano +grasa +gratis +grave +grieta +grillo +gripe +gris +grito +grosor +grúa +grueso +grumo +grupo +guante +guapo +guardia +guerra +guía +guiño +guion +guiso +guitarra +gusano +gustar +haber +hábil +hablar +hacer +hacha +hada +hallar +hamaca +harina +haz +hazaña +hebilla +hebra +hecho +helado +helio +hembra +herir +hermano +héroe +hervir +hielo +hierro +hígado +higiene +hijo +himno +historia +hocico +hogar +hoguera +hoja +hombre +hongo +honor +honra +hora +hormiga +horno +hostil +hoyo +hueco +huelga +huerta +hueso +huevo +huida +huir +humano +húmedo +humilde +humo +hundir +huracán +hurto +icono +ideal +idioma +ídolo +iglesia +iglú +igual +ilegal +ilusión +imagen +imán +imitar +impar +imperio +imponer +impulso +incapaz +índice +inerte +infiel +informe +ingenio +inicio +inmenso +inmune +innato +insecto +instante +interés +íntimo +intuir +inútil +invierno +ira +iris +ironía +isla +islote +jabalí +jabón +jamón +jarabe +jardín +jarra +jaula +jazmín +jefe +jeringa +jinete +jornada +joroba +joven +joya +juerga +jueves +juez +jugador +jugo +juguete +juicio +junco +jungla +junio +juntar +júpiter +jurar +justo +juvenil +juzgar +kilo +koala +labio +lacio +lacra +lado +ladrón +lagarto +lágrima +laguna +laico +lamer +lámina +lámpara +lana +lancha +langosta +lanza +lápiz +largo +larva +lástima +lata +látex +latir +laurel +lavar +lazo +leal +lección +leche +lector +leer +legión +legumbre +lejano +lengua +lento +leña +león +leopardo +lesión +letal +letra +leve +leyenda +libertad +libro +licor +líder +lidiar +lienzo +liga +ligero +lima +límite +limón +limpio +lince +lindo +línea +lingote +lino +linterna +líquido +liso +lista +litera +litio +litro +llaga +llama +llanto +llave +llegar +llenar +llevar +llorar +llover +lluvia +lobo +loción +loco +locura +lógica +logro +lombriz +lomo +lonja +lote +lucha +lucir +lugar +lujo +luna +lunes +lupa +lustro +luto +luz +maceta +macho +madera +madre +maduro +maestro +mafia +magia +mago +maíz +maldad +maleta +malla +malo +mamá +mambo +mamut +manco +mando +manejar +manga +maniquí +manjar +mano +manso +manta +mañana +mapa +máquina +mar +marco +marea +marfil +margen +marido +mármol +marrón +martes +marzo +masa +máscara +masivo +matar +materia +matiz +matriz +máximo +mayor +mazorca +mecha +medalla +medio +médula +mejilla +mejor +melena +melón +memoria +menor +mensaje +mente +menú +mercado +merengue +mérito +mes +mesón +meta +meter +método +metro +mezcla +miedo +miel +miembro +miga +mil +milagro +militar +millón +mimo +mina +minero +mínimo +minuto +miope +mirar +misa +miseria +misil +mismo +mitad +mito +mochila +moción +moda +modelo +moho +mojar +molde +moler +molino +momento +momia +monarca +moneda +monja +monto +moño +morada +morder +moreno +morir +morro +morsa +mortal +mosca +mostrar +motivo +mover +móvil +mozo +mucho +mudar +mueble +muela +muerte +muestra +mugre +mujer +mula +muleta +multa +mundo +muñeca +mural +muro +músculo +museo +musgo +música +muslo +nácar +nación +nadar +naipe +naranja +nariz +narrar +nasal +natal +nativo +natural +náusea +naval +nave +navidad +necio +néctar +negar +negocio +negro +neón +nervio +neto +neutro +nevar +nevera +nicho +nido +niebla +nieto +niñez +niño +nítido +nivel +nobleza +noche +nómina +noria +norma +norte +nota +noticia +novato +novela +novio +nube +nuca +núcleo +nudillo +nudo +nuera +nueve +nuez +nulo +número +nutria +oasis +obeso +obispo +objeto +obra +obrero +observar +obtener +obvio +oca +ocaso +océano +ochenta +ocho +ocio +ocre +octavo +octubre +oculto +ocupar +ocurrir +odiar +odio +odisea +oeste +ofensa +oferta +oficio +ofrecer +ogro +oído +oír +ojo +ola +oleada +olfato +olivo +olla +olmo +olor +olvido +ombligo +onda +onza +opaco +opción +ópera +opinar +oponer +optar +óptica +opuesto +oración +orador +oral +órbita +orca +orden +oreja +órgano +orgía +orgullo +oriente +origen +orilla +oro +orquesta +oruga +osadía +oscuro +osezno +oso +ostra +otoño +otro +oveja +óvulo +óxido +oxígeno +oyente +ozono +pacto +padre +paella +página +pago +país +pájaro +palabra +palco +paleta +pálido +palma +paloma +palpar +pan +panal +pánico +pantera +pañuelo +papá +papel +papilla +paquete +parar +parcela +pared +parir +paro +párpado +parque +párrafo +parte +pasar +paseo +pasión +paso +pasta +pata +patio +patria +pausa +pauta +pavo +payaso +peatón +pecado +pecera +pecho +pedal +pedir +pegar +peine +pelar +peldaño +pelea +peligro +pellejo +pelo +peluca +pena +pensar +peñón +peón +peor +pepino +pequeño +pera +percha +perder +pereza +perfil +perico +perla +permiso +perro +persona +pesa +pesca +pésimo +pestaña +pétalo +petróleo +pez +pezuña +picar +pichón +pie +piedra +pierna +pieza +pijama +pilar +piloto +pimienta +pino +pintor +pinza +piña +piojo +pipa +pirata +pisar +piscina +piso +pista +pitón +pizca +placa +plan +plata +playa +plaza +pleito +pleno +plomo +pluma +plural +pobre +poco +poder +podio +poema +poesía +poeta +polen +policía +pollo +polvo +pomada +pomelo +pomo +pompa +poner +porción +portal +posada +poseer +posible +poste +potencia +potro +pozo +prado +precoz +pregunta +premio +prensa +preso +previo +primo +príncipe +prisión +privar +proa +probar +proceso +producto +proeza +profesor +programa +prole +promesa +pronto +propio +próximo +prueba +público +puchero +pudor +pueblo +puerta +puesto +pulga +pulir +pulmón +pulpo +pulso +puma +punto +puñal +puño +pupa +pupila +puré +quedar +queja +quemar +querer +queso +quieto +química +quince +quitar +rábano +rabia +rabo +ración +radical +raíz +rama +rampa +rancho +rango +rapaz +rápido +rapto +rasgo +raspa +rato +rayo +raza +razón +reacción +realidad +rebaño +rebote +recaer +receta +rechazo +recoger +recreo +recto +recurso +red +redondo +reducir +reflejo +reforma +refrán +refugio +regalo +regir +regla +regreso +rehén +reino +reír +reja +relato +relevo +relieve +relleno +reloj +remar +remedio +remo +rencor +rendir +renta +reparto +repetir +reposo +reptil +res +rescate +resina +respeto +resto +resumen +retiro +retorno +retrato +reunir +revés +revista +rey +rezar +rico +riego +rienda +riesgo +rifa +rígido +rigor +rincón +riñón +río +riqueza +risa +ritmo +rito +rizo +roble +roce +rociar +rodar +rodeo +rodilla +roer +rojizo +rojo +romero +romper +ron +ronco +ronda +ropa +ropero +rosa +rosca +rostro +rotar +rubí +rubor +rudo +rueda +rugir +ruido +ruina +ruleta +rulo +rumbo +rumor +ruptura +ruta +rutina +sábado +saber +sabio +sable +sacar +sagaz +sagrado +sala +saldo +salero +salir +salmón +salón +salsa +salto +salud +salvar +samba +sanción +sandía +sanear +sangre +sanidad +sano +santo +sapo +saque +sardina +sartén +sastre +satán +sauna +saxofón +sección +seco +secreto +secta +sed +seguir +seis +sello +selva +semana +semilla +senda +sensor +señal +señor +separar +sepia +sequía +ser +serie +sermón +servir +sesenta +sesión +seta +setenta +severo +sexo +sexto +sidra +siesta +siete +siglo +signo +sílaba +silbar +silencio +silla +símbolo +simio +sirena +sistema +sitio +situar +sobre +socio +sodio +sol +solapa +soldado +soledad +sólido +soltar +solución +sombra +sondeo +sonido +sonoro +sonrisa +sopa +soplar +soporte +sordo +sorpresa +sorteo +sostén +sótano +suave +subir +suceso +sudor +suegra +suelo +sueño +suerte +sufrir +sujeto +sultán +sumar +superar +suplir +suponer +supremo +sur +surco +sureño +surgir +susto +sutil +tabaco +tabique +tabla +tabú +taco +tacto +tajo +talar +talco +talento +talla +talón +tamaño +tambor +tango +tanque +tapa +tapete +tapia +tapón +taquilla +tarde +tarea +tarifa +tarjeta +tarot +tarro +tarta +tatuaje +tauro +taza +tazón +teatro +techo +tecla +técnica +tejado +tejer +tejido +tela +teléfono +tema +temor +templo +tenaz +tender +tener +tenis +tenso +teoría +terapia +terco +término +ternura +terror +tesis +tesoro +testigo +tetera +texto +tez +tibio +tiburón +tiempo +tienda +tierra +tieso +tigre +tijera +tilde +timbre +tímido +timo +tinta +tío +típico +tipo +tira +tirón +titán +títere +título +tiza +toalla +tobillo +tocar +tocino +todo +toga +toldo +tomar +tono +tonto +topar +tope +toque +tórax +torero +tormenta +torneo +toro +torpedo +torre +torso +tortuga +tos +tosco +toser +tóxico +trabajo +tractor +traer +tráfico +trago +traje +tramo +trance +trato +trauma +trazar +trébol +tregua +treinta +tren +trepar +tres +tribu +trigo +tripa +triste +triunfo +trofeo +trompa +tronco +tropa +trote +trozo +truco +trueno +trufa +tubería +tubo +tuerto +tumba +tumor +túnel +túnica +turbina +turismo +turno +tutor +ubicar +úlcera +umbral +unidad +unir +universo +uno +untar +uña +urbano +urbe +urgente +urna +usar +usuario +útil +utopía +uva +vaca +vacío +vacuna +vagar +vago +vaina +vajilla +vale +válido +valle +valor +válvula +vampiro +vara +variar +varón +vaso +vecino +vector +vehículo +veinte +vejez +vela +velero +veloz +vena +vencer +venda +veneno +vengar +venir +venta +venus +ver +verano +verbo +verde +vereda +verja +verso +verter +vía +viaje +vibrar +vicio +víctima +vida +vídeo +vidrio +viejo +viernes +vigor +vil +villa +vinagre +vino +viñedo +violín +viral +virgo +virtud +visor +víspera +vista +vitamina +viudo +vivaz +vivero +vivir +vivo +volcán +volumen +volver +voraz +votar +voto +voz +vuelo +vulgar +yacer +yate +yegua +yema +yerno +yeso +yodo +yoga +yogur +zafiro +zanja +zapato +zarza +zona +zorro +zumo +zurdo diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/.gitkeep b/DevelopPods/MnemonicsView/MnemonicsView/Classes/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsProvider/MnemonicsProvider.h b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsProvider/MnemonicsProvider.h new file mode 100644 index 0000000..e64579c --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsProvider/MnemonicsProvider.h @@ -0,0 +1,16 @@ +// +// MnemonicsProvider.h +// +// Created by Mikhail Nikanorov. +// + +#import +#import "MnemonicsProviderProtocol.h" + +NS_ASSUME_NONNULL_BEGIN + +@interface MnemonicsProvider : NSObject + +@end + +NS_ASSUME_NONNULL_END diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsProvider/MnemonicsProvider.m b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsProvider/MnemonicsProvider.m new file mode 100644 index 0000000..428bb07 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsProvider/MnemonicsProvider.m @@ -0,0 +1,67 @@ +// +// MnemonicsProvider.m +// +// Created by Mikhail Nikanorov. +// + +#import "MnemonicsProvider.h" + +static NSString *const kMnemonicsProviderFileExtension = @"txt"; + +@interface MnemonicsProvider () +@property (nonatomic, strong) NSArray *words; +@end + +@implementation MnemonicsProvider + +#pragma mark - Lifecycle + +- (instancetype)initWithLanguage:(MnemonicsProviderLanguage)language { + self = [super init]; + if (self) { + NSString *filename = NSStringFilenameFromMnemonicsProviderLanguage(language); + if (filename) { + [self _loadWordsWithFilename:filename]; + } + } + return self; +} + +#pragma mark - MnemonicsProviderProtocol + +- (NSArray *) allWords { + return self.words; +} + +- (NSArray *) wordsWithSearchTerm:(NSString *)term { + term = [term stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]]; + if ([term length] > 0) { + NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF BEGINSWITH[cd] %@", term]; + return [self.words filteredArrayUsingPredicate:predicate]; + } else { + return [self allWords]; + } +} + +- (BOOL) validateWords:(NSArray *)words { + NSSet *uniqueWords = [NSSet setWithArray:words]; + NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF IN[cd] %@", uniqueWords]; + NSArray *filtered = [self.words filteredArrayUsingPredicate:predicate]; + return [filtered count] == [uniqueWords count]; +} + +#pragma mark - Private + +- (void) _loadWordsWithFilename:(NSString *)filename { + NSURL *url = [[NSBundle bundleForClass:[self class]] URLForResource:filename withExtension:kMnemonicsProviderFileExtension]; + NSParameterAssert(url); + NSError *error = nil; + NSString *wordsContent = [[NSString alloc] initWithContentsOfURL:url encoding:NSUTF8StringEncoding error:&error]; + if (error) { + [NSException raise:@"Loading error" format:@"Words loading error: %@", [error localizedDescription]]; + return; + } + _words = [wordsContent componentsSeparatedByString:@"\n"]; +} + +@end diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsProvider/MnemonicsProviderLanguage.h b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsProvider/MnemonicsProviderLanguage.h new file mode 100644 index 0000000..0e0d5cc --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsProvider/MnemonicsProviderLanguage.h @@ -0,0 +1,48 @@ +// +// MnemonicsProviderLanguage.h +// +// Created by Mikhail Nikanorov. +// + +#ifndef MnemonicsProviderLanguage_h +#define MnemonicsProviderLanguage_h + +static NSString *const kMnemonicsProviderEnglishFilename = @"english"; +static NSString *const kMnemonicsProviderJapaneseFilename = @"japanese"; +static NSString *const kMnemonicsProviderKoreanFilename = @"korean"; +static NSString *const kMnemonicsProviderSpanishFilename = @"spanish"; +static NSString *const kMnemonicsProviderChineseSimplifiedFilename = @"chinese_simplified"; +static NSString *const kMnemonicsProviderChineseTraditionalFilename = @"chinese_traditional"; +static NSString *const kMnemonicsProviderFrenchFilename = @"french"; +static NSString *const kMnemonicsProviderItalianFilename = @"italian"; + +typedef NS_ENUM(short, MnemonicsProviderLanguage) { + MnemonicsProviderLanguageCustom = -1, + MnemonicsProviderLanguageEnglish = 0, + MnemonicsProviderLanguageJapanese = 1, + MnemonicsProviderLanguageKorean = 2, + MnemonicsProviderLanguageSpanish = 3, + MnemonicsProviderLanguageChineseSimplified = 4, + MnemonicsProviderLanguageChineseTraditional = 5, + MnemonicsProviderLanguageFrench = 6, + MnemonicsProviderLanguageItalian = 7, +}; + +NS_INLINE NSString *NSStringFilenameFromMnemonicsProviderLanguage(MnemonicsProviderLanguage language) { + NSString *filename = nil; + switch (language) { + case MnemonicsProviderLanguageJapanese: { filename = kMnemonicsProviderJapaneseFilename; break; } + case MnemonicsProviderLanguageKorean: { filename = kMnemonicsProviderKoreanFilename; break; } + case MnemonicsProviderLanguageSpanish: { filename = kMnemonicsProviderSpanishFilename; break; } + case MnemonicsProviderLanguageChineseSimplified: { filename = kMnemonicsProviderChineseSimplifiedFilename; break; } + case MnemonicsProviderLanguageChineseTraditional: { filename = kMnemonicsProviderChineseTraditionalFilename; break; } + case MnemonicsProviderLanguageFrench: { filename = kMnemonicsProviderFrenchFilename; break; } + case MnemonicsProviderLanguageItalian: { filename = kMnemonicsProviderItalianFilename; break; } + case MnemonicsProviderLanguageCustom: { filename = nil; break; } + case MnemonicsProviderLanguageEnglish: + default: { filename = kMnemonicsProviderEnglishFilename; break; } + } + return filename; +} + +#endif /* MnemonicsProviderLanguage_h */ diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsProvider/MnemonicsProviderProtocol.h b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsProvider/MnemonicsProviderProtocol.h new file mode 100644 index 0000000..7b532eb --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsProvider/MnemonicsProviderProtocol.h @@ -0,0 +1,20 @@ +// +// MnemonicsProviderProtocol.h +// +// Created by Mikhail Nikanorov. +// + +#import + +#import "MnemonicsProviderLanguage.h" + +NS_ASSUME_NONNULL_BEGIN + +@protocol MnemonicsProviderProtocol +- (instancetype) initWithLanguage:(MnemonicsProviderLanguage)language; +- (NSArray *) allWords; +- (NSArray *) wordsWithSearchTerm:(NSString *)term; +- (BOOL) validateWords:(NSArray *)words; +@end + +NS_ASSUME_NONNULL_END diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryView.h b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryView.h new file mode 100644 index 0000000..362e338 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryView.h @@ -0,0 +1,25 @@ +// +// MnemonicsSuggestionsInputAccessoryView.h +// +// Created by Mikhail Nikanorov. +// + +#import +#import "MnemonicsItemViewUpdateProtocol.h" + +NS_ASSUME_NONNULL_BEGIN + +@class MnemonicsSuggestionsInputAccessoryViewDataSource; +@protocol MnemonicsSuggestionsInputAccessoryViewDelegate; + +@interface MnemonicsSuggestionsInputAccessoryView : UIView +@property (nonatomic, weak, nullable) id delegate; +- (void) setLast:(BOOL)last; +@end + +@protocol MnemonicsSuggestionsInputAccessoryViewDelegate +- (void) mnemonicsSuggestions:(MnemonicsSuggestionsInputAccessoryView *)view didSelectWord:(NSString *)word; +- (void) mnemonicsSuggestionsDidCompletion:(MnemonicsSuggestionsInputAccessoryView *)view; +@end + +NS_ASSUME_NONNULL_END diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryView.m b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryView.m new file mode 100644 index 0000000..9085815 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryView.m @@ -0,0 +1,100 @@ +// +// MnemonicsSuggestionsInputAccessoryView.m +// +// Created by Mikhail Nikanorov. +// + +#import "MnemonicsSuggestionsInputAccessoryView.h" +#import "MnemonicsSuggestionsInputAccessoryViewDataSource.h" + +static CGFloat const kMnemonicsSuggestionsInputDefaultHeight = 42.0; + +@interface MnemonicsSuggestionsInputAccessoryView () +@property (nonatomic, strong) MnemonicsSuggestionsInputAccessoryViewDataSource *dataSource; +@property (nonatomic, weak) UICollectionView *collectionView; +@end + +@implementation MnemonicsSuggestionsInputAccessoryView +@dynamic words; + +- (instancetype)initWithFrame:(CGRect)frame { + self = [super initWithFrame:frame]; + if (self) { + [self _commonInit]; + } + return self; +} + +- (void)setLast:(BOOL)last { + self.dataSource.last = last; +} + +#pragma mark - Private + +- (void) _commonInit { + self.translatesAutoresizingMaskIntoConstraints = NO; + self.backgroundColor = [UIColor colorWithRed:229.0/255.0 green:237.0/255.0 blue:251.0/255.0 alpha:1.0]; + [self invalidateIntrinsicContentSize]; + [self layoutIfNeeded]; + + UICollectionViewFlowLayout *flowLayout = [[UICollectionViewFlowLayout alloc] init]; + flowLayout.scrollDirection = UICollectionViewScrollDirectionHorizontal; + + UICollectionView *collectionView = [[UICollectionView alloc] initWithFrame:self.bounds collectionViewLayout:flowLayout]; + collectionView.backgroundColor = [UIColor whiteColor]; + collectionView.translatesAutoresizingMaskIntoConstraints = NO; + [self addSubview:collectionView]; + + [NSLayoutConstraint activateConstraints: + @[[self.leftAnchor constraintEqualToAnchor:collectionView.leftAnchor], + [self.topAnchor constraintEqualToAnchor:collectionView.topAnchor], + [self.rightAnchor constraintEqualToAnchor:collectionView.rightAnchor], + [collectionView.heightAnchor constraintEqualToConstant:kMnemonicsSuggestionsInputDefaultHeight]] + ]; + + self.dataSource = [[MnemonicsSuggestionsInputAccessoryViewDataSource alloc] initWithCollectionView:collectionView]; + self.dataSource.delegate = self; +} + +#pragma mark - MnemonicsItemViewUpdateProtocol + +- (BOOL)isCompleted { + return self.dataSource.isCompleted; +} + +- (void)updateWithWords:(NSArray *)words { + [self.dataSource updateWithWords:words]; +} + +- (void)makeCompleted { + [self.dataSource makeCompleted]; +} + +#pragma mark - MnemonicsSuggestionsInputAccessoryViewDataSourceDelegate + +- (void)mnemonicsSuggestionsInputAccessoryViewDataSource:(MnemonicsSuggestionsInputAccessoryViewDataSource *)dataSource didSelectItemAtIndex:(NSUInteger)idx { + if ([self isCompleted]) { + [self.delegate mnemonicsSuggestionsDidCompletion:self]; + } else { + NSString *word = dataSource.words[idx]; + [self.delegate mnemonicsSuggestions:self didSelectWord:word]; + } +} + +#pragma mark - Override + +- (CGSize)intrinsicContentSize { + CGSize size = CGSizeMake(UIViewNoIntrinsicMetric, kMnemonicsSuggestionsInputDefaultHeight); + if (@available(iOS 11.0, *)) { + size.height += self.safeAreaInsets.bottom; + } + return size; +} + +- (void)safeAreaInsetsDidChange { + [self invalidateIntrinsicContentSize]; + [super safeAreaInsetsDidChange]; +} + + +@end diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewCollectionViewCell.h b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewCollectionViewCell.h new file mode 100644 index 0000000..41a34ba --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewCollectionViewCell.h @@ -0,0 +1,17 @@ +// +// MnemonicsSuggestionsInputAccessoryViewCollectionViewCell.h +// +// Created by Mikhail Nikanorov. +// + +#import +#import "MnemonicsSuggestionsInputAccessoryViewCollectionViewCellUpdateProtocol.h" + +NS_ASSUME_NONNULL_BEGIN + +@interface MnemonicsSuggestionsInputAccessoryViewCollectionViewCell : UICollectionViewCell ++ (UIColor *) textColor; ++ (UIFont *) font; +@end + +NS_ASSUME_NONNULL_END diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewCollectionViewCell.m b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewCollectionViewCell.m new file mode 100644 index 0000000..3f55d98 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewCollectionViewCell.m @@ -0,0 +1,49 @@ +// +// MnemonicsSuggestionsInputAccessoryViewCollectionViewCell.m +// +// Created by Mikhail Nikanorov. +// + +#import "MnemonicsSuggestionsInputAccessoryViewCollectionViewCell.h" + +@interface MnemonicsSuggestionsInputAccessoryViewCollectionViewCell () +@property (nonatomic, weak) UILabel *titleLabel; +@end + +@implementation MnemonicsSuggestionsInputAccessoryViewCollectionViewCell + +- (instancetype)initWithFrame:(CGRect)frame { + self = [super initWithFrame:frame]; + if (self) { + UILabel *titleLabel = [[UILabel alloc] initWithFrame:self.contentView.bounds]; + titleLabel.textColor = [[self class] textColor]; + titleLabel.font = [[self class] font]; + titleLabel.translatesAutoresizingMaskIntoConstraints = NO; + titleLabel.textAlignment = NSTextAlignmentCenter; + [self.contentView addSubview:titleLabel]; + [NSLayoutConstraint activateConstraints: + @[[self.contentView.leadingAnchor constraintEqualToAnchor:titleLabel.leadingAnchor], + [self.contentView.topAnchor constraintEqualToAnchor:titleLabel.topAnchor], + [self.contentView.trailingAnchor constraintEqualToAnchor:titleLabel.trailingAnchor], + [self.contentView.bottomAnchor constraintEqualToAnchor:titleLabel.bottomAnchor] + ]]; + self.titleLabel = titleLabel; + } + return self; +} + +#pragma mark - MnemonicsSuggestionsInputAccessoryViewCollectionViewCellUpdateProtocol + +- (void)updateWithWord:(NSString *)word { + self.titleLabel.text = word; +} + ++ (UIColor *) textColor { + return [UIColor colorWithRed:6.0/255 green:77/255.0 blue:214/255.0 alpha:1.0]; +} + ++ (UIFont *) font { + return [UIFont systemFontOfSize:17.0]; +} + +@end diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewCollectionViewDoneCell.h b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewCollectionViewDoneCell.h new file mode 100644 index 0000000..514e179 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewCollectionViewDoneCell.h @@ -0,0 +1,16 @@ +// +// MnemonicsSuggestionsInputAccessoryViewCollectionViewDoneCell.h +// Pods +// +// Created by Mikhail Nikanorov on 2/5/19. +// + +#import "MnemonicsSuggestionsInputAccessoryViewCollectionViewCell.h" + +NS_ASSUME_NONNULL_BEGIN + +@interface MnemonicsSuggestionsInputAccessoryViewCollectionViewDoneCell : MnemonicsSuggestionsInputAccessoryViewCollectionViewCell + +@end + +NS_ASSUME_NONNULL_END diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewCollectionViewDoneCell.m b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewCollectionViewDoneCell.m new file mode 100644 index 0000000..698c475 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewCollectionViewDoneCell.m @@ -0,0 +1,20 @@ +// +// MnemonicsSuggestionsInputAccessoryViewCollectionViewDoneCell.m +// Pods +// +// Created by Mikhail Nikanorov on 2/5/19. +// + +#import "MnemonicsSuggestionsInputAccessoryViewCollectionViewDoneCell.h" + +@implementation MnemonicsSuggestionsInputAccessoryViewCollectionViewDoneCell + ++ (UIColor *) textColor { + return [UIColor whiteColor]; +} + ++ (UIFont *) font { + return [UIFont systemFontOfSize:15.0 weight:UIFontWeightSemibold]; +} + +@end diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewDataSource.h b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewDataSource.h new file mode 100644 index 0000000..d9e7e02 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewDataSource.h @@ -0,0 +1,30 @@ +// +// MnemonicsSuggestionsInputAccessoryViewDataSource.h +// +// Created by Mikhail Nikanorov. +// + +#import + +#import "MnemonicsItemViewUpdateProtocol.h" + +@class UICollectionView; +@class UICollectionViewCell; + +NS_ASSUME_NONNULL_BEGIN + +@protocol MnemonicsSuggestionsInputAccessoryViewDataSourceDelegate; + +@interface MnemonicsSuggestionsInputAccessoryViewDataSource : NSObject +@property (nonatomic) BOOL last; +@property (nonatomic, weak) id delegate; +- (instancetype) initWithCollectionView:(UICollectionView *)collectionView; +- (Class) cellClass; +- (Class) doneCellClass; +@end + +@protocol MnemonicsSuggestionsInputAccessoryViewDataSourceDelegate +- (void) mnemonicsSuggestionsInputAccessoryViewDataSource:(MnemonicsSuggestionsInputAccessoryViewDataSource *)dataSource didSelectItemAtIndex:(NSUInteger)idx; +@end + +NS_ASSUME_NONNULL_END diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewDataSource.m b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewDataSource.m new file mode 100644 index 0000000..bd4a305 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/AccessoryView/MnemonicsSuggestionsInputAccessoryViewDataSource.m @@ -0,0 +1,135 @@ +// +// MnemonicsSuggestionsInputAccessoryViewDataSource.m +// +// Created by Mikhail Nikanorov. +// + +#import + +#import "MnemonicsSuggestionsInputAccessoryViewDataSource.h" +#import "MnemonicsSuggestionsInputAccessoryViewCollectionViewCell.h" +#import "MnemonicsSuggestionsInputAccessoryViewCollectionViewDoneCell.h" + +@interface MnemonicsSuggestionsInputAccessoryViewDataSource () +@property (nonatomic, weak) UICollectionView *collectionView; +@end + +@implementation MnemonicsSuggestionsInputAccessoryViewDataSource +@synthesize completed = _completed; +@synthesize words = _words; + +- (instancetype)initWithCollectionView:(UICollectionView *)collectionView { + self = [super init]; + if (self) { + self.collectionView = collectionView; + self.collectionView.dataSource = self; + self.collectionView.delegate = self; + + Class cellClass = [self cellClass]; + Class doneCellClass = [self doneCellClass]; + [self.collectionView registerClass:cellClass forCellWithReuseIdentifier:NSStringFromClass(cellClass)]; + [self.collectionView registerClass:doneCellClass forCellWithReuseIdentifier:NSStringFromClass(doneCellClass)]; + } + return self; +} + +#pragma mark - UICollectionViewDataSource + +- (nonnull __kindof UICollectionViewCell *)collectionView:(nonnull UICollectionView *)collectionView cellForItemAtIndexPath:(nonnull NSIndexPath *)indexPath { + NSString *identifier = _completed ? NSStringFromClass([self doneCellClass]) : NSStringFromClass([self cellClass]); + __kindof MnemonicsSuggestionsInputAccessoryViewCollectionViewCell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:identifier forIndexPath:indexPath]; + if (!_completed) { + NSString *word = nil; + if (indexPath.row < [_words count]) { + word = _words[indexPath.row]; + [cell updateWithWord:word]; + } + } else { + if (self.last) { + [cell updateWithWord:NSLocalizedString(@"DONE", nil)]; + } else { + [cell updateWithWord:NSLocalizedString(@"NEXT WORD", nil)]; + } + } + return cell; +} + +- (NSInteger)numberOfSectionsInCollectionView:(UICollectionView *)collectionView { + return 1; +} + +- (NSInteger)collectionView:(nonnull UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section { + return _completed ? 1 : MIN([_words count], 3); +} + +- (CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout *)collectionViewLayout sizeForItemAtIndexPath:(NSIndexPath *)indexPath { + CGFloat availableWidth = CGRectGetWidth(collectionView.frame); + if (@available(iOS 11.0, *)) { + availableWidth = availableWidth - (collectionView.adjustedContentInset.left + collectionView.adjustedContentInset.right); + } + UIEdgeInsets sectionInsets = [self collectionView:collectionView layout:collectionViewLayout insetForSectionAtIndex:indexPath.section]; + availableWidth -= sectionInsets.left + sectionInsets.right; + + if (self.completed) { + return CGSizeMake(availableWidth, CGRectGetHeight(collectionView.frame)); + } else { + CGFloat lineSpacing = [self collectionView:collectionView layout:collectionViewLayout minimumLineSpacingForSectionAtIndex:indexPath.section]; + NSUInteger numberOfSpacings = MAX(MIN([_words count], 3) - 1, 0); + CGFloat totalWidth = availableWidth - (numberOfSpacings * lineSpacing); + CGFloat width = totalWidth / MIN([_words count], 3); + return CGSizeMake(width, CGRectGetHeight(collectionView.frame)); + } +} + +- (CGFloat)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout *)collectionViewLayout minimumLineSpacingForSectionAtIndex:(NSInteger)section { + return 1.0; +} + +- (CGFloat)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout *)collectionViewLayout minimumInteritemSpacingForSectionAtIndex:(NSInteger)section { + return 0.0; +} + +- (UIEdgeInsets)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout *)collectionViewLayout insetForSectionAtIndex:(NSInteger)section { + UIEdgeInsets insets = UIEdgeInsetsZero; + if (@available(iOS 11.0, *)) { + insets.left = collectionView.safeAreaInsets.left; + insets.right = collectionView.safeAreaInsets.right; + } + return insets; +} + +#pragma mark - UICollectionViewDelegate + +- (void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath { + [collectionView deselectItemAtIndexPath:indexPath animated:YES]; + [self.delegate mnemonicsSuggestionsInputAccessoryViewDataSource:self didSelectItemAtIndex:indexPath.row]; +} + +#pragma mark - Override + +- (CGSize)intrinsicContentSize { + return CGSizeMake(UIViewNoIntrinsicMetric, 42.0); +} + +#pragma mark - Public + +- (Class)cellClass { + return [MnemonicsSuggestionsInputAccessoryViewCollectionViewCell class]; +} + +- (Class) doneCellClass { + return [MnemonicsSuggestionsInputAccessoryViewCollectionViewDoneCell class]; +} + +- (void) updateWithWords:(NSArray *)words { + _completed = NO; + _words = words; + [self.collectionView reloadData]; +} + +- (void) makeCompleted { + _completed = YES; + [self.collectionView reloadData]; +} + +@end diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/ItemView/MnemonicsItemView.h b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/ItemView/MnemonicsItemView.h new file mode 100644 index 0000000..e14a6f3 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/ItemView/MnemonicsItemView.h @@ -0,0 +1,34 @@ +// +// MnemonicsItemView.h +// +// Created by Mikhail Nikanorov. +// + +#import + +NS_ASSUME_NONNULL_BEGIN + +@protocol MnemonicsProviderProtocol; +@protocol MnemonicsItemViewDelegate; + +@interface MnemonicsItemView : UIView +@property (nonatomic, weak) id delegate; +@property (nonatomic, weak, readonly) UITextField *textField; +@property (nonatomic, weak, readonly) UILabel *label; +@property (nonatomic, weak, readonly) UIView *placeholder; +@property (nonatomic, strong, readonly) id mnemonicsProvider; +//@property (nonatomic, strong) SuggestionView *suggestionC; +@property (nonatomic, readonly) NSInteger index; +@property (nonatomic) BOOL last; ++ (instancetype) itemWithIndex:(NSInteger)index mnemonicsProvider:(id )mnemonicsProvider; +- (void) updateText:(NSString *)text; +@end + +@protocol MnemonicsItemViewDelegate +- (void) mnemonicsItemViewDidEndEditing:(MnemonicsItemView *)view; //end +- (void) mnemonicsItemViewDidEndErasing:(MnemonicsItemView *)view; //askprevious +- (void) mnemonicsItemView:(MnemonicsItemView *)view didPasteWords:(NSArray *)words; +- (void) mnemonicsItemViewDidChangeState:(MnemonicsItemView * __nullable)view; +@end + +NS_ASSUME_NONNULL_END diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/ItemView/MnemonicsItemView.m b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/ItemView/MnemonicsItemView.m new file mode 100644 index 0000000..d672fa7 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/ItemView/MnemonicsItemView.m @@ -0,0 +1,366 @@ +// +// MnemonicsItemView.m +// +// Created by Mikhail Nikanorov. +// + +#import "MnemonicsItemView.h" +#import "MnemonicsTextField.h" +#import "MnemonicsProviderProtocol.h" +#import "MnemonicsSuggestionsInputAccessoryView.h" +#import "MnemonicsSuggestionsInputAccessoryViewDataSource.h" + +static CGFloat const kMnemonicsItemViewPlaceholderHeight = 16.0; + +@interface MnemonicsItemView () +@property (nonatomic, strong) NSString *previousTerm; +@property (nonatomic, weak) MnemonicsTextField *textField; +@property (nonatomic, weak) UILabel *label; +@property (nonatomic, weak) UIView *placeholder; +@end + +@implementation MnemonicsItemView + +#pragma mark - Lifecycle + +- (instancetype) initWithIndex:(NSInteger)index mnemonicsProvider:(id)mnemonicsProvider { + self = [super init]; + if (self) { + _index = index; + _mnemonicsProvider = mnemonicsProvider; + + UILabel *label = [[UILabel alloc] init]; + label.textAlignment = NSTextAlignmentCenter; + label.translatesAutoresizingMaskIntoConstraints = NO; + [label setContentHuggingPriority:UILayoutPriorityDefaultHigh forAxis:UILayoutConstraintAxisHorizontal]; + [label setContentCompressionResistancePriority:UILayoutPriorityRequired forAxis:UILayoutConstraintAxisHorizontal]; + [self addSubview:label]; + + label.text = [NSString stringWithFormat:@"%zd", index + 1]; + + self.label = label; + + CGSize maxLabelSize = [@"00" boundingRectWithSize:CGSizeMake(1000.0, 1000.0) + options:NSStringDrawingUsesLineFragmentOrigin + attributes:@{NSFontAttributeName: [[self class] selectedFont]} + context:nil].size; + + UIView *placeholder = [[UIView alloc] init]; + placeholder.translatesAutoresizingMaskIntoConstraints = NO; + placeholder.backgroundColor = [UIColor colorWithRed:242.0/255.0 green:244.0/255.0 blue:247.0/255.0 alpha:1.0]; + placeholder.layer.cornerRadius = 3.0; + + self.placeholder = placeholder; + + [self addSubview:placeholder]; + + MnemonicsTextField *textField = [[MnemonicsTextField alloc] init]; + [textField addTarget:self action:@selector(textFieldDidChanged:) forControlEvents:UIControlEventEditingChanged]; + textField.markedTextStyle = @{NSBackgroundColorAttributeName: [UIColor colorWithRed:229.0/255.0 green:237.0/255.0 blue:251.0/255.0 alpha:1.0]}; + textField.delegate = self; + textField.translatesAutoresizingMaskIntoConstraints = NO; + [self addSubview:textField]; + + textField.hidden = YES; + textField.suggestionsInputAccessoryView.delegate = self; + + self.textField = textField; + self.textField.inputAccessoryView = nil; + [self.textField.inputAccessoryView reloadInputViews]; + + UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapAction:)]; + [self addGestureRecognizer:tap]; + + [NSLayoutConstraint activateConstraints: + @[ + [self.leadingAnchor constraintEqualToAnchor:label.leadingAnchor], + [placeholder.heightAnchor constraintEqualToConstant:kMnemonicsItemViewPlaceholderHeight], + [placeholder.centerYAnchor constraintEqualToAnchor:self.centerYAnchor], + [placeholder.leadingAnchor constraintEqualToAnchor:label.trailingAnchor constant:8.0], + [self.trailingAnchor constraintEqualToAnchor:placeholder.trailingAnchor constant:arc4random_uniform(29) + 11.0], + [textField.topAnchor constraintEqualToAnchor:self.topAnchor], + [textField.bottomAnchor constraintEqualToAnchor:self.bottomAnchor], + [textField.leadingAnchor constraintEqualToAnchor:label.trailingAnchor constant:5.0], + [self.trailingAnchor constraintEqualToAnchor:textField.trailingAnchor constant:11.0], + [label.widthAnchor constraintEqualToConstant:maxLabelSize.width], + [label.centerYAnchor constraintEqualToAnchor:textField.centerYAnchor constant:1.0], + ]]; + } + return self; +} + ++ (instancetype) itemWithIndex:(NSInteger)index mnemonicsProvider:(id)mnemonicsProvider { + return [[[self class] alloc] initWithIndex:index mnemonicsProvider:mnemonicsProvider]; +} + +- (void)updateText:(NSString *)text { + [self.textField setText:text]; + self.textField.hidden = NO; + self.placeholder.hidden = YES; + [self _textFieldDidChanged:self.textField reloadInputs:NO]; +} + +#pragma mark - Override + +- (CGSize) intrinsicContentSize { + return CGSizeMake(UIViewNoIntrinsicMetric, 40.0); +} + +- (BOOL)becomeFirstResponder { + [self.textField becomeFirstResponder]; + return NO; +} + +#pragma mark - Actions + +- (void) tapAction:(UITapGestureRecognizer *)tap { + [self.textField becomeFirstResponder]; +} + +#pragma mark - UITextFieldDelegate + +- (void) textFieldDidBeginEditing:(UITextField *)textField { + self.placeholder.hidden = YES; + [self _updateTitle]; + if (textField.markedTextRange != nil) { + UITextRange *textRange = [textField textRangeFromPosition:textField.markedTextRange.start toPosition:textField.markedTextRange.start]; + [textField setSelectedTextRange:textRange]; + } +} + +- (void) textFieldDidEndEditing:(UITextField *)textField { + self.placeholder.hidden = (textField.text.length != 0); + [self _updateTitle]; +} + +- (BOOL) textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string { + self.previousTerm = nil; + NSMutableCharacterSet *separators = [[NSCharacterSet whitespaceAndNewlineCharacterSet] mutableCopy]; + [separators addCharactersInString:@".,\n"]; + NSArray *components = [string componentsSeparatedByCharactersInSet:separators]; + components = [components filteredArrayUsingPredicate:[NSPredicate predicateWithFormat:@"SELF.length > 0"]]; + if ([components count] > 1) { + string = [components firstObject]; + if (textField.markedTextRange != nil) { + if (@available(iOS 12.0, *)) { + [textField setMarkedText:nil selectedRange:NSMakeRange(0, 0)]; + } else { + [textField setMarkedText:@"" selectedRange:NSMakeRange(0, 0)]; + } + [textField unmarkText]; + } + textField.text = string; + [self _textFieldDidChanged:(MnemonicsTextField *)textField reloadInputs:NO]; + + NSArray *leftComponents = [components subarrayWithRange:NSMakeRange(1, [components count] - 1)]; + [self.delegate mnemonicsItemView:self didPasteWords:leftComponents]; + return NO; + } else if (textField.markedTextRange != nil) { + if (@available(iOS 12.0, *)) { + [textField setMarkedText:nil selectedRange:NSMakeRange(0, 0)]; + } else { + [textField setMarkedText:@"" selectedRange:NSMakeRange(0, 0)]; + } + [textField unmarkText]; + NSString *oldText = textField.text; + if (range.location > [oldText length]) { + range.location = [oldText length]; + } + if (NSMaxRange(range) > [oldText length]) { + range.length = [oldText length] - range.location; + } + NSString *newString = [oldText stringByReplacingCharactersInRange:range withString:string]; + textField.text = newString; + UITextPosition *position = [textField positionFromPosition:textField.beginningOfDocument offset:range.location + [string length]]; + UITextRange *textRange = [textField textRangeFromPosition:position toPosition:position]; + [textField setSelectedTextRange:textRange]; + return NO; + } + return YES; +} + +- (BOOL)textFieldShouldReturn:(MnemonicsTextField *)textField { + if ([textField.inputAccessoryView isCompleted]) { + [self.delegate mnemonicsItemViewDidEndEditing:self]; + } else { + [textField unmarkText]; + if ([textField isCorrect]) { + [self.delegate mnemonicsItemViewDidEndEditing:self]; + } + } + return NO; +} + +- (void) textFieldDidChanged:(MnemonicsTextField *)textField { + [self _textFieldDidChanged:textField reloadInputs:YES]; +} + +- (void)textFieldDidTryDeleteEmptyText:(UITextField *)textField { + [self.delegate mnemonicsItemViewDidEndErasing:self]; +} + +- (void)textField:(UITextField *)textField didCreateNewInputAccessoryView:(MnemonicsSuggestionsInputAccessoryView *)inputAccessoryView { + inputAccessoryView.delegate = self; + [inputAccessoryView setLast:self.last]; +} + +- (void)textFieldDidFireTabCommand:(UITextField *)textField { + [self.delegate mnemonicsItemViewDidEndEditing:self]; +} + +#pragma mark - MnemonicsSuggestionsInputAccessoryViewDelegate + +- (void) mnemonicsSuggestions:(nonnull MnemonicsSuggestionsInputAccessoryView *)view didSelectWord:(nonnull NSString *)word { + [self.textField setText:word]; + [self.textField unmarkText]; + UITextRange *range = [self.textField textRangeFromPosition:self.textField.endOfDocument toPosition:self.textField.endOfDocument]; + [self.textField setSelectedTextRange:range]; + self.textField.returnKeyType = UIReturnKeyNext; + [view makeCompleted]; + [self.textField reloadInputViews]; + [self.delegate mnemonicsItemViewDidChangeState:self]; + [self.delegate mnemonicsItemViewDidEndEditing:self]; +} + +- (void) mnemonicsSuggestionsDidCompletion:(nonnull MnemonicsSuggestionsInputAccessoryView *)view { + if ([view isCompleted]) { + if (self.textField.markedTextRange != nil) { + [self.textField unmarkText]; + } + [self.delegate mnemonicsItemViewDidEndEditing:self]; + } else { + [self.textField unmarkText]; + } +} + +#pragma mark - Private + +- (void) _textFieldDidChanged:(__kindof MnemonicsTextField *)textField reloadInputs:(BOOL)reloadInputs { + dispatch_async(dispatch_get_main_queue(), ^{ + //jap - todo + if ([textField.text length] == 0) { + [self _textFieldDidChangedCompletion:textField empty:YES correct:YES completed:NO reloadInputs:reloadInputs]; + return; + } + + NSString *term = nil; + if (textField.markedTextRange) { + UITextRange *range = [textField textRangeFromPosition:textField.beginningOfDocument + toPosition:textField.markedTextRange.start]; + term = [textField textInRange:range]; + } else { + term = textField.text; + } + //To stop infinite loop, because of setMarkedText: + if ([self.previousTerm isEqualToString:term]) { + return; + } + self.previousTerm = term; + term = [term stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]]; + + if ([term length] == 0) { + [self _textFieldDidChangedCompletion:textField empty:YES correct:YES completed:NO reloadInputs:reloadInputs]; + return; + } + + NSArray *words = [self.mnemonicsProvider wordsWithSearchTerm:term]; + if ([words count] == 0) { + [self _textFieldDidChangedCompletion:textField empty:NO correct:NO completed:NO reloadInputs:reloadInputs]; + return; + } + + NSString *fullSuggestion = [words firstObject]; + if (fullSuggestion && (![term isEqualToString:fullSuggestion] || [words count] > 1)) { + textField.showInputAccessoryView = YES; + [textField.inputAccessoryView updateWithWords:words]; + NSString *suggestion = [fullSuggestion substringFromIndex:[term length]]; + + if (![[[self.textField.text stringByAppendingString:suggestion] lowercaseString] containsString:fullSuggestion]) { + [self _textFieldDidChangedCompletion:textField empty:NO correct:NO completed:NO reloadInputs:reloadInputs]; + } else { + UITextRange *oldTextRange = textField.selectedTextRange; + UITextPosition *position = textField.endOfDocument; + UITextRange *textRange = [textField textRangeFromPosition:position toPosition:position]; + [textField setSelectedTextRange:textRange]; + [textField setMarkedText:suggestion selectedRange:NSMakeRange(0, 0)]; + [textField setSelectedTextRange:oldTextRange]; + + [self _textFieldDidChangedCompletion:textField empty:NO correct:YES completed:([words count] == 1) reloadInputs:reloadInputs]; + } + } else if (textField.markedTextRange != nil) { + textField.inputAccessoryView = textField.inputAccessoryView; + [textField.inputAccessoryView updateWithWords:words]; + [self _textFieldDidChangedCompletion:textField empty:NO correct:YES completed:NO reloadInputs:reloadInputs]; + } else if ([words count] == 1) { + + [self _textFieldDidChangedCompletion:textField empty:NO correct:YES completed:YES reloadInputs:reloadInputs]; + } + }); +} + +- (void) _textFieldDidChangedCompletion:(__kindof MnemonicsTextField *)textField empty:(BOOL)empty correct:(BOOL)correct completed:(BOOL)completed reloadInputs:(BOOL)reloadInputs { + if (empty) { + textField.showInputAccessoryView = NO; + [textField markAsCorrect]; + self.textField.returnKeyType = UIReturnKeyDone; + } + if (correct) { + [textField markAsCorrect]; + if (!empty) { + textField.showInputAccessoryView = YES; + } + } else { + textField.showInputAccessoryView = NO; + [textField markAsIncorrect]; + self.textField.returnKeyType = UIReturnKeyDone; + } + if (completed) { + textField.showInputAccessoryView = NO; + [textField.inputAccessoryView makeCompleted]; + if (!self.last) { + self.textField.returnKeyType = UIReturnKeyNext; + } else { + self.textField.returnKeyType = UIReturnKeyDone; + } + } else { + self.textField.returnKeyType = UIReturnKeyDone; + } + if (reloadInputs) { + [self.textField reloadInputViews]; + } + [self _updateTitle]; + [self.delegate mnemonicsItemViewDidChangeState:self]; +} + +- (void) _updateTitle { + UIColor *color = nil; + UIFont *font = nil; + BOOL isCorrect = [(MnemonicsTextField *)self.textField isCorrect]; + if ([self.textField isFirstResponder]) { + font = [[self class] selectedFont]; + if (isCorrect) { + color = [UIColor colorWithRed:6.0/255.0 green:77.0/255.0 blue:214.0/255.0 alpha:1.0]; + } else { + color = [UIColor colorWithRed:214.0/255.0 green:6.0/255.0 blue:6.0/255.0 alpha:1.0]; + } + } else { + font = [[self class] normalFont]; + if (isCorrect) { + color = [UIColor blackColor]; + } else { + color = [UIColor colorWithRed:214.0/255.0 green:6.0/255.0 blue:6.0/255.0 alpha:1.0]; + } + } + self.label.textColor = color; + self.label.font = font; +} + ++ (UIFont *) selectedFont { + return [UIFont systemFontOfSize:15.0 weight:UIFontWeightMedium]; +} + ++ (UIFont *) normalFont { + return [UILabel appearanceWhenContainedInInstancesOfClasses:@[[MnemonicsItemView class]]].font; +} + +@end diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/Protocols/MnemonicsItemViewUpdateProtocol.h b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/Protocols/MnemonicsItemViewUpdateProtocol.h new file mode 100644 index 0000000..2d8a809 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/Protocols/MnemonicsItemViewUpdateProtocol.h @@ -0,0 +1,18 @@ +// +// MnemonicsItemViewUpdateProtocol.h +// +// Created by Mikhail Nikanorov. +// + +#import + +NS_ASSUME_NONNULL_BEGIN + +@protocol MnemonicsItemViewUpdateProtocol +@property (nonatomic, readonly, getter=isCompleted) BOOL completed; +@property (nonatomic, strong, readonly) NSArray *words; +- (void) updateWithWords:(NSArray *)words; +- (void) makeCompleted; +@end + +NS_ASSUME_NONNULL_END diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/Protocols/MnemonicsSuggestionsInputAccessoryViewCollectionViewCellUpdateProtocol.h b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/Protocols/MnemonicsSuggestionsInputAccessoryViewCollectionViewCellUpdateProtocol.h new file mode 100644 index 0000000..9aa0864 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/Protocols/MnemonicsSuggestionsInputAccessoryViewCollectionViewCellUpdateProtocol.h @@ -0,0 +1,15 @@ +// +// MnemonicsSuggestionsInputAccessoryViewCollectionViewCellUpdateProtocol.h +// +// Created by Mikhail Nikanorov. +// + +#import + +NS_ASSUME_NONNULL_BEGIN + +@protocol MnemonicsSuggestionsInputAccessoryViewCollectionViewCellUpdateProtocol +- (void) updateWithWord:(NSString * __nullable)word; +@end + +NS_ASSUME_NONNULL_END diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/TextField/MnemonicsTextField.h b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/TextField/MnemonicsTextField.h new file mode 100644 index 0000000..f9336d5 --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/TextField/MnemonicsTextField.h @@ -0,0 +1,28 @@ +// +// MnemonicsTextField.h +// +// Created by Mikhail Nikanorov. +// + +#import +#import "MnemonicsSuggestionsInputAccessoryView.h" + +NS_ASSUME_NONNULL_BEGIN + +@protocol MnemonicsTextFieldDelegate +- (void) textFieldDidTryDeleteEmptyText:(UITextField *)textField; +- (void) textField:(UITextField *)textField didCreateNewInputAccessoryView:(MnemonicsSuggestionsInputAccessoryView *)accessoryView; +- (void) textFieldDidFireTabCommand:(UITextField *)textField; +@end + +@interface MnemonicsTextField : UITextField +@property (nullable, nonatomic, weak) id delegate; +@property (nullable, readwrite, strong) __kindof MnemonicsSuggestionsInputAccessoryView *inputAccessoryView; +@property (nonatomic, strong, readonly) MnemonicsSuggestionsInputAccessoryView *suggestionsInputAccessoryView; +@property (nonatomic, readonly, getter=isCorrect) BOOL correct; +@property (nonatomic) BOOL showInputAccessoryView; +- (void) markAsCorrect; +- (void) markAsIncorrect; +@end + +NS_ASSUME_NONNULL_END diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/TextField/MnemonicsTextField.m b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/TextField/MnemonicsTextField.m new file mode 100644 index 0000000..cf6c71a --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/Components/TextField/MnemonicsTextField.m @@ -0,0 +1,156 @@ +// +// MnemonicsTextField.m +// +// Created by Mikhail Nikanorov. +// + +#import "MnemonicsTextField.h" + +#import "MnemonicsSuggestionsInputAccessoryView.h" + +@interface MnemonicsTextField () +@property (nonatomic, strong) MnemonicsSuggestionsInputAccessoryView *suggestionsInputAccessoryView; +@end + +@implementation MnemonicsTextField +@dynamic delegate; +@dynamic inputAccessoryView; + +- (instancetype)init { + self = [super init]; + if (self) { + _showInputAccessoryView = NO; + _correct = YES; + [self _createInputAccessoryView]; + self.autocorrectionType = UITextAutocorrectionTypeNo; + self.spellCheckingType = UITextSpellCheckingTypeNo; + self.autocapitalizationType = UITextAutocapitalizationTypeNone; + self.returnKeyType = UIReturnKeyDone; + } + return self; +} + +- (CGRect) textRectForBounds:(CGRect)bounds { + CGRect rect = [super textRectForBounds:bounds]; + rect = CGRectInset(rect, 7.0, 2.0); + return rect; +} + +- (CGRect) placeholderRectForBounds:(CGRect)bounds { + CGRect rect = [super placeholderRectForBounds:bounds]; + rect = CGRectInset(rect, 7.0, 2.0); + return rect; +} + +- (CGRect) editingRectForBounds:(CGRect)bounds { + CGRect rect = [super editingRectForBounds:bounds]; + rect = CGRectInset(rect, 7.0, 2.0); + return rect; +} + +- (BOOL) becomeFirstResponder { + if (_correct || [self.text length] == 0) { + self.textColor = [UIColor colorWithRed:6.0/255.0 green:77.0/255.0 blue:214.0/255.0 alpha:1.0]; + self.layer.borderColor = [UIColor colorWithRed:4.0/255.0 green:76.0/255.0 blue:221.0/255.0 alpha:1.0].CGColor; + self.layer.backgroundColor = [UIColor whiteColor].CGColor; + self.layer.borderWidth = 2.0; + self.layer.cornerRadius = 8.0; + } else { + self.layer.borderColor = [UIColor clearColor].CGColor; + self.layer.backgroundColor = [UIColor colorWithRed:250.0/255.0 green:230.0/255.0 blue:230.0/255.0 alpha:0.8].CGColor; + } + self.hidden = NO; + return [super becomeFirstResponder]; +} + +- (BOOL) resignFirstResponder { + if ([self.text length] == 0) { + self.hidden = YES; + } + if (_correct) { + self.textColor = [UIColor blackColor]; + } + self.layer.backgroundColor = [UIColor whiteColor].CGColor; + self.layer.borderColor = [UIColor clearColor].CGColor; + + return [super resignFirstResponder]; +} + +- (void) deleteBackward { + if ([self.text length] == 0) { + [self.delegate textFieldDidTryDeleteEmptyText:self]; + } else { + if (@available(iOS 12.0, *)) { + [self setMarkedText:nil selectedRange:NSMakeRange(0, 0)]; + } else { + [self setMarkedText:@"" selectedRange:NSMakeRange(0, 0)]; + } + [self unmarkText]; + [super deleteBackward]; + } +} + +- (void) tabCommand:(UIKeyCommand *)sender { + [self.delegate textFieldDidFireTabCommand:self]; +} + +#pragma mark - Public + +- (void) markAsCorrect { + if (!_correct) { + _correct = YES; + self.layer.backgroundColor = [UIColor whiteColor].CGColor; + if (![self isFirstResponder]) { + self.textColor = [UIColor blackColor]; + self.layer.borderColor = [UIColor clearColor].CGColor; + self.layer.borderWidth = 2.0; + self.layer.cornerRadius = 8.0; + } else { + self.textColor = [UIColor colorWithRed:6.0/255.0 green:77.0/255.0 blue:214.0/255.0 alpha:1.0]; + self.layer.borderColor = [UIColor colorWithRed:4.0/255.0 green:76.0/255.0 blue:221.0/255.0 alpha:1.0].CGColor; + } + self.tintColor = self.textColor; + } + if ([super inputAccessoryView] == nil) { + [self reloadInputViews]; + } +} + +- (NSArray *)keyCommands { + return @[[UIKeyCommand keyCommandWithInput:@"\t" modifierFlags:0 action:@selector(tabCommand:)]]; +} + +- (void) markAsIncorrect { + if (_correct) { + _correct = NO; + self.textColor = [UIColor colorWithRed:214.0/255.0 green:6.0/255.0 blue:6.0/255.0 alpha:1.0]; + self.layer.borderColor = [UIColor clearColor].CGColor; + if ([self isFirstResponder]) { + self.layer.backgroundColor = [UIColor colorWithRed:250.0/255.0 green:230.0/255.0 blue:230.0/255.0 alpha:0.8].CGColor; + } + self.layer.borderWidth = 2.0; + self.layer.cornerRadius = 8.0; + self.tintColor = self.textColor; + } + if ([super inputAccessoryView] != nil) { + [self reloadInputViews]; + } +} + +#pragma mark - Override + +- (__kindof MnemonicsSuggestionsInputAccessoryView *)inputAccessoryView { + if (!_showInputAccessoryView) { + return nil; + } + return self.suggestionsInputAccessoryView; +} + +#pragma mark - Private + +- (void) _createInputAccessoryView { + MnemonicsSuggestionsInputAccessoryView *inputAccessoryView = [[MnemonicsSuggestionsInputAccessoryView alloc] init];; + self.suggestionsInputAccessoryView = inputAccessoryView; +} + +@end diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/MnemonicsView.h b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/MnemonicsView.h new file mode 100644 index 0000000..c67914f --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/MnemonicsView.h @@ -0,0 +1,18 @@ +// +// MnemonicsView.h +// +// Created by Mikhail Nikanorov. +// + +#import + +NS_ASSUME_NONNULL_BEGIN + +IB_DESIGNABLE +@interface MnemonicsView : UIControl +@property (nonatomic, getter=isCentered) IBInspectable BOOL centered; +@property (nonatomic) IBInspectable NSUInteger numberOfWords; +@property (nonatomic, strong, readonly) NSString *mnemonics; +@end + +NS_ASSUME_NONNULL_END diff --git a/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/MnemonicsView.m b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/MnemonicsView.m new file mode 100644 index 0000000..bf2716d --- /dev/null +++ b/DevelopPods/MnemonicsView/MnemonicsView/Classes/MnemonicsView/MnemonicsView.m @@ -0,0 +1,294 @@ +// +// MnemonicsView.m +// +// Created by Mikhail Nikanorov. +// + +#import "MnemonicsView.h" +#import "MnemonicsItemView.h" +#import "MnemonicsProvider.h" + +static UIEdgeInsets const kMnemonicsDefaultInsets = {15.0, 16.0, 15.0, 20.0}; +static UIEdgeInsets const kMnemonicsDefaultDecreasedInsets = {8.0, 8.0, 8.0, 16.0}; +static UIEdgeInsets const kMnemonicsDefaultCenteredInsets = {16.0, 16.0, 16.0, 16.0}; +static UIEdgeInsets const kMnemonicsDefaultDecreasedCenteredInsets = {8.0, 8.0, 8.0, 8.0}; + +static CGFloat const kDecreasedSizeThreshold = 305.0; + +typedef NS_OPTIONS(short, MnemonicsViewLayoutState) { + MnemonicsViewLayoutStateDefault = 0 << 0, + MnemonicsViewLayoutStateDecreasedSize = 1 << 0, + MnemonicsViewLayoutStateCentered = 1 << 1, + MnemonicsViewLayoutStateDecreasedCentered = MnemonicsViewLayoutStateDecreasedSize | MnemonicsViewLayoutStateCentered, + MnemonicsViewLayoutStateCustom = 1 << 2 +}; + +static NSUInteger const MnemonicsViewDefaultCount = 24; + +@interface MnemonicsView () +@property (nonatomic, weak) NSLayoutConstraint *containerTopConstraint; +@property (nonatomic, weak) NSLayoutConstraint *containerLeadingConstraint; +@property (nonatomic, weak) NSLayoutConstraint *containerBottomConstraint; +@property (nonatomic, weak) NSLayoutConstraint *containerTrailingConstraint; +@property (nonatomic, weak) UIStackView *columnsStackView; +@property (nonatomic, getter=isDecreasedSize) BOOL decreasedSize; +@property (nonatomic, strong) NSPointerArray *items; +@property (nonatomic, strong) id mnemonicsProvider; +@property (nonatomic) BOOL pasteSentence; +@end + +@implementation MnemonicsView { + MnemonicsViewLayoutState _layoutState; +} + +@dynamic centered; +@dynamic decreasedSize; + +- (instancetype) init { + self = [super init]; + if (self) { + [self _commonInit]; + } + return self; +} + +- (instancetype)initWithCoder:(NSCoder *)aDecoder { + self = [super initWithCoder:aDecoder]; + if (self) { + [self _commonInit]; + } + return self; +} + +- (instancetype)initWithFrame:(CGRect)frame { + self = [super initWithFrame:frame]; + if (self) { + [self _commonInit]; + } + return self; +} + +- (void) prepareForInterfaceBuilder { + [self _commonInit]; +} + +#pragma mark - Private + +- (void) _commonInit { + self.items = [NSPointerArray weakObjectsPointerArray]; + if (!self.columnsStackView) { + UIStackView *hStackView = [[UIStackView alloc] init]; + hStackView.distribution = UIStackViewDistributionFillEqually; + hStackView.alignment = UIStackViewAlignmentTop; + hStackView.translatesAutoresizingMaskIntoConstraints = NO; + [self addSubview:hStackView]; + + self.columnsStackView = hStackView; + + NSLayoutConstraint *top = [hStackView.topAnchor constraintEqualToAnchor:self.topAnchor]; + NSLayoutConstraint *leading = [hStackView.leadingAnchor constraintEqualToAnchor:self.leadingAnchor]; + NSLayoutConstraint *bottom = [self.bottomAnchor constraintEqualToAnchor:hStackView.bottomAnchor]; + NSLayoutConstraint *trailing = [self.trailingAnchor constraintEqualToAnchor:hStackView.trailingAnchor]; + + [NSLayoutConstraint activateConstraints:@[leading, trailing, top, bottom]]; + + self.containerTopConstraint = top; + self.containerLeadingConstraint = leading; + self.containerBottomConstraint = bottom; + self.containerTrailingConstraint = trailing; + if (self.numberOfWords == 0) { + self.numberOfWords = MnemonicsViewDefaultCount; + } + } +} + +- (void) _prepareColumns { + if (self.columnsStackView) { + + NSUInteger secondHalf = _numberOfWords / 2; + NSUInteger firstHalf = _numberOfWords - secondHalf; + + [self.columnsStackView.arrangedSubviews makeObjectsPerformSelector:@selector(removeFromSuperview)]; + + if (!self.mnemonicsProvider) { + self.mnemonicsProvider = [[MnemonicsProvider alloc] initWithLanguage:MnemonicsProviderLanguageEnglish]; + } + + [self.columnsStackView addArrangedSubview:[self _prepareColumnWithNumberOfItems:firstHalf startIndex:0 mnemonicsProvider:self.mnemonicsProvider]]; + [self.columnsStackView addArrangedSubview:[self _prepareColumnWithNumberOfItems:secondHalf startIndex:firstHalf mnemonicsProvider:self.mnemonicsProvider]]; + MnemonicsItemView *item = [[self.items allObjects] lastObject]; + item.last = YES; + [self.items addPointer:NULL]; //https://stackoverflow.com/questions/31322290/nspointerarray-weird-compaction + [self.items compact]; + } +} + +- (UIStackView *) _prepareColumnWithNumberOfItems:(short)numberOfItems startIndex:(short)startIndex mnemonicsProvider:(id )mnemonicsProvider { + UIStackView *stackView = [[UIStackView alloc] init]; + stackView.axis = UILayoutConstraintAxisVertical; + stackView.distribution = UIStackViewDistributionFillProportionally; + + UILabel *label = nil; + for (short i = 0; i < numberOfItems; ++i) { + MnemonicsItemView *item = [MnemonicsItemView itemWithIndex:startIndex+i mnemonicsProvider:mnemonicsProvider]; + //TODO weak self? + item.delegate = self; + item.translatesAutoresizingMaskIntoConstraints = NO; + [stackView addArrangedSubview:item]; + if (label) { + [item.label.widthAnchor constraintEqualToAnchor:label.widthAnchor].active = YES; + } + label = item.label; + [self.items addPointer:(__bridge void *)item]; + } + return stackView; +} + +#pragma mark - Override + +- (void) setCentered:(BOOL)centered { + if (centered != [self isCentered]) { + if (centered) { + _layoutState |= MnemonicsViewLayoutStateCentered; + } else { + _layoutState &= ~MnemonicsViewLayoutStateCentered; + } + [self setNeedsUpdateConstraints]; + } +} + +- (BOOL) isCentered { + return (_layoutState & MnemonicsViewLayoutStateCentered) == MnemonicsViewLayoutStateCentered; +} + +- (void)setDecreasedSize:(BOOL)decreasedSize { + if (decreasedSize != [self isDecreasedSize]) { + if (decreasedSize) { + _layoutState |= MnemonicsViewLayoutStateDecreasedSize; + } else { + _layoutState &= ~MnemonicsViewLayoutStateDecreasedSize; + } + [self setNeedsUpdateConstraints]; + } +} + +- (BOOL)isDecreasedSize { + return (_layoutState & MnemonicsViewLayoutStateDecreasedSize) == MnemonicsViewLayoutStateDecreasedSize; +} + +- (void)setNumberOfWords:(NSUInteger)numberOfWords { + _numberOfWords = MAX(numberOfWords, 1); + [self _prepareColumns]; +} + +- (BOOL)becomeFirstResponder { + NSArray *items = [self.items allObjects]; + NSArray *emptyObjects = [items filteredArrayUsingPredicate:[NSPredicate predicateWithFormat:@"SELF.textField.text.length == 0"]]; + MnemonicsItemView *nextItem = nil; + if ([emptyObjects count] == 0) { + nextItem = [items lastObject]; + } else { + nextItem = [emptyObjects firstObject]; + } + [nextItem becomeFirstResponder]; + return NO; +} + +#pragma mark - Autolayout + +- (void) layoutSubviews { + [super layoutSubviews]; + self.decreasedSize = CGRectGetWidth(self.bounds) < kDecreasedSizeThreshold; +} + +- (void)updateConstraints { + [super updateConstraints]; + + UIEdgeInsets insets = UIEdgeInsetsZero; + switch (_layoutState) { + case MnemonicsViewLayoutStateDefault: { insets = kMnemonicsDefaultInsets; break; } + case MnemonicsViewLayoutStateCentered: { insets = kMnemonicsDefaultCenteredInsets; break; } + case MnemonicsViewLayoutStateDecreasedSize: { insets = kMnemonicsDefaultDecreasedInsets; break; } + case MnemonicsViewLayoutStateDecreasedCentered: { insets = kMnemonicsDefaultDecreasedCenteredInsets; break; } + default: break; + } + if (@available(iOS 11.0, *)) { + NSDirectionalEdgeInsets directionalInsets = NSDirectionalEdgeInsetsMake(insets.top, insets.left, insets.bottom, insets.right); + self.containerTopConstraint.constant = directionalInsets.top; + self.containerLeadingConstraint.constant = directionalInsets.leading; + self.containerBottomConstraint.constant = directionalInsets.bottom; + self.containerTrailingConstraint.constant = directionalInsets.trailing; + } else { + self.containerTopConstraint.constant = insets.top; + self.containerLeadingConstraint.constant = insets.left; + self.containerBottomConstraint.constant = insets.bottom; + self.containerTrailingConstraint.constant = insets.right; + } + +} + +#pragma mark - MnemonicsItemViewDelegate + +- (void) mnemonicsItemViewDidEndEditing:(MnemonicsItemView *)view { + //https://gist.github.com/gamenerds/62e7a13b786dcb807507 + NSInteger nextItemIdx = view.index + 1; + if (nextItemIdx < [[self.items allObjects] count]) { + MnemonicsItemView *nextItem = [self.items allObjects][nextItemIdx]; + [nextItem becomeFirstResponder]; + } else { + [self sendActionsForControlEvents:UIControlEventEditingDidEnd]; + [self endEditing:YES]; + } +} + +- (void) mnemonicsItemViewDidEndErasing:(MnemonicsItemView *)view { + NSInteger previousItemIdx = view.index - 1; + if (previousItemIdx >= 0) { + MnemonicsItemView *previousItem = [self.items allObjects][previousItemIdx]; + [previousItem becomeFirstResponder]; + } +} + +- (void)mnemonicsItemView:(MnemonicsItemView *)view didPasteWords:(NSArray *)words { + self.pasteSentence = YES; + NSInteger itemIdx = view.index + 1; + NSArray *items = [self.items allObjects]; + for (NSInteger wordIdx = 0; itemIdx < [items count] && wordIdx < [words count]; ++itemIdx, ++wordIdx) { + NSString *word = words[wordIdx]; + MnemonicsItemView *item = items[itemIdx]; + [item updateText:word]; + } + MnemonicsItemView *item = nil; + if (itemIdx < [items count]) { + item = items[itemIdx]; + } else { + item = [items lastObject]; + } + [item becomeFirstResponder]; + + dispatch_async(dispatch_get_main_queue(), ^{ + self.pasteSentence = NO; + [self mnemonicsItemViewDidChangeState:nil]; + }); +} + +- (void) mnemonicsItemViewDidChangeState:(MnemonicsItemView *)view { + if (!self.pasteSentence) { + NSMutableArray *words = [[NSMutableArray alloc] initWithCapacity:0]; + for (MnemonicsItemView *item in [self.items allObjects]) { + NSString *value = [[item.textField.text stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]] lowercaseString]; + if ([value length] > 0) { + [words addObject:value]; + } + } + BOOL validated = [self.mnemonicsProvider validateWords:words]; + if (validated) { + _mnemonics = [words componentsJoinedByString:@" "]; + } else { + _mnemonics = nil; + } + [self sendActionsForControlEvents:UIControlEventValueChanged]; + } +} + +@end diff --git a/DevelopPods/MnemonicsView/README.md b/DevelopPods/MnemonicsView/README.md new file mode 100644 index 0000000..dc99521 --- /dev/null +++ b/DevelopPods/MnemonicsView/README.md @@ -0,0 +1,28 @@ +# MnemonicsView + +[![Version](https://img.shields.io/cocoapods/v/MnemonicsView.svg?style=flat)](https://cocoapods.org/pods/MnemonicsView) +[![License](https://img.shields.io/cocoapods/l/MnemonicsView.svg?style=flat)](https://cocoapods.org/pods/MnemonicsView) +[![Platform](https://img.shields.io/cocoapods/p/MnemonicsView.svg?style=flat)](https://cocoapods.org/pods/MnemonicsView) + +## Example + +To run the example project, clone the repo, and run `pod install` from the Example directory first. + +## Requirements + +## Installation + +MnemonicsView is available through [CocoaPods](https://cocoapods.org). To install +it, simply add the following line to your Podfile: + +```ruby +pod 'MnemonicsView' +``` + +## Author + +Mikhail Nikanorov + +## License + +MnemonicsView is available under the MIT license. See the LICENSE file for more info. diff --git a/DevelopPods/MnemonicsView/_Pods.xcodeproj b/DevelopPods/MnemonicsView/_Pods.xcodeproj new file mode 120000 index 0000000..3c5a8e7 --- /dev/null +++ b/DevelopPods/MnemonicsView/_Pods.xcodeproj @@ -0,0 +1 @@ +Example/Pods/Pods.xcodeproj \ No newline at end of file diff --git a/MyEtherWallet-iOS.xcodeproj/project.pbxproj b/MyEtherWallet-iOS.xcodeproj/project.pbxproj index ff6ad5e..0a4ca15 100644 --- a/MyEtherWallet-iOS.xcodeproj/project.pbxproj +++ b/MyEtherWallet-iOS.xcodeproj/project.pbxproj @@ -9766,6 +9766,7 @@ "${PODS_ROOT}/GoogleWebRTC/Frameworks/frameworks/WebRTC.framework", "${BUILT_PRODUCTS_DIR}/M13Checkbox/M13Checkbox.framework", "${BUILT_PRODUCTS_DIR}/MagicalRecord/MagicalRecord.framework", + "${BUILT_PRODUCTS_DIR}/MnemonicsView/MnemonicsView.framework", "${BUILT_PRODUCTS_DIR}/Nimbus/Nimbus.framework", "${BUILT_PRODUCTS_DIR}/PromiseKit/PromiseKit.framework", "${BUILT_PRODUCTS_DIR}/RamblerAppDelegateProxy/RamblerAppDelegateProxy.framework", @@ -9807,6 +9808,7 @@ "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/WebRTC.framework", "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/M13Checkbox.framework", "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/MagicalRecord.framework", + "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/MnemonicsView.framework", "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/Nimbus.framework", "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/PromiseKit.framework", "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/RamblerAppDelegateProxy.framework", @@ -9894,6 +9896,7 @@ "${PODS_ROOT}/GoogleWebRTC/Frameworks/frameworks/WebRTC.framework", "${BUILT_PRODUCTS_DIR}/M13Checkbox/M13Checkbox.framework", "${BUILT_PRODUCTS_DIR}/MagicalRecord/MagicalRecord.framework", + "${BUILT_PRODUCTS_DIR}/MnemonicsView/MnemonicsView.framework", "${BUILT_PRODUCTS_DIR}/Nimbus/Nimbus.framework", "${BUILT_PRODUCTS_DIR}/PromiseKit/PromiseKit.framework", "${BUILT_PRODUCTS_DIR}/RamblerAppDelegateProxy/RamblerAppDelegateProxy.framework", @@ -9935,6 +9938,7 @@ "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/WebRTC.framework", "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/M13Checkbox.framework", "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/MagicalRecord.framework", + "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/MnemonicsView.framework", "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/Nimbus.framework", "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/PromiseKit.framework", "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/RamblerAppDelegateProxy.framework", @@ -9999,6 +10003,7 @@ "${PODS_ROOT}/GoogleWebRTC/Frameworks/frameworks/WebRTC.framework", "${BUILT_PRODUCTS_DIR}/M13Checkbox/M13Checkbox.framework", "${BUILT_PRODUCTS_DIR}/MagicalRecord/MagicalRecord.framework", + "${BUILT_PRODUCTS_DIR}/MnemonicsView/MnemonicsView.framework", "${BUILT_PRODUCTS_DIR}/Nimbus/Nimbus.framework", "${BUILT_PRODUCTS_DIR}/PromiseKit/PromiseKit.framework", "${BUILT_PRODUCTS_DIR}/RamblerAppDelegateProxy/RamblerAppDelegateProxy.framework", @@ -10041,6 +10046,7 @@ "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/WebRTC.framework", "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/M13Checkbox.framework", "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/MagicalRecord.framework", + "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/MnemonicsView.framework", "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/Nimbus.framework", "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/PromiseKit.framework", "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/RamblerAppDelegateProxy.framework", diff --git a/MyEtherWallet-iOS.xcodeproj/xcshareddata/xcschemes/Mogenerator.xcscheme b/MyEtherWallet-iOS.xcodeproj/xcshareddata/xcschemes/Mogenerator.xcscheme new file mode 100644 index 0000000..61d70c3 --- /dev/null +++ b/MyEtherWallet-iOS.xcodeproj/xcshareddata/xcschemes/Mogenerator.xcscheme @@ -0,0 +1,80 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/MyEtherWallet-iOS.xcodeproj/xcshareddata/xcschemes/MyEtherWallet-iOS.xcscheme b/MyEtherWallet-iOS.xcodeproj/xcshareddata/xcschemes/MyEtherWallet-iOS.xcscheme index 07cd911..20c1321 100644 --- a/MyEtherWallet-iOS.xcodeproj/xcshareddata/xcschemes/MyEtherWallet-iOS.xcscheme +++ b/MyEtherWallet-iOS.xcodeproj/xcshareddata/xcschemes/MyEtherWallet-iOS.xcscheme @@ -532,7 +532,7 @@ + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/MyEtherWallet-iOS/Classes/ApplicationLayer/ApplicationConfigurator/ApplicationConfiguratorImplementation.m b/MyEtherWallet-iOS/Classes/ApplicationLayer/ApplicationConfigurator/ApplicationConfiguratorImplementation.m index 90a86c5..01fe30f 100644 --- a/MyEtherWallet-iOS/Classes/ApplicationLayer/ApplicationConfigurator/ApplicationConfiguratorImplementation.m +++ b/MyEtherWallet-iOS/Classes/ApplicationLayer/ApplicationConfigurator/ApplicationConfiguratorImplementation.m @@ -8,6 +8,7 @@ @import UIKit; @import MagicalRecord; +@import MnemonicsView; #if BETA #import "MyEtherWallet_iOS_Beta-Swift.h" @@ -37,7 +38,6 @@ @implementation ApplicationConfiguratorImplementation - (void)configureInitialSettings { [self.keychainService saveFirstLaunchDate]; [self.rateService checkForUpdate]; - [self.rateService applicationLaunched]; } - (void)configurateAppearance { @@ -120,6 +120,16 @@ - (void)configurateAppearance { } /* Toolbar Buttons */ [UIBarButtonItem appearance].tintColor = [UIColor mainApplicationColor]; + /* Mnemonics View */ + [[UIView appearanceWhenContainedInInstancesOfClasses:@[[MnemonicsSuggestionsInputAccessoryViewCollectionViewCell class]]] setBackgroundColor:[UIColor backgroundLightBlue]]; + [[UILabel appearanceWhenContainedInInstancesOfClasses:@[[MnemonicsSuggestionsInputAccessoryViewCollectionViewCell class]]] setTextColor:[UIColor mainApplicationColor]]; + + [[UIView appearanceWhenContainedInInstancesOfClasses:@[[MnemonicsSuggestionsInputAccessoryViewCollectionViewDoneCell class]]] setBackgroundColor:[UIColor mainApplicationColor]]; + [[UILabel appearanceWhenContainedInInstancesOfClasses:@[[MnemonicsSuggestionsInputAccessoryViewCollectionViewDoneCell class]]] setTextColor:[UIColor whiteColor]]; + + + [[UILabel appearanceWhenContainedInInstancesOfClasses:@[[MnemonicsItemView class]]] setFont:[UIFont systemFontOfSize:13.0]]; + [[UITextField appearanceWhenContainedInInstancesOfClasses:@[[MnemonicsItemView class]]] setFont:[UIFont systemFontOfSize:19.0]]; } @end diff --git a/MyEtherWallet-iOS/Classes/ApplicationLayer/CoreDataConfigurator/CoreDataConfiguratorImplementation.m b/MyEtherWallet-iOS/Classes/ApplicationLayer/CoreDataConfigurator/CoreDataConfiguratorImplementation.m index 10ea194..b647474 100644 --- a/MyEtherWallet-iOS/Classes/ApplicationLayer/CoreDataConfigurator/CoreDataConfiguratorImplementation.m +++ b/MyEtherWallet-iOS/Classes/ApplicationLayer/CoreDataConfigurator/CoreDataConfiguratorImplementation.m @@ -75,12 +75,8 @@ - (void) _restoreCoreDataStructure { NSManagedObjectContext *rootSavingContext = [NSManagedObjectContext MR_rootSavingContext]; [rootSavingContext performBlockAndWait:^{ NSArray *accountModels = [AccountModelObject MR_findAllInContext:rootSavingContext]; - if ([accountModels count] == 0) { - NSArray *storedItems = [self.keychainService obtainStoredItems]; - if ([storedItems count] == 0) { - return; - } - + NSArray *storedItems = [self.keychainService obtainStoredItems]; + if ([accountModels count] == 0 && [storedItems count] != 0) { for (KeychainAccountModel *keychainItem in storedItems) { AccountModelObject *accountModelObject = [AccountModelObject MR_findFirstOrCreateByAttribute:NSStringFromSelector(@selector(uid)) withValue:keychainItem.uid inContext:rootSavingContext]; accountModelObject.backedUp = @(keychainItem.backedUp); @@ -130,10 +126,23 @@ - (void) _restoreCoreDataStructure { accountModelObject.active = @YES; networkModelObject.active = @YES; - - if ([rootSavingContext hasChanges]) { - [rootSavingContext MR_saveToPersistentStoreAndWait]; - } + } + //Clear ghost tokens + NSPredicate *predicate = [NSPredicate predicateWithFormat:@"SELF.fromNetworkMaster == nil && SELF.fromNetwork == nil"]; + NSArray *ghostMasterTokens = [MasterTokenModelObject MR_findAllWithPredicate:predicate inContext:rootSavingContext]; + if ([ghostMasterTokens count] > 0) { + [rootSavingContext MR_deleteObjects:ghostMasterTokens]; + } + + predicate = [NSPredicate predicateWithFormat:@"SELF.fromNetwork == nil"]; + NSFetchRequest *request = [TokenModelObject MR_requestAllWithPredicate:predicate inContext:rootSavingContext]; + request.includesSubentities = NO; + NSArray *ghostTokens = [request execute:nil]; + if ([ghostTokens count] > 0) { + [rootSavingContext MR_deleteObjects:ghostTokens]; + } + if ([rootSavingContext hasChanges]) { + [rootSavingContext MR_saveToPersistentStoreAndWait]; } }]; } diff --git a/MyEtherWallet-iOS/Classes/ApplicationLayer/ThirdPartiesConfigurator/ThirdPartiesConfiguratorImplementation.m b/MyEtherWallet-iOS/Classes/ApplicationLayer/ThirdPartiesConfigurator/ThirdPartiesConfiguratorImplementation.m index d3d1422..bcc892e 100644 --- a/MyEtherWallet-iOS/Classes/ApplicationLayer/ThirdPartiesConfigurator/ThirdPartiesConfiguratorImplementation.m +++ b/MyEtherWallet-iOS/Classes/ApplicationLayer/ThirdPartiesConfigurator/ThirdPartiesConfiguratorImplementation.m @@ -16,7 +16,7 @@ - (void) configurate { /* Logger */ [DDLog addLogger:[DDTTYLogger sharedInstance]]; #if !DEBUG - [DDLog addLogger:[DDASLLogger sharedInstance]]; + [DDLog addLogger:[DDOSLogger sharedInstance]]; #endif /* WebRTC */ RTCInitializeSSL(); diff --git a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Assemblies/ServiceComponentsAssembly/ServiceComponentsAssembly.m b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Assemblies/ServiceComponentsAssembly/ServiceComponentsAssembly.m index 304cb24..b1c47d0 100644 --- a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Assemblies/ServiceComponentsAssembly/ServiceComponentsAssembly.m +++ b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Assemblies/ServiceComponentsAssembly/ServiceComponentsAssembly.m @@ -238,6 +238,8 @@ - (MEWconnectServiceStateMachine *) MEWconnectServiceStateMachine { return [TyphoonDefinition withClass:[SecurityServiceImplementation class] configuration:^(TyphoonDefinition *definition) { definition.scope = TyphoonScopeSingleton; + [definition injectProperty:@selector(keychainService) + with:[self keychainService]]; }]; } diff --git a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/Constants/KeychainServiceSharedConstants.h b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/Constants/KeychainServiceSharedConstants.h index ff3b243..84ec816 100644 --- a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/Constants/KeychainServiceSharedConstants.h +++ b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/Constants/KeychainServiceSharedConstants.h @@ -10,9 +10,6 @@ FOUNDATION_EXPORT NSString *const kKeychainServiceFirstLaunchField; -FOUNDATION_EXPORT NSString *const kKeychainServiceRateAskedValue; -FOUNDATION_EXPORT NSString *const kKeychainServiceRateAskedField; - FOUNDATION_EXPORT NSString *const kKeychainServiceVersionField; FOUNDATION_EXPORT NSString *const kKeychainServiceEntropyField; @@ -24,3 +21,6 @@ FOUNDATION_EXPORT NSString *const kKeychainServicePurchaseDateField; //Current version FOUNDATION_EXPORT NSString *const kKeychainServiceCurrentKeychainVersionField; FOUNDATION_EXPORT NSInteger const kKeychainServiceCurrentKeychainVersionValue; + +FOUNDATION_EXPORT NSString *const kKeychainServiceBruteForceLockDateField; +FOUNDATION_EXPORT NSString *const kKeychainServiceBruteForceNumberOfAttempts; diff --git a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/Constants/KeychainServiceSharedConstants.m b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/Constants/KeychainServiceSharedConstants.m index fadc63d..5205305 100644 --- a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/Constants/KeychainServiceSharedConstants.m +++ b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/Constants/KeychainServiceSharedConstants.m @@ -10,9 +10,6 @@ NSString *const kKeychainServiceFirstLaunchField = @"firstLaunch"; -NSString *const kKeychainServiceRateAskedValue = @"true"; -NSString *const kKeychainServiceRateAskedField = @"com.myetherwallet.rater.rateasked"; - NSString *const kKeychainServiceVersionField = @"com.myetherwallet.keychain.version"; NSString *const kKeychainServiceEntropyField = @"entropy"; @@ -24,3 +21,6 @@ //Current version NSString *const kKeychainServiceCurrentKeychainVersionField = @"version"; NSInteger const kKeychainServiceCurrentKeychainVersionValue = 2; + +NSString *const kKeychainServiceBruteForceLockDateField = @"com.myetherwallet.bruteforce.lockdate"; +NSString *const kKeychainServiceBruteForceNumberOfAttempts = @"com.myetherwallet.bruteforce.attempts"; diff --git a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/KeychainService.h b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/KeychainService.h index edc3916..e2dc8d9 100644 --- a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/KeychainService.h +++ b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/KeychainService.h @@ -47,17 +47,21 @@ NS_ASSUME_NONNULL_BEGIN */ - (NSString * _Nullable) obtainFirstLaunchDate; /** - Saving rate status + Obtaining number of password attempts */ -- (void) rateDidAsked; +- (NSInteger) obtainNumberOfPasswordAttempts; /** - Obtain rate status + Reset number of password attempts */ -- (BOOL) obtainRateStatus; +- (void) savePasswordAttempts:(NSInteger)attempts; /** - Reset rate status + Obtain unlock date */ -- (void) resetRateStatus; +- (NSDate *) obtainPasswordUnlockDate; +/** + Save password unlock date + */ +- (void) savePasswordUnlockDate:(NSDate *)date; @end NS_ASSUME_NONNULL_END diff --git a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/KeychainServiceImplementation.m b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/KeychainServiceImplementation.m index 4353003..60c83e0 100644 --- a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/KeychainServiceImplementation.m +++ b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/KeychainService/KeychainServiceImplementation.m @@ -158,7 +158,7 @@ - (void) removeDataOfAccount:(AccountPlainObject *)account { - (void) resetKeychain { NSArray *keys = [self.keychainStore allKeys]; - NSArray *ignoringKeys = @[kKeychainServiceRateAskedField, kKeychainServiceVersionField, kKeychainServiceFirstLaunchField]; + NSArray *ignoringKeys = @[kKeychainServiceVersionField, kKeychainServiceFirstLaunchField]; for (NSString *key in keys) { if (![ignoringKeys containsObject:key]) { [self _removeItemWithKey:key]; @@ -178,16 +178,27 @@ - (NSString *)obtainFirstLaunchDate { return [self.keychainStore stringForKey:kKeychainServiceFirstLaunchField]; } -- (void) rateDidAsked { - [self.keychainStore setString:kKeychainServiceRateAskedValue forKey:kKeychainServiceRateAskedField]; +- (NSInteger) obtainNumberOfPasswordAttempts { + NSString *attemptsValue = [self.keychainStore stringForKey:kKeychainServiceBruteForceNumberOfAttempts]; + return [attemptsValue integerValue]; } -- (BOOL) obtainRateStatus { - return [self.keychainStore stringForKey:kKeychainServiceRateAskedField] != nil; +- (void) savePasswordAttempts:(NSInteger)attempts { + NSString *attemptsValue = [@(attempts) stringValue]; + [self.keychainStore setString:attemptsValue forKey:kKeychainServiceBruteForceNumberOfAttempts]; } -- (void) resetRateStatus { - [self.keychainStore removeItemForKey:kKeychainServiceRateAskedField]; +- (NSDate *) obtainPasswordUnlockDate { + NSString *dateString = [self.keychainStore stringForKey:kKeychainServiceBruteForceLockDateField]; + if (!dateString) { + return nil; + } + return [self.dateFormatter dateFromString:dateString]; +} + +- (void) savePasswordUnlockDate:(NSDate *)date { + NSString *dateString = [self.dateFormatter stringFromDate:date]; + [self.keychainStore setString:dateString forKey:kKeychainServiceBruteForceLockDateField]; } #pragma mark - Protected @@ -228,7 +239,7 @@ - (void) _storeKeychainVersion:(NSInteger)version { - (NSArray *) _obtainRawKeys { NSMutableArray *keys = [[self.keychainStore allKeys] mutableCopy]; - NSArray *ignoringKeys = @[kKeychainServiceRateAskedField, kKeychainServiceVersionField, kKeychainServiceFirstLaunchField]; + NSArray *ignoringKeys = @[kKeychainServiceVersionField, kKeychainServiceFirstLaunchField]; [keys removeObjectsInArray:ignoringKeys]; return [keys copy]; } diff --git a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/RateService/RateService.h b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/RateService/RateService.h index c00a851..64a9745 100644 --- a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/RateService/RateService.h +++ b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/RateService/RateService.h @@ -13,7 +13,6 @@ NS_ASSUME_NONNULL_BEGIN @protocol RateService - (void) checkForUpdate; - (void) balanceUpdated; -- (void) applicationLaunched; - (void) clearCount; - (void) requestReviewIfNeeded; @end diff --git a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/RateService/RateServiceImplementation.m b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/RateService/RateServiceImplementation.m index 245a0dc..c8f0d2e 100644 --- a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/RateService/RateServiceImplementation.m +++ b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/RateService/RateServiceImplementation.m @@ -11,13 +11,13 @@ #import "RateServiceImplementation.h" #import "KeychainService.h" -static NSString *const kRateServiceImplementationRaterVersion = @"group.myetherwallet.userdefaults.raterversion"; -static NSString *const kRateServiceImplementationLaunchCount = @"group.myetherwallet.userdefaults.launchcount"; -static NSString *const kRateServiceImplementationBalanceUpdateCount = @"group.myetherwallet.userdefaults.balanceupdate"; +static NSString *const kRateServiceImplementationRaterVersion = @"group.myetherwallet.userdefaults.raterversion"; +static NSString *const kRateServiceImplementationBalanceUpdateCount = @"group.myetherwallet.userdefaults.balanceupdate"; +static NSString *const kRateServiceImplementationPhase = @"group.myetherwallet.userdefaults.phase"; -static NSInteger const kRateServiceImplementationNumberOfLaunchCount = 5; -static NSInteger const kRateServiceImplementationNumberOfBalanceUpdate = 10; -static NSInteger const kRateServiceImplementationCurrentRaterVersion = 2; +static NSInteger const kRateServiceImplementationNumberOfBalanceUpdate = 10; +static NSInteger const kRateServiceImplementationNextNumberOfBalanceUpdate = 100; +static NSInteger const kRateServiceImplementationCurrentRaterVersion = 3; @implementation RateServiceImplementation @@ -25,7 +25,6 @@ - (void) checkForUpdate { NSInteger version = [self.userDefaults integerForKey:kRateServiceImplementationRaterVersion]; if (version != kRateServiceImplementationCurrentRaterVersion) { [self clearCount]; - [self.keychainService resetRateStatus]; [self.userDefaults setInteger:kRateServiceImplementationCurrentRaterVersion forKey:kRateServiceImplementationRaterVersion]; [self.userDefaults synchronize]; } @@ -38,31 +37,24 @@ - (void) balanceUpdated { [self.userDefaults synchronize]; } -- (void) applicationLaunched { - NSInteger count = [self.userDefaults integerForKey:kRateServiceImplementationLaunchCount]; - ++count; - [self.userDefaults setInteger:count forKey:kRateServiceImplementationLaunchCount]; - [self.userDefaults synchronize]; -} - - (void) clearCount { - [self.userDefaults removeObjectForKey:kRateServiceImplementationLaunchCount]; + [self.userDefaults removeObjectForKey:kRateServiceImplementationPhase]; [self.userDefaults removeObjectForKey:kRateServiceImplementationBalanceUpdateCount]; [self.userDefaults synchronize]; } - (void) requestReviewIfNeeded { - NSInteger launchCount = [self.userDefaults integerForKey:kRateServiceImplementationLaunchCount]; NSInteger updateCount = [self.userDefaults integerForKey:kRateServiceImplementationBalanceUpdateCount]; + NSInteger requiredCount = kRateServiceImplementationNumberOfBalanceUpdate + [self.userDefaults integerForKey:kRateServiceImplementationPhase] * kRateServiceImplementationNextNumberOfBalanceUpdate; - if (launchCount >= kRateServiceImplementationNumberOfLaunchCount - && updateCount >= kRateServiceImplementationNumberOfBalanceUpdate - && ![self.keychainService obtainRateStatus]) { - + if (updateCount >= requiredCount) { dispatch_async(dispatch_get_main_queue(), ^{ if (@available(iOS 10.3, *)) { [SKStoreReviewController requestReview]; - [self.keychainService rateDidAsked]; + NSInteger phase = [self.userDefaults integerForKey:kRateServiceImplementationPhase]; + ++phase; + [self.userDefaults setInteger:phase forKey:kRateServiceImplementationPhase]; + [self.userDefaults synchronize]; } }); } diff --git a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/SecurityService/SecurityService.h b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/SecurityService/SecurityService.h index 5451bbf..3e7d4d6 100644 --- a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/SecurityService/SecurityService.h +++ b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/SecurityService/SecurityService.h @@ -18,6 +18,11 @@ NS_ASSUME_NONNULL_BEGIN - (void) disableForceProtection; - (BOOL) obtainProtectionStatus; - (void) resetOneTimeProtection; + +- (void) incorrectAttempt; +- (void) correctAttempt; +- (BOOL) isInputLocked; +- (NSDate * __nullable) unlockTime; @end NS_ASSUME_NONNULL_END diff --git a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/SecurityService/SecurityServiceImplementation.h b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/SecurityService/SecurityServiceImplementation.h index 6eecbc3..6d058e7 100644 --- a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/SecurityService/SecurityServiceImplementation.h +++ b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/SecurityService/SecurityServiceImplementation.h @@ -8,10 +8,12 @@ #import "SecurityService.h" +@protocol KeychainService; + NS_ASSUME_NONNULL_BEGIN @interface SecurityServiceImplementation : NSObject - +@property (nonatomic, strong) id keychainService; @end NS_ASSUME_NONNULL_END diff --git a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/SecurityService/SecurityServiceImplementation.m b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/SecurityService/SecurityServiceImplementation.m index 6781f6f..43287f9 100644 --- a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/SecurityService/SecurityServiceImplementation.m +++ b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/SecurityService/SecurityServiceImplementation.m @@ -6,9 +6,16 @@ // Copyright © 2018 MyEtherWallet, Inc. All rights reserved. // +#import "KeychainService.h" #import "SecurityServiceImplementation.h" -static CFTimeInterval const kSecurityServiceImplementationDefaultTimeout = 300.0; +static CFTimeInterval const kSecurityServiceImplementationDefaultTimeout = 300.0; +static NSInteger const kSecurityServiceImplementationNumberOfIncorrectAttempts = 5; +#if DEBUG +static NSTimeInterval const kSecurityServiceImplementationUnlockTimeout = 120.0; +#else +static NSTimeInterval const kSecurityServiceImplementationUnlockTimeout = 300.0; +#endif @interface SecurityServiceImplementation () @property (nonatomic) BOOL forceProtection; @@ -61,6 +68,33 @@ - (BOOL) obtainProtectionStatus { - (void) resetOneTimeProtection { self.oneTimeProtection = NO; } + +- (void) incorrectAttempt { + NSInteger numberOfAttempts = [self.keychainService obtainNumberOfPasswordAttempts]; + ++numberOfAttempts; + if (numberOfAttempts >= kSecurityServiceImplementationNumberOfIncorrectAttempts) { + NSDate *date = [NSDate dateWithTimeIntervalSinceNow:kSecurityServiceImplementationUnlockTimeout]; + [self.keychainService savePasswordUnlockDate:date]; + [self.keychainService savePasswordAttempts:0]; + } else { + [self.keychainService savePasswordAttempts:numberOfAttempts]; + } +} + +- (void) correctAttempt { + [self.keychainService savePasswordAttempts:0]; +} + +- (BOOL) isInputLocked { + NSDate *unlockDate = [self.keychainService obtainPasswordUnlockDate]; + NSDate *now = [NSDate date]; + BOOL locked = unlockDate && [now compare:unlockDate] != NSOrderedDescending; + return locked; +} + +- (NSDate * __nullable) unlockTime { + return [self.keychainService obtainPasswordUnlockDate]; +} #pragma mark - Notifications diff --git a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/TokensService/TokensService.h b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/TokensService/TokensService.h index 71d151e..08f8cac 100644 --- a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/TokensService/TokensService.h +++ b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/TokensService/TokensService.h @@ -22,4 +22,5 @@ typedef void(^TokensServiceCompletion)(NSError *error); - (NSDecimalNumber *) obtainTokensTotalPriceOfMasterToken:(MasterTokenPlainObject *)masterToken; - (MasterTokenModelObject *) obtainActiveMasterToken; - (TokenModelObject *) obtainTokenWithAddress:(NSString *)address ofMasterToken:(MasterTokenPlainObject *)masterToken; +- (void) resetTokens; @end diff --git a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/TokensService/TokensServiceImplementation.m b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/TokensService/TokensServiceImplementation.m index a50099e..e14ee57 100644 --- a/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/TokensService/TokensServiceImplementation.m +++ b/MyEtherWallet-iOS/Classes/BusinessLogicLayer/Services/ConcreteServices/TokensService/TokensServiceImplementation.m @@ -197,6 +197,15 @@ - (TokenModelObject *) obtainTokenWithAddress:(NSString *)address ofMasterToken: return tokenModelObject; } +- (void) resetTokens { + NSManagedObjectContext *rootSavingContext = [NSManagedObjectContext MR_rootSavingContext]; + [rootSavingContext performBlockAndWait:^{ + NSArray *tokens = [TokenModelObject MR_findAllInContext:rootSavingContext]; + [rootSavingContext MR_deleteObjects:tokens]; + [rootSavingContext MR_saveToPersistentStoreAndWait]; + }]; +} + #pragma mark - Private - (TokensBody *) obtainTokensBodyWithToken:(MasterTokenPlainObject *)token contractAddresses:(NSArray *)contractAddresses { diff --git a/MyEtherWallet-iOS/Classes/Extenstions/UIColor/UIColor+Application/UIColor+Application.h b/MyEtherWallet-iOS/Classes/Extenstions/UIColor/UIColor+Application/UIColor+Application.h index 9b9c25d..eb67785 100644 --- a/MyEtherWallet-iOS/Classes/Extenstions/UIColor/UIColor+Application/UIColor+Application.h +++ b/MyEtherWallet-iOS/Classes/Extenstions/UIColor/UIColor+Application/UIColor+Application.h @@ -20,4 +20,6 @@ + (instancetype) applicationLightBlue; + (instancetype) backgroundLightBlue; + (instancetype) lightGreyTextColor; ++ (instancetype) disabledBackgroundColor; ++ (instancetype) disabledPlaceholderColor; @end diff --git a/MyEtherWallet-iOS/Classes/Extenstions/UIColor/UIColor+Application/UIColor+Application.m b/MyEtherWallet-iOS/Classes/Extenstions/UIColor/UIColor+Application/UIColor+Application.m index 8c90645..df676ae 100644 --- a/MyEtherWallet-iOS/Classes/Extenstions/UIColor/UIColor+Application/UIColor+Application.m +++ b/MyEtherWallet-iOS/Classes/Extenstions/UIColor/UIColor+Application/UIColor+Application.m @@ -66,4 +66,13 @@ + (instancetype) backgroundLightBlue { + (instancetype) lightGreyTextColor { return [UIColor colorWithRGB:0x6E7384]; } + ++ (instancetype) disabledBackgroundColor { + return [UIColor colorWithRGB:0xF5F4F5]; +} + ++ (instancetype) disabledPlaceholderColor { + return [UIColor colorWithWhite:0.0 alpha:0.2]; +} + @end diff --git a/MyEtherWallet-iOS/Classes/Models/ConcreteClasses/MEWConnect/MEWConnectTransaction/MEWConnectTransaction.m b/MyEtherWallet-iOS/Classes/Models/ConcreteClasses/MEWConnect/MEWConnectTransaction/MEWConnectTransaction.m index 8aa50e6..43641e3 100644 --- a/MyEtherWallet-iOS/Classes/Models/ConcreteClasses/MEWConnect/MEWConnectTransaction/MEWConnectTransaction.m +++ b/MyEtherWallet-iOS/Classes/Models/ConcreteClasses/MEWConnect/MEWConnectTransaction/MEWConnectTransaction.m @@ -58,7 +58,7 @@ - (NSDecimalNumber *) decimalValue { } else { decimalValue = [self.value decimalNumberFromHexRepresentation]; } - if (!self.token.decimals) { + if (self.token.decimals == nil) { return decimalValue; } NSDecimalNumber *decimals = [NSDecimalNumber decimalNumberWithMantissa:1 exponent:[self.token.decimals shortValue] isNegative:NO]; diff --git a/MyEtherWallet-iOS/Classes/Models/ConcreteClasses/MEWConnect/MEWconnectTokenTransfer/MEWconnectTokenTransfer.h b/MyEtherWallet-iOS/Classes/Models/ConcreteClasses/MEWConnect/MEWconnectTokenTransfer/MEWconnectTokenTransfer.h index 6cb21a9..dae0fc0 100644 --- a/MyEtherWallet-iOS/Classes/Models/ConcreteClasses/MEWConnect/MEWconnectTokenTransfer/MEWconnectTokenTransfer.h +++ b/MyEtherWallet-iOS/Classes/Models/ConcreteClasses/MEWConnect/MEWconnectTokenTransfer/MEWconnectTokenTransfer.h @@ -13,7 +13,7 @@ NS_ASSUME_NONNULL_BEGIN @interface MEWconnectTokenTransfer : NSObject @property (nonatomic, strong, readonly) NSString *to; @property (nonatomic, strong, readonly) NSDecimalNumber *decimalValue; -+ (instancetype) tokenTransferWithData:(id)data; ++ (instancetype __nullable) tokenTransferWithData:(id)data; @end NS_ASSUME_NONNULL_END diff --git a/MyEtherWallet-iOS/Classes/Models/ConcreteClasses/MEWConnect/MEWconnectTokenTransfer/MEWconnectTokenTransfer.m b/MyEtherWallet-iOS/Classes/Models/ConcreteClasses/MEWConnect/MEWconnectTokenTransfer/MEWconnectTokenTransfer.m index 2d70362..e236cf9 100644 --- a/MyEtherWallet-iOS/Classes/Models/ConcreteClasses/MEWConnect/MEWconnectTokenTransfer/MEWconnectTokenTransfer.m +++ b/MyEtherWallet-iOS/Classes/Models/ConcreteClasses/MEWConnect/MEWconnectTokenTransfer/MEWconnectTokenTransfer.m @@ -15,7 +15,7 @@ @implementation MEWconnectTokenTransfer -+ (instancetype) tokenTransferWithData:(id)data { ++ (instancetype __nullable) tokenTransferWithData:(id)data { if (![data isKindOfClass:[NSString class]]) { return nil; } diff --git a/MyEtherWallet-iOS/Classes/PresentationLayer/Assemblies/TransitionDelegatesAssembly/TransitioningDelegateAssembly.m b/MyEtherWallet-iOS/Classes/PresentationLayer/Assemblies/TransitionDelegatesAssembly/TransitioningDelegateAssembly.m index 1b38b73..1ca07c7 100644 --- a/MyEtherWallet-iOS/Classes/PresentationLayer/Assemblies/TransitionDelegatesAssembly/TransitioningDelegateAssembly.m +++ b/MyEtherWallet-iOS/Classes/PresentationLayer/Assemblies/TransitionDelegatesAssembly/TransitioningDelegateAssembly.m @@ -66,10 +66,12 @@ @implementation TransitioningDelegateAssembly configuration:^(TyphoonDefinition *definition) { [definition injectProperty:@selector(presentationControllerType) with:@(PresentationControllerBottomModalType)]; - [definition injectProperty:@selector(presentingAnimationController) - with:[self fadeModalPresentingAnimationController]]; - [definition injectProperty:@selector(dismissingAnimationController) - with:[self fadeModalDismissingAnimationController]]; + if (@available(iOS 11.0, *)) { + [definition injectProperty:@selector(presentingAnimationController) + with:[self fadeModalPresentingAnimationController]]; + [definition injectProperty:@selector(dismissingAnimationController) + with:[self fadeModalDismissingAnimationController]]; + } [definition injectProperty:@selector(presentationControllerFactory) with:self.presentationControllerFactory]; [definition injectProperty:@selector(dimmed) diff --git a/MyEtherWallet-iOS/Classes/PresentationLayer/Common/ConcreteClasses/PasswordTextField/PasswordTextField.h b/MyEtherWallet-iOS/Classes/PresentationLayer/Common/ConcreteClasses/PasswordTextField/PasswordTextField.h index a37f3dd..3b4abfc 100644 --- a/MyEtherWallet-iOS/Classes/PresentationLayer/Common/ConcreteClasses/PasswordTextField/PasswordTextField.h +++ b/MyEtherWallet-iOS/Classes/PresentationLayer/Common/ConcreteClasses/PasswordTextField/PasswordTextField.h @@ -11,8 +11,11 @@ typedef NS_ENUM(short, PasswordTextFieldTheme) { PasswordTextFieldThemeDefault, PasswordTextFieldThemeRed, + PasswordTextFieldThemeDisabled, }; @interface PasswordTextField : UITextField @property (nonatomic) PasswordTextFieldTheme theme; +@property (nonatomic) BOOL inputEnabled; +- (void) setRightViewText:(NSString *)text; @end diff --git a/MyEtherWallet-iOS/Classes/PresentationLayer/Common/ConcreteClasses/PasswordTextField/PasswordTextField.m b/MyEtherWallet-iOS/Classes/PresentationLayer/Common/ConcreteClasses/PasswordTextField/PasswordTextField.m index 7f211ba..c1cb4d8 100644 --- a/MyEtherWallet-iOS/Classes/PresentationLayer/Common/ConcreteClasses/PasswordTextField/PasswordTextField.m +++ b/MyEtherWallet-iOS/Classes/PresentationLayer/Common/ConcreteClasses/PasswordTextField/PasswordTextField.m @@ -10,17 +10,27 @@ #import "UIColor+Application.h" #import "UIImage+Color.h" -static CGFloat kPasswordTextFieldTextInset = 14.0; -static CGFloat kPasswordTextFieldCaretHeight = 24.0; +static CGFloat kPasswordTextFieldTextInset = 14.0; +static CGFloat kPasswordTextFieldCaretHeight = 24.0; +static CGFloat kPasswordTextFieldRightLabelWidth = 100.0; -@implementation PasswordTextField +@interface PasswordTextField() +@property (nonatomic, weak) UILabel *rightLabel; +@end + +@implementation PasswordTextField { + NSAttributedString *_originalPlaceholder; + NSString *_lastRightLabelText; +} - (void)awakeFromNib { [super awakeFromNib]; - + _inputEnabled = YES; NSAttributedString *attributedPlaceholder = [[NSAttributedString alloc] initWithString:NSLocalizedString(@"Password", @"Password text field placeholder") attributes:@{NSForegroundColorAttributeName: [UIColor placeholderColor]}]; [self setAttributedPlaceholder:attributedPlaceholder]; + self.enablesReturnKeyAutomatically = YES; + [self _updateRightView]; } #pragma mark - Public @@ -30,8 +40,12 @@ - (void)setTheme:(PasswordTextFieldTheme)theme { _theme = theme; switch (theme) { case PasswordTextFieldThemeDefault: { + self.tintColor = ((PasswordTextField *)[[self class] appearance]).tintColor; /* Password text field */ [self setBackground:[[PasswordTextField appearance] background]]; + if (_originalPlaceholder) { + [self setAttributedPlaceholder:_originalPlaceholder]; + } break; } case PasswordTextFieldThemeRed: { @@ -41,13 +55,58 @@ - (void)setTheme:(PasswordTextFieldTheme)theme { [self setBackground:background]; break; } + case PasswordTextFieldThemeDisabled: { + self.tintColor = [UIColor clearColor]; + NSAttributedString *attributedPlaceholder = [[NSAttributedString alloc] initWithString:NSLocalizedString(@"Please wait", @"Password text field placeholder. Locked state") + attributes:@{NSForegroundColorAttributeName: [UIColor disabledPlaceholderColor]}]; + [self setAttributedPlaceholder:attributedPlaceholder]; + UIImage *background = [[UIImage imageWithColor:[UIColor disabledBackgroundColor] + size:CGSizeMake(48.0f, 48.0f) + cornerRadius:10.0] resizableImageWithCapInsets:UIEdgeInsetsMake(24.0f, 24.0f, 24.0f, 24.0f)]; + [self setBackground:background]; + } default: break; } } } +- (void) setRightViewText:(NSString *)text { + _lastRightLabelText = text; + [self.rightLabel setText:text]; +} + +#pragma mark - Override + +- (void) setInputEnabled:(BOOL)enabled { + BOOL wasEnabled = _inputEnabled; + _inputEnabled = enabled; + if (wasEnabled != enabled) { + if (enabled) { + [self setTheme:PasswordTextFieldThemeDefault]; + self.rightViewMode = UITextFieldViewModeNever; + } else { + [self setTheme:PasswordTextFieldThemeDisabled]; + self.rightViewMode = UITextFieldViewModeAlways; + } + } +} + +- (void)setAttributedPlaceholder:(NSAttributedString *)attributedPlaceholder { + [super setAttributedPlaceholder:attributedPlaceholder]; + if (_inputEnabled) { + _originalPlaceholder = attributedPlaceholder; + } +} + +- (BOOL)canPerformAction:(SEL)action withSender:(id)sender { + if (!_inputEnabled) { + return NO; + } + return [super canPerformAction:action withSender:sender]; +} + #pragma mark - Insets - (CGRect)textRectForBounds:(CGRect)bounds { @@ -73,4 +132,31 @@ - (CGRect)caretRectForPosition:(UITextPosition *)position { return caretRect; } +#pragma mark - Private + +- (void) _updateRightView { + if (!self.rightView) { + UIView *container = [[UIView alloc] initWithFrame:CGRectMake(0.0, 0.0, kPasswordTextFieldRightLabelWidth, CGRectGetHeight(self.bounds))]; + + UILabel *label = [[UILabel alloc] init]; + label.text = _lastRightLabelText; + label.font = [UIFont monospacedDigitSystemFontOfSize:17.0 weight:UIFontWeightRegular]; + label.textColor = [UIColor disabledPlaceholderColor]; + label.textAlignment = NSTextAlignmentRight; + label.translatesAutoresizingMaskIntoConstraints = NO; + [container addSubview:label]; + [NSLayoutConstraint activateConstraints: + @[[container.leadingAnchor constraintEqualToAnchor:label.leadingAnchor], + [container.topAnchor constraintEqualToAnchor:label.topAnchor], + [container.bottomAnchor constraintEqualToAnchor:label.bottomAnchor], + [container.trailingAnchor constraintEqualToAnchor:label.trailingAnchor constant:14.0] + ]]; + self.rightLabel = label; + [self setNeedsLayout]; + [self layoutIfNeeded]; + + self.rightView = container; + } +} + @end diff --git a/MyEtherWallet-iOS/Classes/PresentationLayer/Presentations/DismissingAnimationControllers/ConcreteClasses/BottomModalDismissingAnimationController/BottomModalDismissingAnimationController.m b/MyEtherWallet-iOS/Classes/PresentationLayer/Presentations/DismissingAnimationControllers/ConcreteClasses/BottomModalDismissingAnimationController/BottomModalDismissingAnimationController.m index 70240f8..b1226ee 100644 --- a/MyEtherWallet-iOS/Classes/PresentationLayer/Presentations/DismissingAnimationControllers/ConcreteClasses/BottomModalDismissingAnimationController/BottomModalDismissingAnimationController.m +++ b/MyEtherWallet-iOS/Classes/PresentationLayer/Presentations/DismissingAnimationControllers/ConcreteClasses/BottomModalDismissingAnimationController/BottomModalDismissingAnimationController.m @@ -21,7 +21,7 @@ - (void)animateTransition:(id )transitionC UIViewController *toViewController = [transitionContext viewControllerForKey:UITransitionContextToViewControllerKey]; UIView *containerView = [transitionContext containerView]; - UIView *dismissedViewSnapshot = [dismissedView snapshotViewAfterScreenUpdates:NO]; + UIView *dismissedViewSnapshot = [dismissedView snapshotViewAfterScreenUpdates:(dismissedView.window == nil)]; [containerView addSubview:dismissedViewSnapshot]; CGRect frame = dismissedView.frame; diff --git a/MyEtherWallet-iOS/Classes/PresentationLayer/Presentations/DismissingAnimationControllers/ConcreteClasses/FadeModalDismissingAnimationController/FadeModalDismissingAnimationController.m b/MyEtherWallet-iOS/Classes/PresentationLayer/Presentations/DismissingAnimationControllers/ConcreteClasses/FadeModalDismissingAnimationController/FadeModalDismissingAnimationController.m index 5cbeb12..e826343 100644 --- a/MyEtherWallet-iOS/Classes/PresentationLayer/Presentations/DismissingAnimationControllers/ConcreteClasses/FadeModalDismissingAnimationController/FadeModalDismissingAnimationController.m +++ b/MyEtherWallet-iOS/Classes/PresentationLayer/Presentations/DismissingAnimationControllers/ConcreteClasses/FadeModalDismissingAnimationController/FadeModalDismissingAnimationController.m @@ -24,7 +24,7 @@ - (void)animateTransition:(id )transitionC [toViewController beginAppearanceTransition:YES animated:[self transitionDuration:transitionContext] > 0.0]; UIView *containerView = [transitionContext containerView]; - UIView *dismissedViewSnapshot = [dismissedView snapshotViewAfterScreenUpdates:NO]; + UIView *dismissedViewSnapshot = [dismissedView snapshotViewAfterScreenUpdates:(dismissedView.window == nil)]; [containerView addSubview:dismissedViewSnapshot]; CGRect frame = dismissedView.frame; diff --git a/MyEtherWallet-iOS/Classes/PresentationLayer/Presentations/PresentationControllers/ConcreteClasses/BottomBackgroundedModalPresentationController/BottomBackgroundedModalPresentationController.m b/MyEtherWallet-iOS/Classes/PresentationLayer/Presentations/PresentationControllers/ConcreteClasses/BottomBackgroundedModalPresentationController/BottomBackgroundedModalPresentationController.m index fbc0762..03076e2 100644 --- a/MyEtherWallet-iOS/Classes/PresentationLayer/Presentations/PresentationControllers/ConcreteClasses/BottomBackgroundedModalPresentationController/BottomBackgroundedModalPresentationController.m +++ b/MyEtherWallet-iOS/Classes/PresentationLayer/Presentations/PresentationControllers/ConcreteClasses/BottomBackgroundedModalPresentationController/BottomBackgroundedModalPresentationController.m @@ -54,7 +54,7 @@ - (UIView *) presentingSnapshot { if (self.presentingViewController.presentationController.containerView != nil) { viewForSnapshot = self.presentingViewController.presentationController.containerView; } - _presentingSnapshot = [viewForSnapshot snapshotViewAfterScreenUpdates:NO]; + _presentingSnapshot = [viewForSnapshot snapshotViewAfterScreenUpdates:(viewForSnapshot.window == nil)]; _presentingSnapshot.translatesAutoresizingMaskIntoConstraints = NO; } return _presentingSnapshot; diff --git a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/BuyEtherStory/Modules/BuyEtherAmount/Interactor/BuyEtherAmountInteractor.m b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/BuyEtherStory/Modules/BuyEtherAmount/Interactor/BuyEtherAmountInteractor.m index f8add10..b3a35f9 100644 --- a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/BuyEtherStory/Modules/BuyEtherAmount/Interactor/BuyEtherAmountInteractor.m +++ b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/BuyEtherStory/Modules/BuyEtherAmount/Interactor/BuyEtherAmountInteractor.m @@ -25,6 +25,8 @@ static NSDecimalNumber *kBuyEtherMinimumUSDAmount; static NSDecimalNumber *kBuyEtherMaximumUSDAmount; +static NSDecimalNumber *kBuyEtherMidRangeFeeValue; +static NSDecimalNumber *kBuyEtherMidRangeFee; static NSString *const kBuyEtherAmountDecimalSeparator = @"."; @@ -43,6 +45,8 @@ @implementation BuyEtherAmountInteractor { + (void)initialize { kBuyEtherMinimumUSDAmount = [NSDecimalNumber decimalNumberWithString:@"50"]; kBuyEtherMaximumUSDAmount = [NSDecimalNumber decimalNumberWithString:@"20000"]; + kBuyEtherMidRangeFeeValue = [NSDecimalNumber decimalNumberWithString:@"210"]; + kBuyEtherMidRangeFee = [NSDecimalNumber decimalNumberWithString:@"0.0566"]; } #pragma mark - BuyEtherAmountInteractorInput @@ -110,16 +114,13 @@ - (void) updateEthPriceIfNeeded { - (void) switchConverting { NSDecimalNumber *convertedAmount = [self obtainConvertedAmount]; - NSDecimalNumberHandler *roundHandler = nil; switch (_currency) { case SimplexServiceCurrencyTypeETH: { _currency = SimplexServiceCurrencyTypeUSD; - roundHandler = _usdRoundHandler; break; } case SimplexServiceCurrencyTypeUSD: { _currency = SimplexServiceCurrencyTypeETH; - roundHandler = _ethRoundHandler; break; } } @@ -128,6 +129,21 @@ - (void) switchConverting { } else { [_amount replaceCharactersInRange:NSMakeRange(0, [_amount length]) withString:[convertedAmount stringValue]]; } + BOOL minimumAmountReached = NO; + switch (_currency) { + case SimplexServiceCurrencyTypeETH: { + NSDecimalNumber *enteredAmount = [self _obtainEnteredAmountNumber]; + NSDecimalNumber *convertedAmount = [self _obtainConvertedAmountWithCurrency:self.currency enteredAmount:enteredAmount]; + minimumAmountReached = [convertedAmount compare:kBuyEtherMinimumUSDAmount] != NSOrderedAscending; + break; + } + case SimplexServiceCurrencyTypeUSD: { + NSDecimalNumber *enteredAmount = [self _obtainEnteredAmountNumber]; + minimumAmountReached = [enteredAmount compare:kBuyEtherMinimumUSDAmount] != NSOrderedAscending; + break; + } + } + [self.output minimumAmountDidReached:minimumAmountReached]; } - (void) appendSymbol:(NSString *)symbol { @@ -289,18 +305,52 @@ - (NSDecimalNumber *) _obtainConvertedAmountWithCurrency:(SimplexServiceCurrency switch (currency) { case SimplexServiceCurrencyTypeETH: { convertedAmount = [enteredAmount decimalNumberByMultiplyingBy:usdPrice]; + convertedAmount = [convertedAmount decimalNumberByAdding:[self _calculateEstimatedFeeForAmount:convertedAmount]]; convertedAmount = [convertedAmount decimalNumberByRoundingAccordingToBehavior:_usdRoundHandler]; break; } case SimplexServiceCurrencyTypeUSD: default: { - convertedAmount = [enteredAmount decimalNumberByDividingBy:usdPrice]; + convertedAmount = [enteredAmount decimalNumberBySubtracting:[self _calculateEstimatedFeeForAmount:enteredAmount]]; + convertedAmount = [convertedAmount decimalNumberByDividingBy:usdPrice]; convertedAmount = [convertedAmount decimalNumberByRoundingAccordingToBehavior:_ethRoundHandler]; break; } } } + if ([convertedAmount compare:[NSDecimalNumber zero]] == NSOrderedAscending) { + convertedAmount = [NSDecimalNumber zero]; + } return convertedAmount; } +- (NSDecimalNumber *) _calculateEstimatedFeeForAmount:(NSDecimalNumber *)amount { + if ([amount compare:[NSDecimalNumber zero]] == NSOrderedSame) { + return [NSDecimalNumber zero]; + } + NSDecimalNumber *feePercent = nil; + NSDecimalNumber *correction = [NSDecimalNumber decimalNumberWithString:@"-0.03"]; + BOOL applyCorrection = NO; + if ([amount compare:kBuyEtherMidRangeFeeValue] == NSOrderedDescending) { + feePercent = kBuyEtherMidRangeFee; + } else { + applyCorrection = YES; + NSDecimalNumber *k1 = [NSDecimalNumber decimalNumberWithString:@"10"]; + NSDecimalNumber *k2 = [NSDecimalNumber decimalNumberWithString:@"-0.08"]; + NSDecimalNumber *k3 = [NSDecimalNumber decimalNumberWithString:@"0.01"]; + + NSDecimalNumber *p1 = [k1 decimalNumberByDividingBy:amount]; + NSDecimalNumber *p2 = [k2 decimalNumberByDividingBy:amount]; + + feePercent = [p1 decimalNumberByAdding:p2]; + feePercent = [feePercent decimalNumberByAdding:k3]; + } + + NSDecimalNumber *fee = [amount decimalNumberByMultiplyingBy:feePercent]; + if (applyCorrection) { + fee = [fee decimalNumberByAdding:correction]; + } + return fee; +} + @end diff --git a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/BuyEtherStory/Modules/BuyEtherAmount/View/BuyEtherAmountViewController.m b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/BuyEtherStory/Modules/BuyEtherAmount/View/BuyEtherAmountViewController.m index 3fc9ec8..72fb9f7 100644 --- a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/BuyEtherStory/Modules/BuyEtherAmount/View/BuyEtherAmountViewController.m +++ b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/BuyEtherStory/Modules/BuyEtherAmount/View/BuyEtherAmountViewController.m @@ -28,10 +28,12 @@ @interface BuyEtherAmountViewController () @property (nonatomic, weak) IBOutlet UIButton *separatorButton; @property (nonatomic, weak) IBOutlet FlatButton *buyButton; @property (nonatomic, strong) IBOutletCollection(UIButton) NSArray *keypadButtons; +@property (nonatomic, weak) IBOutlet UILabel *approximateFeeLabel; +@property (nonatomic, weak) IBOutlet UIActivityIndicatorView *priceActivityIndicator; @property (nonatomic, weak) IBOutlet NSLayoutConstraint *amountTopOffsetConstraint; @property (nonatomic, weak) IBOutlet NSLayoutConstraint *keypadToContainerTopOffsetConstraint; @property (nonatomic, weak) IBOutlet NSLayoutConstraint *buttonBottomOffsetConstraint; -@property (nonatomic, weak) IBOutlet UIActivityIndicatorView *priceActivityIndicator; +@property (nonatomic, weak) IBOutlet NSLayoutConstraint *approximateFeeTopConstraint; @end @implementation BuyEtherAmountViewController { @@ -61,11 +63,42 @@ - (UIStatusBarStyle) preferredStatusBarStyle { #pragma mark - BuyEtherAmountViewInput - (void) setupInitialStateWithCurrency:(SimplexServiceCurrencyType)currency minimumAmount:(NSDecimalNumber *)minimumAmount { - if ([UIScreen mainScreen].screenSizeType == ScreenSizeTypeInches40) { - self.amountTopOffsetConstraint.constant = -4.0; - self.keypadToContainerTopOffsetConstraint.constant = 17.0; - self.buttonBottomOffsetConstraint.constant = 22.0; + switch ([UIScreen mainScreen].screenSizeType) { + case ScreenSizeTypeInches40: { + self.amountTopOffsetConstraint.constant = -4.0; + self.keypadToContainerTopOffsetConstraint.constant = 17.0; + self.buttonBottomOffsetConstraint.constant = 22.0; + self.approximateFeeLabel.text = NSLocalizedString(@"Approx. Simplex fee included in rate", @"BuyEther. Approximate fee"); + break; + } + case ScreenSizeTypeInches47: { + self.amountTopOffsetConstraint.constant = 13.0; + break; + } + case ScreenSizeTypeInches55: { + self.amountTopOffsetConstraint.constant = 26.0; + break; + } + default: { + self.approximateFeeTopConstraint.constant = 30.0; + break; + } } + + { + NSDictionary *attributes = @{NSFontAttributeName: self.approximateFeeLabel.font, + NSForegroundColorAttributeName: self.approximateFeeLabel.textColor}; + NSMutableAttributedString *approximateString = [[NSMutableAttributedString alloc] initWithString:self.approximateFeeLabel.text + attributes:attributes]; + NSRange simplexRange = [approximateString.string rangeOfString:@"Simplex"]; + if (simplexRange.location != NSNotFound) { + [approximateString addAttribute:NSUnderlineStyleAttributeName value:@(NSUnderlineStyleSingle) range:simplexRange]; + } + + self.approximateFeeLabel.attributedText = approximateString; + } + + _currency = currency; self.amountCurrencyLabel.text = NSStringFromSimplexServiceCurrencyType(currency); @@ -114,7 +147,8 @@ - (void) updateWithEnteredAmount:(NSString *)enteredAmount convertedAmount:(NSDe self.amountLabel.text = [prefix stringByAppendingString:enteredAmount]; if (convertedAmount) { - self.resultLabel.text = [convertedFormatter stringFromNumber:convertedAmount]; + NSString *convertedAmountText = [@"≈" stringByAppendingString:[convertedFormatter stringFromNumber:convertedAmount]]; + self.resultLabel.text = convertedAmountText; } else { self.resultLabel.text = [@"— " stringByAppendingString:nullSuffix]; } diff --git a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/BuyEtherStory/Storyboard/BuyEther.storyboard b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/BuyEtherStory/Storyboard/BuyEther.storyboard index 4b1538b..12122ff 100644 --- a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/BuyEtherStory/Storyboard/BuyEther.storyboard +++ b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/BuyEtherStory/Storyboard/BuyEther.storyboard @@ -34,7 +34,7 @@ - + @@ -249,6 +249,15 @@ + @@ -264,10 +273,14 @@ + + + + @@ -289,6 +302,8 @@ + + diff --git a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/NewWallet/Assembly/NewWalletAssembly.m b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/NewWallet/Assembly/NewWalletAssembly.m index 3d3f1ed..19a3838 100644 --- a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/NewWallet/Assembly/NewWalletAssembly.m +++ b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/NewWallet/Assembly/NewWalletAssembly.m @@ -41,6 +41,8 @@ - (NewWalletInteractor *) interactorNewWallet { with:[self.serviceComponents accountsService]]; [definition injectProperty:@selector(keychainService) with:[self.serviceComponents keychainService]]; + [definition injectProperty:@selector(tokensService) + with:[self.serviceComponents tokensService]]; [definition injectProperty:@selector(ponsomizer) with:[self.ponsomizerAssembly ponsomizer]]; [definition injectProperty:@selector(connectFacade) diff --git a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/NewWallet/Interactor/NewWalletInteractor.h b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/NewWallet/Interactor/NewWalletInteractor.h index e71fe82..c529ca2 100644 --- a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/NewWallet/Interactor/NewWalletInteractor.h +++ b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/NewWallet/Interactor/NewWalletInteractor.h @@ -11,6 +11,7 @@ @protocol NewWalletInteractorOutput; @protocol AccountsService; @protocol KeychainService; +@protocol TokensService; @protocol BlockchainNetworkService; @protocol MEWwallet; @protocol Ponsomizer; @@ -21,6 +22,7 @@ @property (nonatomic, weak) id output; @property (nonatomic, strong) id accountsService; @property (nonatomic, strong) id keychainService; +@property (nonatomic, strong) id tokensService; @property (nonatomic, strong) id blockchainNetworkService; @property (nonatomic, strong) id mewWallet; @property (nonatomic, strong) id ponsomizer; diff --git a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/NewWallet/Interactor/NewWalletInteractor.m b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/NewWallet/Interactor/NewWalletInteractor.m index 993f18b..6876f60 100644 --- a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/NewWallet/Interactor/NewWalletInteractor.m +++ b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/NewWallet/Interactor/NewWalletInteractor.m @@ -14,6 +14,7 @@ #import "MEWConnectFacade.h" #import "AccountsService.h" +#import "TokensService.h" #import "KeychainService.h" #import "BlockchainNetworkService.h" #import "MEWwallet.h" @@ -34,6 +35,7 @@ - (void) createNewWalletWithPassword:(NSString *)password words:(NSArray -@property (nonatomic, weak) id output; +@property (nonatomic, weak) id output; @property (nonatomic, strong) DBZxcvbn *zxcvbn; @end diff --git a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/RestoreWallet/View/RestoreWalletViewController.m b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/RestoreWallet/View/RestoreWalletViewController.m index fe5c7ff..9b4b7cf 100644 --- a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/RestoreWallet/View/RestoreWalletViewController.m +++ b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Modules/RestoreWallet/View/RestoreWalletViewController.m @@ -8,6 +8,7 @@ @import libextobjc.EXTScope; @import UITextView_Placeholder; +@import MnemonicsView; #import "RestoreWalletViewController.h" @@ -21,14 +22,14 @@ @interface RestoreWalletViewController () @property (nonatomic, weak) IBOutlet UIBarButtonItem *nextButton; @property (nonatomic, weak) IBOutlet UILabel *titleLabel; -@property (nonatomic, weak) IBOutlet UITextView *mnemonicsTextView; +@property (nonatomic, weak) IBOutlet MnemonicsView *mnemonicsView; @property (nonatomic, weak) IBOutlet UIScrollView *scrollView; -@property (nonatomic, weak) IBOutlet NSLayoutConstraint *mnemonicsTextViewHeightConstraint; @property (nonatomic, weak) IBOutlet NSLayoutConstraint *titleTopOffsetConstraint; @end @implementation RestoreWalletViewController { CGFloat _keyboardHeight; + BOOL _keyboardWasShown; } #pragma mark - LifeCycle @@ -43,7 +44,12 @@ - (void)viewWillAppear:(BOOL)animated { [super viewWillAppear:animated]; [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardWillShow:) name:UIKeyboardWillShowNotification object:nil]; [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardWillHide:) name:UIKeyboardWillHideNotification object:nil]; - [self.mnemonicsTextView becomeFirstResponder]; + [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardWillChangeFrame:) name:UIKeyboardWillChangeFrameNotification object:nil]; +} + +- (void)viewDidAppear:(BOOL)animated { + [super viewDidAppear:animated]; + [self.mnemonicsView becomeFirstResponder]; } - (void) viewDidDisappear:(BOOL)animated { @@ -60,11 +66,8 @@ - (void) viewSafeAreaInsetsDidChange { - (void) setupInitialState { if ([UIScreen mainScreen].screenSizeType == ScreenSizeTypeInches40) { - self.mnemonicsTextViewHeightConstraint.constant = 164.0; self.titleTopOffsetConstraint.constant = 30.0; } - self.mnemonicsTextView.placeholder = NSLocalizedString(@"Words separated by spaces…", @"Restore wallet. Mnemonics placeholder"); - self.mnemonicsTextView.placeholderColor = [[UIColor lightGreyTextColor] colorWithAlphaComponent:0.5]; { //Title label NSMutableParagraphStyle *style = [[NSMutableParagraphStyle alloc] init]; style.lineSpacing = 0.0; @@ -86,13 +89,13 @@ - (void) setupInitialState { NSKernAttributeName: @(kern)}; self.titleLabel.attributedText = [[NSAttributedString alloc] initWithString:self.titleLabel.text attributes:attributes]; } - { //TextView - self.mnemonicsTextView.textContainerInset = UIEdgeInsetsMake(16.0, 11.0, 11.0, 11.0); - NSMutableParagraphStyle *style = [[NSMutableParagraphStyle alloc] init]; - style.lineSpacing = 2.0; - NSDictionary *attributes = @{NSParagraphStyleAttributeName: style, - NSFontAttributeName: self.mnemonicsTextView.font}; - self.mnemonicsTextView.typingAttributes = attributes; + { //MnemonicsView + self.mnemonicsView.layer.cornerRadius = 10.0; + self.mnemonicsView.layer.shadowColor = [UIColor blackColor].CGColor; + self.mnemonicsView.layer.shadowRadius = 20.0; + self.mnemonicsView.layer.shadowOpacity = 0.2; + self.mnemonicsView.layer.shadowOffset = CGSizeMake(0.0, 10.0); + self.mnemonicsView.clipsToBounds = NO; } } @@ -109,7 +112,7 @@ - (void) presentIncorrectMnemonicsWarning { style:UIAlertActionStyleDefault handler:^(__unused UIAlertAction * _Nonnull action) { @strongify(self); - [self.mnemonicsTextView becomeFirstResponder]; + [self.mnemonicsView becomeFirstResponder]; }]]; [self presentViewController:alert animated:YES completion:nil]; } @@ -124,30 +127,29 @@ - (IBAction) nextAction:(__unused id)sender { [self.output nextAction]; } -#pragma mark - UITextViewDelegate - -- (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(__unused NSRange)range replacementText:(__unused NSString *)text { - NSMutableParagraphStyle *style = [[NSMutableParagraphStyle alloc] init]; - style.lineSpacing = 2.0; - NSDictionary *attributes = @{NSParagraphStyleAttributeName: style, - NSFontAttributeName: self.mnemonicsTextView.font}; - textView.typingAttributes = attributes; - return YES; -} - -- (void)textViewDidChange:(UITextView *)textView { - [self.output textDidChangedAction:textView.text]; +- (IBAction) mnemonicsChangedAction:(MnemonicsView *)sender { + [self.output textDidChangedAction:sender.mnemonics]; } #pragma mark - Notifications - (void) keyboardWillShow:(NSNotification *)notification { + _keyboardWasShown = YES; CGSize keyboardSize = [notification.userInfo[UIKeyboardFrameEndUserInfoKey] CGRectValue].size; _keyboardHeight = keyboardSize.height; [self _updateScrollViewInsets]; } +- (void) keyboardWillChangeFrame:(NSNotification *)notification { + if (_keyboardWasShown) { + CGSize keyboardSize = [notification.userInfo[UIKeyboardFrameEndUserInfoKey] CGRectValue].size; + _keyboardHeight = keyboardSize.height; + [self _updateScrollViewInsets]; + } +} + - (void) keyboardWillHide:(__unused NSNotification *)notification { + _keyboardWasShown = NO; _keyboardHeight = 0.0; [self _updateScrollViewInsets]; } @@ -162,11 +164,17 @@ - (void) _updateScrollViewInsets { insets = self.scrollView.contentInset; } insets.bottom = _keyboardHeight; + if (@available(iOS 11.0, *)) { + insets.bottom -= self.view.safeAreaInsets.bottom; + } self.scrollView.contentInset = insets; UIEdgeInsets indicatorInset = self.scrollView.scrollIndicatorInsets; indicatorInset.bottom = _keyboardHeight; + if (@available(iOS 11.0, *)) { + indicatorInset.bottom -= self.view.safeAreaInsets.bottom; + } self.scrollView.scrollIndicatorInsets = indicatorInset; } diff --git a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Storyboard/Setup.storyboard b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Storyboard/Setup.storyboard index 2d5204c..218d35d 100644 --- a/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Storyboard/Setup.storyboard +++ b/MyEtherWallet-iOS/Classes/PresentationLayer/UserStories/SetupUserStory/Storyboard/Setup.storyboard @@ -1,11 +1,11 @@ - + - + @@ -30,17 +30,17 @@ - + -