* added svg, transformer to android

* base64 svgs do not load, font files do not link

* Change files

* bump package versions manually

* Change files

* upgrade react-native-svg

* Change files

* revert 'bump package versions manually'

* Change files
This commit is contained in:
Tushar Anil Masane 2021-04-08 04:59:09 +05:30 коммит произвёл GitHub
Родитель 23b0a399f1
Коммит b8f260a8b9
Не найден ключ, соответствующий данной подписи
Идентификатор ключа GPG: 4AEE18F83AFDEB23
14 изменённых файлов: 204 добавлений и 75 удалений

Просмотреть файл

@ -6,15 +6,47 @@
*/
const {getWatchFolders} = require('@uifabricshared/build-native');
const {getDefaultConfig} = require('metro-config');
module.exports = {
watchFolders: getWatchFolders(),
transformer: {
getTransformOptions: async () => ({
transform: {
experimentalImportSupport: false,
inlineRequires: false,
module.exports = (async () => {
const {
resolver: {sourceExts, assetExts},
} = await getDefaultConfig();
return {
watchFolders: getWatchFolders(),
resolver: {
// prettier-ignore
assetExts: [assetExts.filter((ext) => ext !== 'svg'), 'ttf', 'otf', 'png'],
sourceExts: [...sourceExts, 'svg'],
},
// Metro doesn't currently handle assets coming from hoisted packages within a monorepo. This is the current workaround people use
// In this case this is to ensure that the image assets that are part of logbox get loaded correctly.
server: {
enhanceMiddleware: (middleware) => {
return (req, res, next) => {
if (req.url.startsWith('/fluent-tester/src')) {
req.url = req.url.replace(
'/fluent-tester/src',
'/assets/../fluent-tester/src',
);
} else if (req.url.startsWith('/node_modules/react-native')) {
req.url = req.url.replace(
'/node_modules/react-native',
'/assets/../../node_modules/react-native',
);
}
return middleware(req, res, next);
};
},
}),
},
};
},
transformer: {
babelTransformerPath: require.resolve('react-native-svg-transformer'),
getTransformOptions: async () => ({
transform: {
experimentalImportSupport: false,
inlineRequires: false,
},
}),
},
};
})();

Просмотреть файл

@ -22,6 +22,7 @@
"@fluentui-react-native/tester": "^0.21.1",
"react": "16.13.1",
"react-native": "^0.63.4",
"react-native-svg": "^12.1.0",
"react-native-test-app": "^0.3.2"
},
"devDependencies": {
@ -34,6 +35,7 @@
"babel-jest": "^24.9.0",
"jest": "^24.9.0",
"metro-react-native-babel-preset": "^0.59.0",
"react-native-svg-transformer": "^0.14.3",
"react-test-renderer": "~16.13.1"
},
"jest": {

Просмотреть файл

@ -0,0 +1,28 @@
buildscript {
ext.kotlin_version = "1.3.72"
repositories {
google()
jcenter()
mavenCentral()
}
dependencies {
classpath "com.android.tools.build:gradle:4.0.1"
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
repositories {
maven {
// All of React Native (JS, Android binaries) is installed from npm
url "$rootDir/../../../node_modules/react-native/android"
}
maven {
// Android JSC is installed from npm
url("$rootDir/../../../node_modules/jsc-android/dist")
}
google()
jcenter()
}
}

Просмотреть файл

@ -29,8 +29,8 @@
"@fluentui-react-native/default-theme": ">=0.5.1 <1.0.0",
"@fluentui-react-native/experimental-avatar": ">=0.7.0 <1.0.0",
"@fluentui-react-native/experimental-button": "0.5.1",
"@fluentui-react-native/experimental-text": ">=0.4.1 <1.0.0",
"@fluentui-react-native/experimental-native-button": ">=0.5.3 <1.0.0",
"@fluentui-react-native/experimental-text": ">=0.4.1 <1.0.0",
"@fluentui-react-native/framework": ">=0.5.1 <1.0.0",
"@fluentui-react-native/icon": "0.4.1",
"@fluentui-react-native/interactive-hooks": ">=0.9.0 <1.0.0",
@ -42,7 +42,7 @@
"@fluentui/react-native": ">=0.23.4 <1.0.0",
"@react-native-menu/menu": "^0.1.2",
"@react-native-picker/picker": "^1.9.11",
"react-native-svg": "^11.0.0"
"react-native-svg": "12.1.0"
},
"devDependencies": {
"@office-iss/react-native-win32": "^0.63.7",

Просмотреть файл

@ -32,14 +32,15 @@ const icons: React.FunctionComponent<{}> = () => {
// d20 icon by Lonnie Tapscott, licensed under CC BY, modified to use "currentColor"
// https://thenounproject.com/search/?q=d20&i=2453700
const svgD20DataUriProps: SvgIconProps = {
uri: '',
viewBox: '25 10 50 50'
uri:
'',
viewBox: '25 10 50 50',
};
// This one doesn't get tinted because it doesn't use currentColor
const svgUriProps: SvgIconProps = {
uri: 'https://upload.wikimedia.org/wikipedia/commons/8/84/Example.svg',
viewBox: '0 0 1000 1000'
viewBox: '0 0 1000 1000',
};
const rasterRainbowSpectrumProps: RasterImageIconProps = { src: testImage };
@ -55,40 +56,39 @@ const icons: React.FunctionComponent<{}> = () => {
return (
<View>
{
showFontIcons ?
<View>
<Text>Font icons</Text>
{
// We've seen some issues getting Font Awesome to link properly on Apple platforms in the FURN test app specifically.
// This shouldn't be an issue in other apps, though, so keeping this icon Windows-only for now is an easy workaround.
// When Android support comes, the platform check can be adjusted accordingly.
Platform.OS == 'windows' ? <Icon fontSource={fontCustomFontProps} width={100} height={100} color="purple" /> : null
}
<Icon fontSource={fontBuiltInProps} width={100} height={100} color="#060" />
</View> : null
}
{
showSvgIcons ?
<View>
<Text>SVG icons</Text>
{
// TODO: Enable on iOS once we get react-native-svg-transformer working properly
Platform.OS == 'ios' ? null :
<Icon svgSource={svgProps} width={100} height={100} color="orange" />
}
<Icon svgSource={svgD20DataUriProps} width={100} height={100} color="#7a7" />
<Icon svgSource={svgUriProps} width={100} height={100} color="red" />
</View> : null
}
{
showRasterIcons ?
<View>
<Text>Raster icons</Text>
<Icon rasterImageSource={rasterRainbowSpectrumProps} width={100} height={100} color="green" />
<Icon rasterImageSource={rasterChessProps} width={100} height={100} color="blue" />
</View> : null
}
{showFontIcons ? (
<View>
<Text>Font icons</Text>
{
// We've seen some issues getting Font Awesome to link properly on Apple platforms in the FURN test app specifically.
// This shouldn't be an issue in other apps, though, so keeping this icon Windows-only for now is an easy workaround.
// When Android support comes, the platform check can be adjusted accordingly.
Platform.OS == 'windows' ? <Icon fontSource={fontCustomFontProps} width={100} height={100} color="purple" /> : null
}
<Icon fontSource={fontBuiltInProps} width={100} height={100} color="#060" />
</View>
) : null}
{showSvgIcons ? (
<View>
<Text>SVG icons</Text>
{
// TODO: Enable on iOS once we get react-native-svg-transformer working properly
Platform.OS == 'ios' ? null : <Icon svgSource={svgProps} width={100} height={100} color="orange" />
}
{
// TODO: Causes TypeError: Network request failed on Android
Platform.OS == 'android' ? null : <Icon svgSource={svgD20DataUriProps} width={100} height={100} color="#7a7" />
}
<Icon svgSource={svgUriProps} width={100} height={100} color="red" />
</View>
) : null}
{showRasterIcons ? (
<View>
<Text>Raster icons</Text>
<Icon rasterImageSource={rasterRainbowSpectrumProps} width={100} height={100} color="green" />
<Icon rasterImageSource={rasterChessProps} width={100} height={100} color="blue" />
</View>
) : null}
</View>
);
};

Просмотреть файл

@ -13,6 +13,7 @@ import { HOMEPAGE_SEPARATOR_BUTTON, SeparatorTest } from './TestComponents/Separ
import { HOMEPAGE_SVG_BUTTON, SvgTest } from './TestComponents/Svg';
import { HOMEPAGE_TEXT_BUTTON, TextTest } from './TestComponents/Text';
import { HOMEPAGE_THEME_BUTTON, ThemeTest } from './TestComponents/Theme';
import { HOMEPAGE_ICON_BUTTON, IconTest } from './TestComponents/Icon';
export const tests: TestDescription[] = [
{
@ -85,4 +86,9 @@ export const tests: TestDescription[] = [
component: SvgTest,
testPage: HOMEPAGE_SVG_BUTTON,
},
{
name: 'Icon Test',
component: IconTest,
testPage: HOMEPAGE_ICON_BUTTON,
},
];

Просмотреть файл

@ -30,11 +30,11 @@
"@fluentui-react-native/tester": "^0.21.1",
"react": "16.13.1",
"react-native": "^0.63.4",
"react-native-svg": "^11.0.0"
"react-native-svg": "12.1.0"
},
"devDependencies": {
"@office-iss/rex-win32": "0.63.22-devmain.13903.10000",
"@office-iss/react-native-win32": "^0.63.7",
"@office-iss/rex-win32": "0.63.22-devmain.13903.10000",
"@react-native-community/eslint-config": "^1.1.0",
"@rnx-kit/cli": "^0.0.3",
"@types/jasmine": "3.5.10",
@ -42,6 +42,15 @@
"@types/react-native": "^0.63.0",
"@uifabricshared/build-native": "^0.1.1",
"@uifabricshared/eslint-config-rules": "^0.1.1",
"@wdio/allure-reporter": "5.22.4",
"@wdio/appium-service": "5.18.2",
"@wdio/cli": "5.23.0",
"@wdio/jasmine-framework": "5.18.6",
"@wdio/local-runner": "5.23.0",
"@wdio/spec-reporter": "5.22.4",
"@wdio/sync": "5.20.1",
"allure-commandline": "2.13.0",
"appium": "1.17.1",
"metro-config": "^0.58.0",
"metro-react-native-babel-preset": "^0.59.0",
"react-native-svg-transformer": "^0.14.3",
@ -49,16 +58,7 @@
"ts-node": "^8.10.1",
"tsconfig-paths": "^3.9.0",
"typescript": "3.8.3",
"allure-commandline": "2.13.0",
"appium": "1.17.1",
"webdriverio": "5.22.4",
"@wdio/allure-reporter": "5.22.4",
"@wdio/appium-service": "5.18.2",
"@wdio/cli": "5.23.0",
"@wdio/jasmine-framework": "5.18.6",
"@wdio/local-runner": "5.23.0",
"@wdio/spec-reporter": "5.22.4",
"@wdio/sync": "5.20.1"
"webdriverio": "5.22.4"
},
"peerDependencies": {
"react": "16.13.1",

Просмотреть файл

@ -0,0 +1,8 @@
{
"type": "patch",
"comment": "upgrade react-native-svg",
"packageName": "@fluentui/react-native",
"email": "tamasane@gmail.com",
"dependentChangeType": "patch",
"date": "2021-04-07T22:56:51.842Z"
}

Просмотреть файл

@ -0,0 +1,8 @@
{
"type": "patch",
"comment": "upgrade react-native-svg",
"packageName": "@fluentui-react-native/android-theme",
"email": "tamasane@gmail.com",
"dependentChangeType": "patch",
"date": "2021-04-07T22:57:08.820Z"
}

Просмотреть файл

@ -0,0 +1,8 @@
{
"type": "patch",
"comment": "Add the rainbow gradient border image test case to experimental avatar (#654)",
"packageName": "@fluentui-react-native/experimental-avatar",
"email": "tamasane@gmail.com",
"dependentChangeType": "patch",
"date": "2021-04-07T22:56:31.314Z"
}

Просмотреть файл

@ -0,0 +1,8 @@
{
"type": "patch",
"comment": "Update Radio Button focus border style to be WCAG 2.1 compliant (#653)",
"packageName": "@fluentui-react-native/radio-group",
"email": "tamasane@gmail.com",
"dependentChangeType": "patch",
"date": "2021-04-07T22:56:22.212Z"
}

Просмотреть файл

@ -0,0 +1,8 @@
{
"type": "minor",
"comment": "added svg, transformer to android",
"packageName": "@fluentui-react-native/tester",
"email": "tamasane@gmail.com",
"dependentChangeType": "patch",
"date": "2021-04-01T08:11:56.684Z"
}

Просмотреть файл

@ -0,0 +1,8 @@
{
"type": "patch",
"comment": "upgrade react-native-svg",
"packageName": "@fluentui-react-native/tester-win32",
"email": "tamasane@gmail.com",
"dependentChangeType": "patch",
"date": "2021-04-05T09:36:01.397Z"
}

Просмотреть файл

@ -6236,7 +6236,7 @@ css-tree@1.0.0-alpha.37:
mdn-data "2.0.4"
source-map "^0.6.1"
css-tree@1.0.0-alpha.39, css-tree@^1.0.0-alpha.39:
css-tree@1.0.0-alpha.39:
version "1.0.0-alpha.39"
resolved "https://registry.yarnpkg.com/css-tree/-/css-tree-1.0.0-alpha.39.tgz#2bff3ffe1bb3f776cf7eefd91ee5cba77a149eeb"
integrity sha512-7UvkEYgBAHRG9Nt980lYxjsTrCyHFN53ky3wVsDkiMdVqylqRt+Zc+jm5qw7/qyOvN2dHSYtX0e4MbCCExSvnA==
@ -6244,6 +6244,14 @@ css-tree@1.0.0-alpha.39, css-tree@^1.0.0-alpha.39:
mdn-data "2.0.6"
source-map "^0.6.1"
css-tree@^1.0.0-alpha.39:
version "1.1.3"
resolved "https://registry.yarnpkg.com/css-tree/-/css-tree-1.1.3.tgz#eb4870fb6fd7707327ec95c2ff2ab09b5e8db91d"
integrity sha512-tRpdppF7TRazZrjJ6v3stzv93qxRcSsFmW6cX0Zm2NVKpxE1WV1HblnghVv9TreireHkqI/VDEsfolRF1p6y7Q==
dependencies:
mdn-data "2.0.14"
source-map "^0.6.1"
css-value@^0.0.1:
version "0.0.1"
resolved "https://registry.yarnpkg.com/css-value/-/css-value-0.0.1.tgz#5efd6c2eea5ea1fd6b6ac57ec0427b18452424ea"
@ -6255,9 +6263,9 @@ css-what@2.1:
integrity sha512-a+EPoD+uZiNfh+5fxw2nO9QwFa6nJe2Or35fGY6Ipw1R3R4AGz1d1TEZrCegvw2YTmZ0jXirGYlzxxpYSHwpEg==
css-what@^3.2.1:
version "3.2.1"
resolved "https://registry.yarnpkg.com/css-what/-/css-what-3.2.1.tgz#f4a8f12421064621b456755e34a03a2c22df5da1"
integrity sha512-WwOrosiQTvyms+Ti5ZC5vGEK0Vod3FTt1ca+payZqvKuGJF+dq7bG63DstxtN0dpm6FxY27a/zS3Wten+gEtGw==
version "3.4.2"
resolved "https://registry.yarnpkg.com/css-what/-/css-what-3.4.2.tgz#ea7026fcb01777edbde52124e21f327e7ae950e4"
integrity sha512-ACUm3L0/jiZTqfzRM3Hi9Q8eZqd6IK37mMWPLz9PJxkLWllYeRf+EHUSHYEtFop2Eqytaq1FizFVh7XfBnXCDQ==
csso@^4.0.2:
version "4.0.3"
@ -6822,9 +6830,9 @@ domelementtype@1, domelementtype@^1.3.0, domelementtype@^1.3.1:
integrity sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==
domelementtype@^2.0.1:
version "2.0.1"
resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-2.0.1.tgz#1f8bdfe91f5a78063274e803b4bdcedf6e94f94d"
integrity sha512-5HOHUDsYZWV8FGWN0Njbr/Rn7f/eWSQi1v7+HsUVwXgn8nWWlL64zKDkS0n8ZmQ3mlWOMuXOnR+7Nx/5tMO5AQ==
version "2.2.0"
resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-2.2.0.tgz#9a0b6c2782ed6a1c7323d42267183df9bd8b1d57"
integrity sha512-DtBMo82pv1dFtUmHyr48beiuq792Sxohr+8Hm9zoxklYPfa6n0Z3Byjj2IV7bmr2IyqClnqEQhfgHJJ5QF0R5A==
domexception@^1.0.1:
version "1.0.1"
@ -7037,9 +7045,9 @@ entities@^1.1.1, entities@~1.1.1:
integrity sha512-f2LZMYl1Fzu7YSBKg+RoROelpOaNrcGmE9AZubeDfrCEia483oW4MI4VyFd5VNHIgQ/7qm1I0wUHK1eJnn2y2w==
entities@^2.0.0:
version "2.0.2"
resolved "https://registry.yarnpkg.com/entities/-/entities-2.0.2.tgz#ac74db0bba8d33808bbf36809c3a5c3683531436"
integrity sha512-dmD3AvJQBUjKpcNkoqr+x+IF0SdRtPz9Vk0uTy4yWqga9ibB6s4v++QFWNohjiUGoMlF552ZvNyXDxz5iW0qmw==
version "2.2.0"
resolved "https://registry.yarnpkg.com/entities/-/entities-2.2.0.tgz#098dc90ebb83d8dffa089d55256b351d34c4da55"
integrity sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==
env-variable@0.0.x:
version "0.0.6"
@ -11490,6 +11498,11 @@ md5@^2.2.1:
crypt "~0.0.1"
is-buffer "~1.1.1"
mdn-data@2.0.14:
version "2.0.14"
resolved "https://registry.yarnpkg.com/mdn-data/-/mdn-data-2.0.14.tgz#7113fc4281917d63ce29b43446f701e68c25ba50"
integrity sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow==
mdn-data@2.0.4:
version "2.0.4"
resolved "https://registry.yarnpkg.com/mdn-data/-/mdn-data-2.0.4.tgz#699b3c38ac6f1d728091a64650b65d388502fd5b"
@ -13968,10 +13981,10 @@ react-native-svg-transformer@^0.14.3:
path-dirname "^1.0.2"
semver "^5.6.0"
react-native-svg@^11.0.0:
version "11.0.1"
resolved "https://registry.yarnpkg.com/react-native-svg/-/react-native-svg-11.0.1.tgz#e92e7e9f9cb2604333fd5014fd4edcf62fea6496"
integrity sha512-XriIwSoe9eTtKyqxpNC6POSOqmXAB9mZQOm5tMoaimEqQOMfzgYrBoF9nY6VPGmaH5dRlWBqnnBf389APiZFcQ==
react-native-svg@12.1.0, react-native-svg@^12.1.0:
version "12.1.0"
resolved "https://registry.yarnpkg.com/react-native-svg/-/react-native-svg-12.1.0.tgz#acfe48c35cd5fca3d5fd767abae0560c36cfc03d"
integrity sha512-1g9qBRci7man8QsHoXn6tP3DhCDiypGgc6+AOWq+Sy+PmP6yiyf8VmvKuoqrPam/tf5x+ZaBT2KI0gl7bptZ7w==
dependencies:
css-select "^2.1.0"
css-tree "^1.0.0-alpha.39"