Skip to content
Permalink
Browse files

first commit

  • Loading branch information...
clovisnicolas committed Jan 29, 2018
0 parents commit 24c484be6087702b037121772d0fdcfcaab63fb5
Showing with 2,519 additions and 0 deletions.
  1. +9 −0 .gitignore
  2. +3 −0 CHANGELOG.md
  3. +1 −0 LICENSE
  4. +10 −0 README.md
  5. +8 −0 android/.gitignore
  6. +42 −0 android/build.gradle
  7. +1 −0 android/gradle.properties
  8. BIN android/gradle/wrapper/gradle-wrapper.jar
  9. +6 −0 android/gradle/wrapper/gradle-wrapper.properties
  10. +160 −0 android/gradlew
  11. +90 −0 android/gradlew.bat
  12. +1 −0 android/settings.gradle
  13. +3 −0 android/src/main/AndroidManifest.xml
  14. +47 −0 android/src/main/java/flutter/plugins/contactsservice/contactsservice/Contact.java
  15. +153 −0 android/src/main/java/flutter/plugins/contactsservice/contactsservice/ContactsServicePlugin.java
  16. +57 −0 android/src/main/java/flutter/plugins/contactsservice/contactsservice/Item.java
  17. +36 −0 android/src/main/java/flutter/plugins/contactsservice/contactsservice/PostalAddress.java
  18. +58 −0 contacts_service.iml
  19. +29 −0 contacts_service_android.iml
  20. +10 −0 example/.gitignore
  21. +8 −0 example/.metadata
  22. +8 −0 example/README.md
  23. +12 −0 example/android.iml
  24. +9 −0 example/android/.gitignore
  25. +52 −0 example/android/app/build.gradle
  26. +40 −0 example/android/app/src/main/AndroidManifest.xml
  27. +14 −0 ...ndroid/app/src/main/java/flutter/plugins/contactsservice/contactsserviceexample/MainActivity.java
  28. +12 −0 example/android/app/src/main/res/drawable/launch_background.xml
  29. BIN example/android/app/src/main/res/mipmap-hdpi/ic_launcher.png
  30. BIN example/android/app/src/main/res/mipmap-mdpi/ic_launcher.png
  31. BIN example/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png
  32. BIN example/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
  33. BIN example/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
  34. +8 −0 example/android/app/src/main/res/values/styles.xml
  35. +31 −0 example/android/build.gradle
  36. +1 −0 example/android/gradle.properties
  37. BIN example/android/gradle/wrapper/gradle-wrapper.jar
  38. +6 −0 example/android/gradle/wrapper/gradle-wrapper.properties
  39. +160 −0 example/android/gradlew
  40. +90 −0 example/android/gradlew.bat
  41. +15 −0 example/android/settings.gradle
  42. +17 −0 example/contacts_service_example.iml
  43. +26 −0 example/contacts_service_example_android.iml
  44. +41 −0 example/ios/.gitignore
  45. +30 −0 example/ios/Flutter/AppFrameworkInfo.plist
  46. +1 −0 example/ios/Flutter/Debug.xcconfig
  47. +1 −0 example/ios/Flutter/Release.xcconfig
  48. +442 −0 example/ios/Runner.xcodeproj/project.pbxproj
  49. +7 −0 example/ios/Runner.xcodeproj/project.xcworkspace/contents.xcworkspacedata
  50. +93 −0 example/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme
  51. +7 −0 example/ios/Runner.xcworkspace/contents.xcworkspacedata
  52. +13 −0 example/ios/Runner/AppDelegate.swift
  53. +116 −0 example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json
  54. BIN example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@1x.png
  55. BIN example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@2x.png
  56. BIN example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@3x.png
  57. BIN example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@1x.png
  58. BIN example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@2x.png
  59. BIN example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@3x.png
  60. BIN example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@1x.png
  61. BIN example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@2x.png
  62. BIN example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@3x.png
  63. BIN example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@2x.png
  64. BIN example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@3x.png
  65. BIN example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@1x.png
  66. BIN example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@2x.png
  67. BIN example/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-83.5x83.5@2x.png
  68. +23 −0 example/ios/Runner/Assets.xcassets/LaunchImage.imageset/Contents.json
  69. BIN example/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage.png
  70. BIN example/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@2x.png
  71. BIN example/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@3x.png
  72. +5 −0 example/ios/Runner/Assets.xcassets/LaunchImage.imageset/README.md
  73. +37 −0 example/ios/Runner/Base.lproj/LaunchScreen.storyboard
  74. +26 −0 example/ios/Runner/Base.lproj/Main.storyboard
  75. +49 −0 example/ios/Runner/Info.plist
  76. +1 −0 example/ios/Runner/Runner-Bridging-Header.h
  77. +119 −0 example/lib/main.dart
  78. +59 −0 example/pubspec.yaml
  79. +29 −0 example/test/widget_test.dart
  80. +31 −0 ios/.gitignore
  81. 0 ios/Assets/.gitkeep
  82. +4 −0 ios/Classes/ContactsServicePlugin.h
  83. +8 −0 ios/Classes/ContactsServicePlugin.m
  84. +14 −0 ios/Classes/SwiftContactsServicePlugin.swift
  85. +21 −0 ios/contacts_service.podspec
  86. +60 −0 lib/contacts_service.dart
  87. +49 −0 pubspec.yaml
@@ -0,0 +1,9 @@
.DS_Store
.atom/
.idea
.packages
.pub/
build/
ios/.generated/
packages
pubspec.lock
@@ -0,0 +1,3 @@
## [0.0.1] - TODO: Add release date.

* TODO: Describe initial release.
@@ -0,0 +1 @@
TODO: Add your license here.
@@ -0,0 +1,10 @@
# contacts_service

A new Flutter plugin.

## Getting Started

For help getting started with Flutter, view our online
[documentation](http://flutter.io/).

For help on editing plugin code, view the [documentation](https://flutter.io/platform-plugins/#edit-code).
@@ -0,0 +1,8 @@
*.iml
.gradle
/local.properties
/.idea/workspace.xml
/.idea/libraries
.DS_Store
/build
/captures
@@ -0,0 +1,42 @@
group 'flutter.plugins.contactsservice.contactsservice'
version '1.0-SNAPSHOT'

buildscript {
repositories {
jcenter()
maven {
url "https://maven.google.com"
}
}

dependencies {
classpath 'com.android.tools.build:gradle:2.3.3'
}
}

rootProject.allprojects {
repositories {
jcenter()
maven {
url "https://maven.google.com"
}
}
}

apply plugin: 'com.android.library'

android {
compileSdkVersion 25
buildToolsVersion '25.0.3'

defaultConfig {
minSdkVersion 16
targetSdkVersion 25
versionCode 1
versionName "1.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}
lintOptions {
disable 'InvalidPackage'
}
}
@@ -0,0 +1 @@
org.gradle.jvmargs=-Xmx1536M
Binary file not shown.
@@ -0,0 +1,6 @@
#Fri Jun 23 08:50:38 CEST 2017
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip
@@ -0,0 +1,160 @@
#!/usr/bin/env bash

##############################################################################
##
## Gradle start up script for UN*X
##
##############################################################################

# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
DEFAULT_JVM_OPTS=""

APP_NAME="Gradle"
APP_BASE_NAME=`basename "$0"`

# Use the maximum available, or set MAX_FD != -1 to use that value.
MAX_FD="maximum"

warn ( ) {
echo "$*"
}

die ( ) {
echo
echo "$*"
echo
exit 1
}

# OS specific support (must be 'true' or 'false').
cygwin=false
msys=false
darwin=false
case "`uname`" in
CYGWIN* )
cygwin=true
;;
Darwin* )
darwin=true
;;
MINGW* )
msys=true
;;
esac

# Attempt to set APP_HOME
# Resolve links: $0 may be a link
PRG="$0"
# Need this for relative symlinks.
while [ -h "$PRG" ] ; do
ls=`ls -ld "$PRG"`
link=`expr "$ls" : '.*-> \(.*\)$'`
if expr "$link" : '/.*' > /dev/null; then
PRG="$link"
else
PRG=`dirname "$PRG"`"/$link"
fi
done
SAVED="`pwd`"
cd "`dirname \"$PRG\"`/" >/dev/null
APP_HOME="`pwd -P`"
cd "$SAVED" >/dev/null

CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar

# Determine the Java command to use to start the JVM.
if [ -n "$JAVA_HOME" ] ; then
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
# IBM's JDK on AIX uses strange locations for the executables
JAVACMD="$JAVA_HOME/jre/sh/java"
else
JAVACMD="$JAVA_HOME/bin/java"
fi
if [ ! -x "$JAVACMD" ] ; then
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi
else
JAVACMD="java"
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi

# Increase the maximum file descriptors if we can.
if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then
MAX_FD_LIMIT=`ulimit -H -n`
if [ $? -eq 0 ] ; then
if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
MAX_FD="$MAX_FD_LIMIT"
fi
ulimit -n $MAX_FD
if [ $? -ne 0 ] ; then
warn "Could not set maximum file descriptor limit: $MAX_FD"
fi
else
warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
fi
fi

# For Darwin, add options to specify how the application appears in the dock
if $darwin; then
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
fi

# For Cygwin, switch paths to Windows format before running java
if $cygwin ; then
APP_HOME=`cygpath --path --mixed "$APP_HOME"`
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
JAVACMD=`cygpath --unix "$JAVACMD"`

# We build the pattern for arguments to be converted via cygpath
ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
SEP=""
for dir in $ROOTDIRSRAW ; do
ROOTDIRS="$ROOTDIRS$SEP$dir"
SEP="|"
done
OURCYGPATTERN="(^($ROOTDIRS))"
# Add a user-defined pattern to the cygpath arguments
if [ "$GRADLE_CYGPATTERN" != "" ] ; then
OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
fi
# Now convert the arguments - kludge to limit ourselves to /bin/sh
i=0
for arg in "$@" ; do
CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option

if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
else
eval `echo args$i`="\"$arg\""
fi
i=$((i+1))
done
case $i in
(0) set -- ;;
(1) set -- "$args0" ;;
(2) set -- "$args0" "$args1" ;;
(3) set -- "$args0" "$args1" "$args2" ;;
(4) set -- "$args0" "$args1" "$args2" "$args3" ;;
(5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
(6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
(7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
(8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
(9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
esac
fi

# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules
function splitJvmOpts() {
JVM_OPTS=("$@")
}
eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS
JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME"

exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@"
@@ -0,0 +1,90 @@
@if "%DEBUG%" == "" @echo off
@rem ##########################################################################
@rem
@rem Gradle startup script for Windows
@rem
@rem ##########################################################################

@rem Set local scope for the variables with windows NT shell
if "%OS%"=="Windows_NT" setlocal

@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
set DEFAULT_JVM_OPTS=

set DIRNAME=%~dp0
if "%DIRNAME%" == "" set DIRNAME=.
set APP_BASE_NAME=%~n0
set APP_HOME=%DIRNAME%

@rem Find java.exe
if defined JAVA_HOME goto findJavaFromJavaHome

set JAVA_EXE=java.exe
%JAVA_EXE% -version >NUL 2>&1
if "%ERRORLEVEL%" == "0" goto init

echo.
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
echo.
echo Please set the JAVA_HOME variable in your environment to match the
echo location of your Java installation.

goto fail

:findJavaFromJavaHome
set JAVA_HOME=%JAVA_HOME:"=%
set JAVA_EXE=%JAVA_HOME%/bin/java.exe

if exist "%JAVA_EXE%" goto init

echo.
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
echo.
echo Please set the JAVA_HOME variable in your environment to match the
echo location of your Java installation.

goto fail

:init
@rem Get command-line arguments, handling Windowz variants

if not "%OS%" == "Windows_NT" goto win9xME_args
if "%@eval[2+2]" == "4" goto 4NT_args

:win9xME_args
@rem Slurp the command line arguments.
set CMD_LINE_ARGS=
set _SKIP=2

:win9xME_args_slurp
if "x%~1" == "x" goto execute

set CMD_LINE_ARGS=%*
goto execute

:4NT_args
@rem Get arguments from the 4NT Shell from JP Software
set CMD_LINE_ARGS=%$

:execute
@rem Setup the command line

set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar

@rem Execute Gradle
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%

:end
@rem End local scope for the variables with windows NT shell
if "%ERRORLEVEL%"=="0" goto mainEnd

:fail
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
rem the _cmd.exe /c_ return code!
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
exit /b 1

:mainEnd
if "%OS%"=="Windows_NT" endlocal

:omega
@@ -0,0 +1 @@
rootProject.name = 'contacts_service'
@@ -0,0 +1,3 @@
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="flutter.plugins.contactsservice.contactsservice">
</manifest>
@@ -0,0 +1,47 @@
package flutter.plugins.contactsservice.contactsservice;

import java.util.ArrayList;
import java.util.HashMap;

public class Contact {

Contact(String id){
this.id = id;
}

String id;
String displayName, givenName, middleName, familyName, company, jobTitle;
ArrayList<Item> emails = new ArrayList<>();
ArrayList<Item> phones = new ArrayList<>();
ArrayList<PostalAddress> postalAddresses = new ArrayList<>();

HashMap<String,Object> toMap(){
HashMap<String,Object> contactMap = new HashMap<>();
contactMap.put("displayName",displayName);
contactMap.put("givenName",givenName);
contactMap.put("middleName",middleName);
contactMap.put("familyName",familyName);
contactMap.put("company",company);
contactMap.put("jobTitle",jobTitle);

ArrayList<HashMap<String,String>> emailsMap = new ArrayList<>();
for(Item email : emails){
emailsMap.add(email.toMap());
}
contactMap.put("emails",emailsMap);

ArrayList<HashMap<String,String>> phonesMap = new ArrayList<>();
for(Item phone : phones){
phonesMap.add(phone.toMap());
}
contactMap.put("phones",phonesMap);

ArrayList<HashMap<String,String>> addressesMap = new ArrayList<>();
for(PostalAddress address : postalAddresses){
addressesMap.add(address.map);
}
contactMap.put("postalAddresses",addressesMap);

return contactMap;
}
}

0 comments on commit 24c484b

Please sign in to comment.
You can’t perform that action at this time.