device_region 1.4.0 copy "device_region: ^1.4.0" to clipboard
device_region: ^1.4.0 copied to clipboard

This plugin uses platform-specific API to return SIM country code

device_region #

A Flutter plugin which uses platform-specific API to return a SIM country code. Supports iOS and Android.

Installation #

In your Flutter project, in pubspec.yaml file add the dependency:

dependencies:
  device_region: ^1.3.0

Usage example #

Import device_region.dart package.

import 'package:device_region/device_region.dart';

Get SIM country code #

Call getSIMCountryCode method to receive SIM country code.

await DeviceRegion.getSIMCountryCode();

Android:

Using TelephonyManager class:

Returns simCountryIso if available. Otherwise, it should return networkCountryIso.

In case the value cannot be retrieved or an error occurs, null value will be returned

iOS:

iOS 16.0 and higher

Due to deprecated properties in CTTelephonyNetworkInfo class, plugin uses Locale class and returns Locale.current.region.identifier.

iOS up to 16.0

Using CTTelephonyNetworkInfo class:

Returns isoCountryCode if available.

In case the value cannot be retrieved or an error occurs, null value will be returned

Important notes #

  • While call getSIMCountryCode on iOS (up to 16.0), it returns proper country code and can throw error log in debugger as below:
[Client] Updating selectors after delegate addition failed with: Error Domain=NSCocoaErrorDomain Code=4099 "The connection to service with pid 91 named com.apple.commcenter.coretelephony.xpc was invalidated from this process." UserInfo={NSDebugDescription=The connection to service with pid 91 named com.apple.commcenter.coretelephony.xpc was invalidated from this process.}

It's well known bug on iOS and it does not affect the operation of the application.

  • Method returns null in case if for some reason it was not possible to retrieve the information from the SIM slot. So it will return null i.e on iOS simulators and devices without SIM card inserted.

  • On iOS, it only works from 12.0 and above. For lower versions it will return null.

21
likes
160
points
5.49k
downloads

Publisher

verified publishermatszafraniec.xyz

Weekly Downloads

This plugin uses platform-specific API to return SIM country code

Repository (GitHub)
View/report issues

Documentation

API reference

License

MIT (license)

Dependencies

flutter

More

Packages that depend on device_region