IT 86

안드로이드 앱에서 READ_MEDIA_* 권한을 받고 있다면

무려 구글 플레이스토어 심사에서 2번이나 리젝 된 후기15일에 심사를 제출하고, 17일에 건강 앱 관련 선언 수정이 필요하여 수정 후 다시 제출을 했다.금방 될 줄 알았는데 소식이 없길래 혹시나 하고 다시 확인해 봤더니새로운 문제가 생겼었다   android.permission.READ_MEDIA_IMAGESandroid.permission.READ_MEDIA_VIDEO 앱에서 사진 및 동영상에 일회성으로 또는 빈번하지 않게 액세스해야 하는 경우 Android 사진 선택 도구 또는 원하는 사진 선택 도구로 이전하세요. 앱에서 사진 및 동영상에 자주 액세스해야 하는 경우 이 권한을 사용하기 위한 요구사항을 충족한다고 생각하는 이유를 알려주세요. Google Play의 사진 및 동영상 권한 정책에 관해 자세..

IT 2024.10.21

eas update not working : Cannot find module

✖ Export failed Error: Cannot find module 'expo/bin/cli.js' Require stack: - /Users/username/Desktop Export failed Error: Cannot find module 'expo/bin/cli.js' Require stack: - /Users/username/Desktop expo eas update를 하려고 하니 갑자기 이런 에러가 발생하며 eas update가 실행되지 않았다구글링을 해봤을 땐 모두 npm reinstall에 대한 얘기만 하고 있어서 따라 해보니 효과는 전혀 없었다 이전에 유튜브 영상을 봤던 것이 기억났다 (아마도 제로초 유튜브였던 것으로 기억)에러 메시지를 무작정 복사해서 구글링하기 ..

IT 2023.12.15

Nextjs Image태그 관련 에러 핸들링

nextjs의 Image 태그를 사용하며 겪은 에러 핸들링에 관한 기록을 남겨보려 한다 1. 정적 이미지 Image src로 사용할 경우 Unhandled Runtime ErrorError: Failed to parse src '이미지 파일명' on `next/image`, if using relative image it must start with a leading slash "/" or be an absolute URL (http:// or https://)  Image 태그에 src로 들어가는 파일명이 'image.png' 이런 형식이었는데,정적 이미지를 사용할 땐 앞에 / 표시를 붙이거나 상대적인 url이 필요하다는 에러였다. 기존의 Image 태그에는data?.image 였다면이를 템플릿레터럴을..

IT 2023.04.22

[css] padding 값만큼 scroll 더 이동시키기 (부모 컴포넌트까지 스크롤 이동을 원한다면)

모달 UI 작업하다 발견 한 획기적인 scroll css라 생각하여 정리를 해둬야겠다. 모달 컴포넌트 내부에는 모달 콘텐츠 컴포넌트가 존재한다.모달 콘텐츠 컴포넌트 하위에 존재하는 버튼을 클릭하면 스크롤은 부모인 모달 컴포넌트의 최상단까지 올라가야 했다. 기존의 로직에서 버튼과 같은 클릭 요소에 이벤트를 주어 스크롤을 내가 원하는 곳에 위치 시키려면버튼에는 스크롤 관련 이벤트를, 스크롤을 위치 시키고 싶은 곳에는 특정 Id를 주면 가능했다.  // scroll 아이디가 존재하는 element로 스크롤 위치를 이동시켜준다 const handleClickScroll = () => { const element = document.getElementById('scroll') if (element) {..

IT 2023.04.14

[github] 삭제된 브랜치에 branch PR 날리기

A 브랜치에서 작업 후 첫 PR을 날렸고 A 브랜치로 돌아와 재작업을 진행했다. 그러던 중 A 브랜치와 develop 브랜치 merge 후, 원격에선 A 브랜치가 삭제된 상황 원래 pr을 날리면, github 상단에 pr 날리는 배너가 생겨서 클릭만 하면 쉽게 pr을 날릴 수 있는데 이번엔 push를 하여도 배너가 자동으로 생기지 않았다. 삭제된 브랜치를 push 하여도  github에 pr 배너가 뜨지 않는다면   1. New pull request 버튼을 눌러준다  2. develop 브랜치로 pr을 날릴 브랜치를 직접 선택해준다  3. create pull request를 클릭하면 정상적으로 pr을 날릴 수 있다

IT 2023.04.13

expo dev client와 eas build 사용하기

npm i expo-dev-client위의 명령어를 통해 expo-dev-client 설치 expo development client는기존의 expo go와 동일한 사용 경험을 제공하지만, 각 커스텀 된 런타임 환경 구성이 가능하다.    npx expo start --dev-client 설치 후, expo를 실행한다  It looks like you're trying to use web support but don't have the required dependencies installed.Please install @expo/webpack-config@^0.17.2 by running: 웹에서도 띄우려 했더니 이런 에러가 발생하여 @expo/webpack-config@^0.17.2 을 설치했다 그리고..

IT 2023.02.12

[Git] 모두를 위한 깃 커밋 단위 쪼개기

나의 기존 커밋 단위는 업무 중 흐름에 따른 커밋이었다. (feat. 의식의 흐름에 내 커밋을 맡긴다)커밋 내역에는 A.파일추가와 B.구조변경, C.새로 추가 한 비즈니스 로직이 뒤엉켜있었다C.새로 추가 한 비즈니스 로직이 완성된 후, 변경사항에는 A,B,C 파일의 변경 사항이 존재하였고A와 B는 고려하지 않고, 현재 커밋을 하는 주 목적은 C라고 생각하였다그래서 대략 '기능 추가'라는 메시지가 담긴 커밋을 하였다. 이때까지만 해도 이것이 문제상황이라는 것을인식하지 못했다고 한다..팀원과 협업 중, 내가 완전히 잘못된 커밋을 하고 있다는 것을 알게 된 계기가 있었다공통 프로젝트에서 하나의 라이브러리를 설치했는데 팀원에게도 이 라이브러리가 필요했던 것.나에게 커밋을 부탁하였고, 나는 별생각 없이 이전 작업..

IT 2023.02.11

ReactNative expo-cli 시작하기. 시작이 반이다. 고로 오늘 반을 끝냈다

이전에는 간단한 앱 개발을 react-native cli로만 조금씩 경험을 해봤었다현 회사 앱 개발이 expo-cli로 되어있는데, 예전의 expo-cli의 단점이 많이 사라졌다고 한다.이번 기회에 expo-cli 개발 환경에 익숙해져 보자 (= 아마도 회사 업무 조금 더 수월해지지 않을까 하는 마음)는 기대감을 갖고!  이번 출시를 목표로 두고 있는 사이드 프로젝트 앱 개발을 expo-cli로 도전해보려한다.  01. expo-cli 설치 yarn add expo-cli명령어를 통하여 우선 expo-cli를 설치해 준다.  expo-cli를 설치했다면npx expo init 을 입력하여, expo-cli 프로젝트를 생성해 준다  02. expo 공식 사이트 가입 및 설정  expo 공식 사이트에 들어가..

IT 2023.02.05

AWS는 왜 계속 내 만원을 가져가나.. (Feat. 탄력적 IP 삭제)

취준 기간 동안 만들었던 웹 프로젝트의 모든 AWS 세팅을 삭제했었다이후에 확인해 보니 AWS에서 매달 내 만원이 줄줄이 세어 나가고 있는 것을 발견하였다 (...)인스턴스를 삭제했기 때문에, 가장 유력한 건 EC2 탄력적 IP였다   [AWS] -> [EC2] -> [탄력적 IP 주소]아무것도 없다고 생각했는데, 내 현주소가 '미국 동부'로 되어 있어서 보이지 않았던 것이다 흑흑다시 서울로 선택하니 그제야 탄력적 IP 주소가 보였다      오른쪽 상단의 작업 버튼을 클릭하여 '탄력적 IP 주소 릴리스'를 선택하면 탄력적 IP가 완전히 삭제된다이제 내 만원을 지킬 수 있다 🥲  ⚠️ 탄력적 IP 사용은 비용이 따로 들지 않지만,연결 한 인스턴스를 사용하지 않을 때(인스턴스 중지/삭제) 요금이 청구된다..

IT 2023.01.29

Nextjs useEffect안의 router query가 빈값으로 나올 때

localStorage는 저장, 변경, 삭제 등 모든 동작이 동기적으로 실행된다.URL의 쿼리스트링으로 존재하는 code를 nextjs의 router.query 를 객체구조분해를 이용하여 가져왔다이후 useEffect가 실행될 때 쿼리스트링의 code 키,값을 가져와서 localStorage에 저장하려는 의도였다 예상과 달리, localStorage에 값이 들어가지 않아 useEffect안에 router.query를 콘솔로 찍어보니빈 객체 { } 가 출력되었다 이는 nextjs에서 정적으로 최적화된 페이지는 루트 매개 변수가 제공되지 않아 query값을 콘솔에 찍어도빈 객체로 나오기 때문이었다 (= 정적 파일 최적화)   Next.js@10.0.5 이후 버전router.isReady라우터 필드가 클라이언..

IT 2023.01.19
반응형