Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
21 changes: 12 additions & 9 deletions src/components/TestDrive/Modal/EmployeeTestDriveModal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -48,9 +48,11 @@ function EmployeeTestDriveModal() {

setIsLoading(true);

verifyTestDriveRecipient(bossEmail)
.then(() => {
setTestReceipt(TestReceipt, 'jpg', (source, _, filename) => {
verifyTestDriveRecipient(bossEmail).then(() => {
setTestReceipt(
TestReceipt,
'jpg',
(source, _, filename) => {
const transactionID = CONST.IOU.OPTIMISTIC_TRANSACTION_ID;
const reportID = generateReportID();
initMoneyRequest(reportID, undefined, false, undefined, CONST.IOU.REQUEST_TYPE.SCAN);
Expand All @@ -75,12 +77,13 @@ function EmployeeTestDriveModal() {
Navigation.goBack();
Navigation.navigate(ROUTES.MONEY_REQUEST_STEP_CONFIRMATION.getRoute(CONST.IOU.ACTION.CREATE, CONST.IOU.TYPE.SUBMIT, transactionID, reportID));
});
});
})
.catch(() => {
setIsLoading(false);
setFormError(translate('testDrive.modal.employee.error'));
});
},
() => {
setIsLoading(false);
setFormError(translate('testDrive.modal.employee.error'));
},
);
});
};

const skipTestDrive = () => {
Expand Down
12 changes: 12 additions & 0 deletions src/libs/actions/setTestReceipt/getFile/index.ios.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
import ReactNativeBlobUtil from 'react-native-blob-util';
import type GetFile from './types';

const getFile: GetFile = (source, path, assetExtension) => {
return ReactNativeBlobUtil.config({
fileCache: true,
appendExt: assetExtension,
path,
}).fetch('GET', source);
};

export default getFile;
19 changes: 19 additions & 0 deletions src/libs/actions/setTestReceipt/getFile/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
import ReactNativeBlobUtil from 'react-native-blob-util';
import RNFS from 'react-native-fs';
import CONFIG from '@src/CONFIG';
import CONST from '@src/CONST';
import type GetFile from './types';

const getFile: GetFile = (source, path, assetExtension) => {
if (CONFIG.ENVIRONMENT === CONST.ENVIRONMENT.DEV) {
return ReactNativeBlobUtil.config({
fileCache: true,
appendExt: assetExtension,
path,
}).fetch('GET', source);
}

return RNFS.copyFileRes(`${source}.${assetExtension}`, path);
};

export default getFile;
6 changes: 6 additions & 0 deletions src/libs/actions/setTestReceipt/getFile/types.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
import type {FetchBlobResponse} from 'react-native-blob-util';
import type {AssetExtension} from '@userActions/setTestReceipt/types';

type GetFile = (source: string, path: string, assetExtension: AssetExtension) => Promise<FetchBlobResponse | void>;

export default GetFile;
54 changes: 24 additions & 30 deletions src/libs/actions/setTestReceipt/index.native.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,41 +3,35 @@ import ReactNativeBlobUtil from 'react-native-blob-util';
import type {FileObject} from '@components/AttachmentModal';
import Log from '@libs/Log';
import CONST from '@src/CONST';
import getFile from './getFile';
import type {SetTestReceipt} from './types';

const setTestReceipt: SetTestReceipt = (asset, assetExtension, onFileRead) => {
try {
const filename = `${CONST.TEST_RECEIPT.FILENAME}_${Date.now()}.${assetExtension}`;
const path = `${ReactNativeBlobUtil.fs.dirs.CacheDir}/${filename}`;
const source = Image.resolveAssetSource(asset).uri;
const setTestReceipt: SetTestReceipt = (asset, assetExtension, onFileRead, onFileError) => {
const filename = `${CONST.TEST_RECEIPT.FILENAME}_${Date.now()}.${assetExtension}`;
const path = `${ReactNativeBlobUtil.fs.dirs.CacheDir}/${filename}`;
const source = Image.resolveAssetSource(asset).uri;

ReactNativeBlobUtil.config({
fileCache: true,
appendExt: assetExtension,
path,
})
.fetch('GET', source)
.then(() => {
const file: FileObject = {
uri: `file://${path}`,
name: filename,
type: CONST.TEST_RECEIPT.FILE_TYPE,
size: 0,
};
getFile(source, path, assetExtension)
.then(() => {
const file: FileObject = {
uri: `file://${path}`,
name: filename,
type: CONST.TEST_RECEIPT.FILE_TYPE,
size: 0,
};

if (!file.uri) {
Log.warn('Error reading test receipt');
return;
}

if (!file.uri) {
Log.warn('Error reading test receipt');
return;
}
onFileRead(file.uri, file, filename);
})
.catch((error) => {
Log.warn('Error reading test receipt:', {message: error});

onFileRead(file.uri, file, filename);
})
.catch((error) => {
Log.warn('Error reading test receipt:', {message: error});
});
} catch (error) {
Log.warn('Error in setTestReceipt:', {message: error});
}
onFileError?.(error);
});
};

export default setTestReceipt;
34 changes: 16 additions & 18 deletions src/libs/actions/setTestReceipt/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,25 +3,23 @@ import Log from '@libs/Log';
import CONST from '@src/CONST';
import type {SetTestReceipt} from './types';

const setTestReceipt: SetTestReceipt = (asset, assetExtension, onFileRead) => {
try {
const filename = `${CONST.TEST_RECEIPT.FILENAME}_${Date.now()}.${assetExtension}`;
readFileAsync(
asset as string,
filename,
(file) => {
const source = URL.createObjectURL(file);
const setTestReceipt: SetTestReceipt = (asset, assetExtension, onFileRead, onFileError) => {
const filename = `${CONST.TEST_RECEIPT.FILENAME}_${Date.now()}.${assetExtension}`;
readFileAsync(
asset as string,
filename,
(file) => {
const source = URL.createObjectURL(file);

onFileRead(source, file, filename);
},
(error) => {
Log.warn('Error reading test receipt:', {message: error});
},
CONST.TEST_RECEIPT.FILE_TYPE,
);
} catch (error) {
Log.warn('Error in setTestReceipt:', {message: error});
}
onFileRead(source, file, filename);
},
(error) => {
Log.warn('Error reading test receipt:', {message: error});

onFileError?.(error);
},
CONST.TEST_RECEIPT.FILE_TYPE,
);
};

export default setTestReceipt;
9 changes: 5 additions & 4 deletions src/libs/actions/setTestReceipt/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,10 @@ import type {FileObject} from '@components/AttachmentModal';

type OnFileRead = (source: string, file: FileObject, filename: string) => void;

type ReceiptExtension = 'jpg' | 'png';
type OnFileError = (error: unknown) => void;

type SetTestReceipt = (asset: ImageSourcePropType, assetExtension: ReceiptExtension, onFileRead: OnFileRead) => void;
type AssetExtension = 'jpg' | 'png';

// eslint-disable-next-line import/prefer-default-export
export type {SetTestReceipt};
type SetTestReceipt = (asset: ImageSourcePropType, assetExtension: AssetExtension, onFileRead: OnFileRead, onFileError?: OnFileError) => void;

export type {AssetExtension, SetTestReceipt};