diff --git a/android/app/build.gradle b/android/app/build.gradle index f672a69..0874adf 100644 --- a/android/app/build.gradle +++ b/android/app/build.gradle @@ -100,7 +100,7 @@ packagingOptions { applicationId 'com.bip.hipmimobileapp' minSdkVersion rootProject.ext.minSdkVersion targetSdkVersion rootProject.ext.targetSdkVersion - versionCode 2 + versionCode 3 versionName "1.0.1" buildConfigField "String", "REACT_NATIVE_RELEASE_LEVEL", "\"${findProperty('reactNativeReleaseLevel') ?: 'stable'}\"" diff --git a/app.config.js b/app.config.js index f8becda..65702a1 100644 --- a/app.config.js +++ b/app.config.js @@ -19,7 +19,7 @@ export default { "NSLocationWhenInUseUsageDescription": "Aplikasi membutuhkan akses lokasi untuk menampilkan peta.", }, associatedDomains: ["applinks:cld-dkr-staging-hipmi.wibudev.com"], - buildNumber: "12", + buildNumber: "13", }, android: { @@ -30,7 +30,7 @@ export default { }, edgeToEdgeEnabled: true, package: "com.bip.hipmimobileapp", - versionCode: 2, + versionCode: 3, // softwareKeyboardLayoutMode: 'resize', // option: untuk mengatur keyboard pada room chst collaboration intentFilters: [ { diff --git a/app/(application)/(user)/forum/[id]/edit.tsx b/app/(application)/(user)/forum/[id]/edit.tsx index 096ab5c..50da5f5 100644 --- a/app/(application)/(user)/forum/[id]/edit.tsx +++ b/app/(application)/(user)/forum/[id]/edit.tsx @@ -5,9 +5,12 @@ import { TextAreaCustom, ViewWrapper, } from "@/components"; +import AlertWarning from "@/components/Alert/AlertWarning"; import { apiForumGetOne, apiForumUpdate } from "@/service/api-client/api-forum"; +import { isBadContent } from "@/utils/badWordsIndonesia"; import { router, useFocusEffect, useLocalSearchParams } from "expo-router"; import { useCallback, useState } from "react"; +import { Alert } from "react-native"; import Toast from "react-native-toast-message"; export default function ForumEdit() { @@ -43,6 +46,12 @@ export default function ForumEdit() { }); return; } + + if (isBadContent(text)) { + AlertWarning({}); + return; + } + try { setIsLoading(true); const response = await apiForumUpdate({ diff --git a/app/(application)/(user)/forum/[id]/index.tsx b/app/(application)/(user)/forum/[id]/index.tsx index 1759e6d..3b10343 100644 --- a/app/(application)/(user)/forum/[id]/index.tsx +++ b/app/(application)/(user)/forum/[id]/index.tsx @@ -7,6 +7,7 @@ import { TextCustom, ViewWrapper, } from "@/components"; +import AlertWarning from "@/components/Alert/AlertWarning"; import { useAuth } from "@/hooks/use-auth"; import Forum_CommentarBoxSection from "@/screens/Forum/CommentarBoxSection"; import Forum_BoxDetailSection from "@/screens/Forum/DiscussionBoxSection"; @@ -18,9 +19,11 @@ import { apiForumGetOne, apiForumUpdateStatus, } from "@/service/api-client/api-forum"; +import { isBadContent } from "@/utils/badWordsIndonesia"; import { useFocusEffect, useLocalSearchParams } from "expo-router"; import _ from "lodash"; import { useCallback, useEffect, useState } from "react"; +import { Alert } from "react-native"; interface CommentProps { id: string; @@ -110,11 +113,15 @@ export default function ForumDetail() { // Create Commentar const handlerCreateCommentar = async () => { + if (isBadContent(text)) { + AlertWarning({}); + return; + } + const newData = { comment: text, authorId: user?.id, }; - try { setLoadingComment(true); const response = await apiForumCreateComment({ diff --git a/app/(application)/(user)/forum/create.tsx b/app/(application)/(user)/forum/create.tsx index 07396e1..8599bbf 100644 --- a/app/(application)/(user)/forum/create.tsx +++ b/app/(application)/(user)/forum/create.tsx @@ -2,12 +2,15 @@ import { BoxButtonOnFooter, ButtonCustom, TextAreaCustom, - ViewWrapper, + ViewWrapper } from "@/components"; +import AlertWarning from "@/components/Alert/AlertWarning"; import { useAuth } from "@/hooks/use-auth"; import { apiForumCreate } from "@/service/api-client/api-forum"; +import { isBadContent } from "@/utils/badWordsIndonesia"; import { router } from "expo-router"; import { useState } from "react"; +import { Alert } from "react-native"; import Toast from "react-native-toast-message"; export default function ForumCreate() { @@ -16,11 +19,16 @@ export default function ForumCreate() { const [isLoading, setIsLoading] = useState(false); const handlerSubmit = async () => { + + if (isBadContent(text)) { + AlertWarning({}) + return; + } + const newData = { diskusi: text, authorId: user?.id, }; - try { setIsLoading(true); const response = await apiForumCreate({ data: newData }); diff --git a/app/(application)/admin/donation/[id]/[status]/index.tsx b/app/(application)/admin/donation/[id]/[status]/index.tsx index 86e4ef0..d866f9b 100644 --- a/app/(application)/admin/donation/[id]/[status]/index.tsx +++ b/app/(application)/admin/donation/[id]/[status]/index.tsx @@ -18,7 +18,7 @@ import { IconDot, IconList } from "@/components/_Icon/IconComponent"; import AdminBackButtonAntTitle from "@/components/_ShareComponent/Admin/BackButtonAntTitle"; import AdminButtonReject from "@/components/_ShareComponent/Admin/ButtonReject"; import AdminButtonReview from "@/components/_ShareComponent/Admin/ButtonReview"; -import { GridDetail_4_8 } from "@/components/_ShareComponent/GridDetail_4_8"; +import { GridSpan_4_8 } from "@/components/_ShareComponent/GridSpan_4_8"; import ReportBox from "@/components/Box/ReportBox"; import { ICON_SIZE_BUTTON, TEXT_SIZE_LARGE } from "@/constants/constans-value"; import AdminDonation_BoxOfDonationStory from "@/screens/Admin/Donation/BoxOfDonationStory"; @@ -195,7 +195,7 @@ export default function AdminDonationDetail() { {listPencarianDana.map((item, i) => ( - {item.label}} value={{item.value}} @@ -236,7 +236,7 @@ export default function AdminDonationDetail() { - Jumlah Donatur} value={ @@ -244,7 +244,7 @@ export default function AdminDonationDetail() { } /> - Dana Terkumpul} value={ @@ -261,7 +261,7 @@ export default function AdminDonationDetail() { {listData.map((item, i) => ( - {item.label}} value={{item.value}} diff --git a/app/(application)/admin/donation/[id]/[status]/transaction-detail.tsx b/app/(application)/admin/donation/[id]/[status]/transaction-detail.tsx index 91e0e46..bf9f3cc 100644 --- a/app/(application)/admin/donation/[id]/[status]/transaction-detail.tsx +++ b/app/(application)/admin/donation/[id]/[status]/transaction-detail.tsx @@ -8,7 +8,7 @@ import { ViewWrapper, } from "@/components"; import AdminBackButtonAntTitle from "@/components/_ShareComponent/Admin/BackButtonAntTitle"; -import { GridDetail_4_8 } from "@/components/_ShareComponent/GridDetail_4_8"; +import { GridSpan_4_8 } from "@/components/_ShareComponent/GridSpan_4_8"; import { apiAdminDonationInvoiceDetailById, apiAdminDonationInvoiceUpdateById, @@ -177,7 +177,7 @@ export default function AdminDonasiTransactionDetail() { {listData.map((item, index) => ( - {item.label}} value={{item.value}} diff --git a/app/(application)/admin/donation/[id]/detail-disbursement-of-funds.tsx b/app/(application)/admin/donation/[id]/detail-disbursement-of-funds.tsx index 4399dfd..10bdd96 100644 --- a/app/(application)/admin/donation/[id]/detail-disbursement-of-funds.tsx +++ b/app/(application)/admin/donation/[id]/detail-disbursement-of-funds.tsx @@ -7,7 +7,7 @@ import { ViewWrapper, } from "@/components"; import AdminBackButtonAntTitle from "@/components/_ShareComponent/Admin/BackButtonAntTitle"; -import { GridDetail_4_8 } from "@/components/_ShareComponent/GridDetail_4_8"; +import { GridSpan_4_8 } from "@/components/_ShareComponent/GridSpan_4_8"; import { apiAdminDonationDisbursementOfFundsListById } from "@/service/api-admin/api-admin-donation"; import { dateTimeView } from "@/utils/dateTimeView"; import { formatCurrencyDisplay } from "@/utils/formatCurrencyDisplay"; @@ -67,7 +67,7 @@ export default function AdminDonationDetailDisbursementOfFunds() { {listData?.map((item, index) => ( - {item.label}} value={{item.value}} diff --git a/app/(application)/admin/donation/category.tsx b/app/(application)/admin/donation/category.tsx index b9237f9..ec2e69f 100644 --- a/app/(application)/admin/donation/category.tsx +++ b/app/(application)/admin/donation/category.tsx @@ -1,30 +1,22 @@ import { - ActionIcon, BadgeCustom, - BaseBox, CenterCustom, ClickableCustom, - DividerCustom, - Grid, Spacing, StackCustom, TextCustom, - ViewWrapper, + ViewWrapper } from "@/components"; -import { IconEdit } from "@/components/_Icon"; import AdminActionIconPlus from "@/components/_ShareComponent/Admin/ActionIconPlus"; import AdminComp_BoxTitle from "@/components/_ShareComponent/Admin/BoxTitlePage"; import AdminTitlePage from "@/components/_ShareComponent/Admin/TitlePage"; -import { GridView_3_3_6 } from "@/components/_ShareComponent/GridView_3_3_6"; -import { MainColor } from "@/constants/color-palet"; -import { ICON_SIZE_BUTTON } from "@/constants/constans-value"; -import { RefreshControl, View } from "react-native"; -import { Divider, Switch } from "react-native-paper"; -import { router, useFocusEffect } from "expo-router"; -import { useCallback, useEffect, useState } from "react"; +import { GridSpan_4_8 } from "@/components/_ShareComponent/GridSpan_4_8"; import { apiAdminMasterDonationCategory } from "@/service/api-admin/api-master-admin"; -import { GridDetail_4_8 } from "@/components/_ShareComponent/GridDetail_4_8"; -import GridTwoView from "@/components/_ShareComponent/GridTwoView"; +import { colorActivationForBadge } from "@/utils/colorActivationForBadge"; +import { router, useFocusEffect } from "expo-router"; +import { useCallback, useState } from "react"; +import { RefreshControl, View } from "react-native"; +import { Divider } from "react-native-paper"; export default function AdminDonationCategory() { const [listData, setListData] = useState([]); @@ -80,14 +72,18 @@ export default function AdminDonationCategory() { /> - - + Status} + value={Kategori} + /> + {/* + Status Kategori - + */} @@ -100,11 +96,22 @@ export default function AdminDonationCategory() { }} key={index} > - - + + + {item.active ? "Aktif" : "Tidak Aktif"} + + + } + value={{item.name}} + /> + {/* + {item.name} - + */} ))} diff --git a/app/(application)/admin/event/[id]/[status]/index.tsx b/app/(application)/admin/event/[id]/[status]/index.tsx index 0025e0f..a0d0c49 100644 --- a/app/(application)/admin/event/[id]/[status]/index.tsx +++ b/app/(application)/admin/event/[id]/[status]/index.tsx @@ -1,22 +1,22 @@ /* eslint-disable react-hooks/exhaustive-deps */ import { - ActionIcon, - AlertDefaultSystem, - BadgeCustom, - BaseBox, - DrawerCustom, - LoaderCustom, - MenuDrawerDynamicGrid, - Spacing, - StackCustom, - TextCustom, - ViewWrapper, + ActionIcon, + AlertDefaultSystem, + BadgeCustom, + BaseBox, + DrawerCustom, + LoaderCustom, + MenuDrawerDynamicGrid, + Spacing, + StackCustom, + TextCustom, + ViewWrapper, } from "@/components"; import { IconDot, IconList } from "@/components/_Icon/IconComponent"; import AdminBackButtonAntTitle from "@/components/_ShareComponent/Admin/BackButtonAntTitle"; import AdminButtonReject from "@/components/_ShareComponent/Admin/ButtonReject"; import AdminButtonReview from "@/components/_ShareComponent/Admin/ButtonReview"; -import { GridDetail_4_8 } from "@/components/_ShareComponent/GridDetail_4_8"; +import { GridSpan_4_8 } from "@/components/_ShareComponent/GridSpan_4_8"; import ReportBox from "@/components/Box/ReportBox"; import { ICON_SIZE_BUTTON } from "@/constants/constans-value"; import { useAuth } from "@/hooks/use-auth"; @@ -39,6 +39,11 @@ export default function AdminEventDetail() { const [data, setData] = React.useState(null); const [loadData, setLoadData] = React.useState(false); const deepLinkURL = `${DEEP_LINK_URL}/event/${id}/confirmation?userId=${user?.id}`; + const deepLinkURLDEV = `${DEEP_LINK_URL}/--/event/${id}/confirmation?userId=${user?.id}`; + + const isDevLink = process.env.NODE_ENV === "development" ? deepLinkURLDEV : deepLinkURL; + + useFocusEffect( useCallback(() => { onLoadData(); @@ -156,7 +161,7 @@ export default function AdminEventDetail() { {listData.map((item, i) => ( - {item.label}} value={{item.value}} @@ -181,7 +186,7 @@ export default function AdminEventDetail() { ) : ( )} - {deepLinkURL} + {isDevLink} )} diff --git a/app/(application)/admin/event/[id]/list-of-participants.tsx b/app/(application)/admin/event/[id]/list-of-participants.tsx index 7e284bd..f8bb439 100644 --- a/app/(application)/admin/event/[id]/list-of-participants.tsx +++ b/app/(application)/admin/event/[id]/list-of-participants.tsx @@ -10,14 +10,17 @@ import { } from "@/components"; import AdminBackButtonAntTitle from "@/components/_ShareComponent/Admin/BackButtonAntTitle"; import { apiAdminEventListOfParticipants } from "@/service/api-admin/api-admin-event"; +import dayjs, { Dayjs } from "dayjs"; import { useFocusEffect, useLocalSearchParams } from "expo-router"; import _ from "lodash"; +import { View } from "moti"; import { useCallback, useState } from "react"; export default function AdminEventListOfParticipants() { const { id } = useLocalSearchParams(); const [listData, setListData] = useState(null); const [loadData, setLoadData] = useState(false); + const [startDate, setStartDate] = useState(); useFocusEffect( useCallback(() => { @@ -32,8 +35,11 @@ export default function AdminEventListOfParticipants() { id: id as string, }); + console.log("[DATA]", JSON.stringify(response, null, 2)); + if (response.success) { setListData(response.data); + setStartDate(dayjs(response.data.Event.tanggal)); } } catch (error) { console.log("[ERROR]", error); @@ -42,7 +48,6 @@ export default function AdminEventListOfParticipants() { } }; - return ( <> - {item?.User?.username} + + {item?.User?.username} + +{item?.User?.nomor} - - {item?.isPresent ? "Hadir" : "Tidak Hadir"} - + {startDate && + startDate.subtract(1, "hour").diff(dayjs()) < 0 ? ( + + {item?.isPresent ? "Hadir" : "Tidak Hadir"} + + ) : ( + + + - + + + )} diff --git a/app/(application)/admin/event/[status]/status.tsx b/app/(application)/admin/event/[status]/status.tsx index 738f91c..74cfe6e 100644 --- a/app/(application)/admin/event/[status]/status.tsx +++ b/app/(application)/admin/event/[status]/status.tsx @@ -1,11 +1,12 @@ /* eslint-disable react-hooks/exhaustive-deps */ import { ActionIcon, + ClickableCustom, LoaderCustom, SearchInput, StackCustom, TextCustom, - ViewWrapper + ViewWrapper, } from "@/components"; import AdminComp_BoxTitle from "@/components/_ShareComponent/Admin/BoxTitlePage"; import AdminTitleTable from "@/components/_ShareComponent/Admin/TableTitle"; @@ -13,6 +14,7 @@ import AdminTableValue from "@/components/_ShareComponent/Admin/TableValue"; import AdminTitlePage from "@/components/_ShareComponent/Admin/TitlePage"; import { ICON_SIZE_BUTTON } from "@/constants/constans-value"; import { apiAdminEvent } from "@/service/api-admin/api-admin-event"; +import { dateTimeView } from "@/utils/dateTimeView"; import { Octicons } from "@expo/vector-icons"; import { router, useFocusEffect, useLocalSearchParams } from "expo-router"; import _ from "lodash"; @@ -74,8 +76,8 @@ export default function AdminEventStatus() { @@ -83,36 +85,47 @@ export default function AdminEventStatus() { {loadData ? ( ) : _.isEmpty(listData) ? ( - Belum ada data + + Belum ada data + ) : ( listData?.map((item, index) => ( - - } - onPress={() => { - router.push(`/admin/event/${item.id}/${status}`); - }} - /> - } - value2={ - - {item?.Author?.username || "-"} - - } - value3={ - - {item?.title || "-"} - - } - /> + onPress={() => { + router.push(`/admin/event/${item.id}/${status}`); + }} + > + + {item?.Author?.username || "-"} + + // + // } + // onPress={() => { + // router.push(`/admin/event/${item.id}/${status}`); + // }} + // /> + } + value2={ + + {dateTimeView({ date: item?.tanggal })} + + } + value3={ + {item?.title || "-"} + } + /> + + )) )} diff --git a/app/(application)/admin/forum/[id]/index.tsx b/app/(application)/admin/forum/[id]/index.tsx index f92388c..d63007a 100644 --- a/app/(application)/admin/forum/[id]/index.tsx +++ b/app/(application)/admin/forum/[id]/index.tsx @@ -11,7 +11,7 @@ import { } from "@/components"; import { IconDot } from "@/components/_Icon/IconComponent"; import AdminBackButtonAntTitle from "@/components/_ShareComponent/Admin/BackButtonAntTitle"; -import { GridDetail_4_8 } from "@/components/_ShareComponent/GridDetail_4_8"; +import { GridSpan_4_8 } from "@/components/_ShareComponent/GridSpan_4_8"; import { MainColor } from "@/constants/color-palet"; import { ICON_SIZE_XLARGE } from "@/constants/constans-value"; import { apiAdminForumPostingById } from "@/service/api-admin/api-admin-forum"; @@ -103,7 +103,7 @@ export default function AdminForumDetailPosting() { {listDataAction.map((item, i) => ( - {item.label}} value={{item.value}} diff --git a/app/(application)/admin/forum/[id]/list-report-comment.tsx b/app/(application)/admin/forum/[id]/list-report-comment.tsx index 1103411..4a4cb30 100644 --- a/app/(application)/admin/forum/[id]/list-report-comment.tsx +++ b/app/(application)/admin/forum/[id]/list-report-comment.tsx @@ -16,7 +16,7 @@ import AdminBackButtonAntTitle from "@/components/_ShareComponent/Admin/BackButt import AdminComp_BoxTitle from "@/components/_ShareComponent/Admin/BoxTitlePage"; import AdminTitleTable from "@/components/_ShareComponent/Admin/TableTitle"; import AdminTableValue from "@/components/_ShareComponent/Admin/TableValue"; -import { GridDetail_4_8 } from "@/components/_ShareComponent/GridDetail_4_8"; +import { GridSpan_4_8 } from "@/components/_ShareComponent/GridSpan_4_8"; import { MainColor } from "@/constants/color-palet"; import { ICON_SIZE_BUTTON } from "@/constants/constans-value"; import { @@ -95,11 +95,11 @@ export default function AdminForumReportComment() { > - Username} value={{data?.Author?.username || "-"}} /> - Komentar} value={{data?.komentar || "-"}} /> @@ -208,20 +208,20 @@ export default function AdminForumReportComment() { height={"auto"} > - Pelapor} value={{selectedReport?.username || "-"}} /> {selectedReport?.kategori && ( <> - Kategori Report} value={ {selectedReport?.kategori || "-"} } /> - Keterangan} value={ {selectedReport?.keterangan || "-"} @@ -231,7 +231,7 @@ export default function AdminForumReportComment() { )} {selectedReport?.deskripsi && ( - Deskripsi} value={ {selectedReport?.deskripsi || "-"} diff --git a/app/(application)/admin/forum/[id]/list-report-posting.tsx b/app/(application)/admin/forum/[id]/list-report-posting.tsx index c806ce3..1d82976 100644 --- a/app/(application)/admin/forum/[id]/list-report-posting.tsx +++ b/app/(application)/admin/forum/[id]/list-report-posting.tsx @@ -17,7 +17,7 @@ import AdminBackButtonAntTitle from "@/components/_ShareComponent/Admin/BackButt import AdminComp_BoxTitle from "@/components/_ShareComponent/Admin/BoxTitlePage"; import AdminTitleTable from "@/components/_ShareComponent/Admin/TableTitle"; import AdminTableValue from "@/components/_ShareComponent/Admin/TableValue"; -import { GridDetail_4_8 } from "@/components/_ShareComponent/GridDetail_4_8"; +import { GridSpan_4_8 } from "@/components/_ShareComponent/GridSpan_4_8"; import { MainColor } from "@/constants/color-palet"; import { ICON_SIZE_BUTTON } from "@/constants/constans-value"; import { @@ -95,12 +95,12 @@ export default function AdminForumReportPosting() { > - Username} value={{data?.Author?.username || "-"}} /> - Status} value={ data && data?.ForumMaster_StatusPosting?.status ? ( @@ -121,7 +121,7 @@ export default function AdminForumReportPosting() { } /> - Postingan} value={{data?.diskusi || "-"}} /> @@ -229,20 +229,20 @@ export default function AdminForumReportPosting() { height={"auto"} > - Pelapor} value={{selectedReport?.username || "-"}} /> {selectedReport?.kategori && ( <> - Kategori Report} value={ {selectedReport?.kategori || "-"} } /> - Keterangan} value={ {selectedReport?.keterangan || "-"} @@ -252,7 +252,7 @@ export default function AdminForumReportPosting() { )} {selectedReport?.deskripsi && ( - Deskripsi} value={ {selectedReport?.deskripsi || "-"} diff --git a/app/(application)/admin/investment/[id]/[status]/index.tsx b/app/(application)/admin/investment/[id]/[status]/index.tsx index f265b28..a3dff44 100644 --- a/app/(application)/admin/investment/[id]/[status]/index.tsx +++ b/app/(application)/admin/investment/[id]/[status]/index.tsx @@ -19,7 +19,7 @@ import { IconDot, IconList } from "@/components/_Icon/IconComponent"; import AdminBackButtonAntTitle from "@/components/_ShareComponent/Admin/BackButtonAntTitle"; import AdminButtonReject from "@/components/_ShareComponent/Admin/ButtonReject"; import AdminButtonReview from "@/components/_ShareComponent/Admin/ButtonReview"; -import { GridDetail_4_8 } from "@/components/_ShareComponent/GridDetail_4_8"; +import { GridSpan_4_8 } from "@/components/_ShareComponent/GridSpan_4_8"; import ReportBox from "@/components/Box/ReportBox"; import { MainColor } from "@/constants/color-palet"; import { ICON_SIZE_BUTTON } from "@/constants/constans-value"; @@ -183,7 +183,7 @@ export default function AdminInvestmentDetail() { /> - Sisa Saham} value={ @@ -191,7 +191,7 @@ export default function AdminInvestmentDetail() { } /> - Validasi Transaksi} value={ @@ -207,7 +207,7 @@ export default function AdminInvestmentDetail() { {listData.map((item, i) => ( - {item.label}} value={{item.value}} @@ -218,7 +218,7 @@ export default function AdminInvestmentDetail() { - File Prospektus} value={ } /> - File Dokumen} value={ diff --git a/app/(application)/admin/investment/[id]/[status]/transaction-detail.tsx b/app/(application)/admin/investment/[id]/[status]/transaction-detail.tsx index f8cb183..6bab71c 100644 --- a/app/(application)/admin/investment/[id]/[status]/transaction-detail.tsx +++ b/app/(application)/admin/investment/[id]/[status]/transaction-detail.tsx @@ -10,7 +10,7 @@ import { ViewWrapper, } from "@/components"; import AdminBackButtonAntTitle from "@/components/_ShareComponent/Admin/BackButtonAntTitle"; -import { GridDetail_4_8 } from "@/components/_ShareComponent/GridDetail_4_8"; +import { GridSpan_4_8 } from "@/components/_ShareComponent/GridSpan_4_8"; import GridTwoView from "@/components/_ShareComponent/GridTwoView"; import { MainColor } from "@/constants/color-palet"; import { @@ -225,7 +225,7 @@ export default function AdminInvestmentTransactionDetail() { {listData.map((item, index) => ( - {item.label}} value={{item.value}} diff --git a/app/(application)/admin/voting/[id]/[status]/index.tsx b/app/(application)/admin/voting/[id]/[status]/index.tsx index 97dd581..ae99746 100644 --- a/app/(application)/admin/voting/[id]/[status]/index.tsx +++ b/app/(application)/admin/voting/[id]/[status]/index.tsx @@ -1,19 +1,19 @@ /* eslint-disable react-hooks/exhaustive-deps */ import { - AlertDefaultSystem, - BadgeCustom, - BaseBox, - CircleContainer, - Grid, - Spacing, - StackCustom, - TextCustom, - ViewWrapper, + AlertDefaultSystem, + BadgeCustom, + BaseBox, + CircleContainer, + Grid, + Spacing, + StackCustom, + TextCustom, + ViewWrapper, } from "@/components"; import AdminBackButtonAntTitle from "@/components/_ShareComponent/Admin/BackButtonAntTitle"; import AdminButtonReject from "@/components/_ShareComponent/Admin/ButtonReject"; import AdminButtonReview from "@/components/_ShareComponent/Admin/ButtonReview"; -import { GridDetail_4_8 } from "@/components/_ShareComponent/GridDetail_4_8"; +import { GridSpan_4_8 } from "@/components/_ShareComponent/GridSpan_4_8"; import ReportBox from "@/components/Box/ReportBox"; import { MainColor } from "@/constants/color-palet"; import funUpdateStatusVoting from "@/screens/Admin/Voting/funUpdateStatus"; @@ -169,7 +169,7 @@ export default function AdminVotingDetail() { {listData.map((item, i) => ( - {item.label}} value={{item.value}} diff --git a/components/Alert/AlertWarning.ts b/components/Alert/AlertWarning.ts new file mode 100644 index 0000000..f619aa7 --- /dev/null +++ b/components/Alert/AlertWarning.ts @@ -0,0 +1,16 @@ +import { Alert } from "react-native"; + +export default function AlertWarning({ + title = "Peringatan Bagi Pengguna !", + description = "Konten yang Anda masukkan mengandung kata-kata yang tidak sesuai dengan pedoman komunitas kami. Mohon gunakan bahasa yang sopan dan menghargai sesama pengguna. Jika kata tersebut sebenarnya lumrah, mohon maaf—kemungkinan sistem kami belum mengenalnya sebagai wajar.", +}: { + title?: string + description?: string; +}) { + return Alert.alert(title, description, [ + { + text: "Tutup", + onPress: () => {}, + }, + ]); +} diff --git a/components/DateInput/DateTimeIOS.tsx b/components/DateInput/DateTimeIOS.tsx index 3fb4c96..54c06d7 100644 --- a/components/DateInput/DateTimeIOS.tsx +++ b/components/DateInput/DateTimeIOS.tsx @@ -7,7 +7,7 @@ import DateTimePicker, { } from "@react-native-community/datetimepicker"; import dayjs from "dayjs"; import React, { useState } from "react"; -import { StyleProp, Text, View, ViewStyle } from "react-native"; +import { Button, StyleProp, Text, View, ViewStyle } from "react-native"; import ClickableCustom from "../Clickable/ClickableCustom"; import TextCustom from "../Text/TextCustom"; @@ -129,24 +129,64 @@ const DateTimeInput_IOS: React.FC = ({ borderWidth: 1, }} > - + {/* setShow(false)} + onPress={() => { + setShow(false); + setSelectedDate(undefined); + }} /> - + */} + + { + setShow(false) + setSelectedDate(undefined) + }} + style={{ + alignItems: "center", + justifyContent: "center", + padding: 12, + borderRadius: 10, + backgroundColor: MainColor.placeholder, + marginTop: 10, + width: "48%", + }} + > + Batal + + + { + setShow(false) + onChange(selectedDate as any) + }} + style={{ + alignItems: "center", + justifyContent: "center", + padding: 12, + borderRadius: 10, + backgroundColor: MainColor.darkblue, + marginTop: 10, + width: "48%", + }} + > + OK + + )} diff --git a/components/_ShareComponent/Admin/ButtonReject.tsx b/components/_ShareComponent/Admin/ButtonReject.tsx index c56e1fd..72dd91e 100644 --- a/components/_ShareComponent/Admin/ButtonReject.tsx +++ b/components/_ShareComponent/Admin/ButtonReject.tsx @@ -15,7 +15,7 @@ export default function AdminButtonReject({ <> } - backgroundColor={MainColor.red} + backgroundColor={MainColor.orange} textColor="white" onPress={onReject} isLoading={isLoading} diff --git a/components/_ShareComponent/GridDetail_4_8.tsx b/components/_ShareComponent/GridDetail_4_8.tsx deleted file mode 100644 index 2ce5b1e..0000000 --- a/components/_ShareComponent/GridDetail_4_8.tsx +++ /dev/null @@ -1,20 +0,0 @@ -import { Grid } from "@/components"; - -export const GridDetail_4_8 = ({ - label, - value, -}: { - label: React.ReactNode; - value: React.ReactNode; -}) => { - return ( - - - {label} - - - {value} - - - ); -}; \ No newline at end of file diff --git a/components/_ShareComponent/GridSpan_4_8.tsx b/components/_ShareComponent/GridSpan_4_8.tsx new file mode 100644 index 0000000..d2721e6 --- /dev/null +++ b/components/_ShareComponent/GridSpan_4_8.tsx @@ -0,0 +1,27 @@ +import { Grid } from "@/components"; + +export const GridSpan_4_8 = ({ + label, + value, +}: { + label: React.ReactNode; + value: React.ReactNode; +}) => { + return ( + + + {label} + + + {value} + + + ); +}; diff --git a/ios/HIPMIBadungConnect/Info.plist b/ios/HIPMIBadungConnect/Info.plist index fa0d347..c092a48 100644 --- a/ios/HIPMIBadungConnect/Info.plist +++ b/ios/HIPMIBadungConnect/Info.plist @@ -39,7 +39,7 @@ CFBundleVersion - 12 + 13 ITSAppUsesNonExemptEncryption LSMinimumSystemVersion diff --git a/utils/badWordsIndonesia.ts b/utils/badWordsIndonesia.ts new file mode 100644 index 0000000..82b60c1 --- /dev/null +++ b/utils/badWordsIndonesia.ts @@ -0,0 +1,108 @@ +// badWordsIndonesia.js (Versi Lengkap) + +const badWordsIndonesia = [ + // 🐶 Kata Kasar & Vulgar + 'anjing', 'babi', 'bangsat', 'bodoh', 'goblok', 'idiot', 'jancok', 'jembut', 'kampret', + 'kontol', 'memek', 'ngentot', 'peler', 'puki', 'sialan', 'tai', 'tolol', 'wibu', + 'anjingg', 'babbii', 'bangsaat', 'gobllokk', 'jancokk', 'kontoll', 'memekk', 'ngentott', + 'pelerr', 'puuki', 'sialann', 'taii', 'tololl', 'wibuu', + + // 🔥 Kata Sindiran & Penghinaan + 'bego', 'dungu', 'edan', 'gila', 'goblog', 'kampang', 'kampret', 'keparat', 'lonte', + 'main mata', 'monyet', 'najis', 'ngeyel', 'ngibul', 'ngomong seenaknya', 'ngurangin', + 'ngutang', 'ngurusin urusan orang', 'pemalas', 'pengecut', 'penipu', 'sinting', + 'begoo', 'dunguu', 'goblogg', 'kampangg', 'keparatt', 'lontee', 'monyyet', 'najiss', + 'ngeyell', 'ngibull', 'ngomongg seenaknya', 'nguranginn', 'ngutangg', 'pemalass', + 'pengecutt', 'penipuu', 'sintting', + + // ⚖️ Kata SARA & Diskriminasi + 'cina', 'kafir', 'kampungan', 'kacung', 'mampus', 'menghina', 'racist', 'sara', + 'setan', 'syiah', 'waria', 'wong jowo', 'wong sunda', 'wong madura', + 'chinna', 'kafiir', 'kampungann', 'kacungg', 'mampuss', 'menghinna', 'racisst', + 'saraa', 'setann', 'syiahh', 'wariia', 'wong jowoo', 'wong sundaa', 'wong maduraa', + + // 💸 Kata Spam / Promosi Ilegal + 'judi', 'togel', 'slot', 'casino', 'poker', 'qq', 'bandar', 'agen', 'link', 'wa', + 'whatsapp', 'telepon', 'nomor', 'hp', 'sms', 'grup', 'join', 'daftar', 'bonus', + 'deposit', 'withdraw', 'uang', 'duit', 'rp', 'ratusan', 'juta', 'milyar', + 'judii', 'togell', 'slotss', 'casinoo', 'pokerr', 'qqq', 'bandarr', 'agenn', 'linkk', + 'waa', 'whatsappp', 'teleponn', 'nomorr', 'hpp', 'smss', 'grupp', 'jooin', 'daftarr', + 'bonuss', 'depositt', 'withdraww', 'uangs', 'duitt', 'rpp', 'ratusann', 'jutaa', 'milyarr', + + // 🧩 Variasi Penulisan (Bypass Filter) + 'a*njing', 'b*b*i', 'b*ngsat', 'g*blok', 'k*nt*l', 'm*m*k', 'n*g*nt*t', 'p*l*r', + 't*i', 't*l*l', 'j*n*c*k', 'j*m*b*t', 'k*m*p*r*t', 's*i*l*a*n', 'w*b*u', + 'a.n.j.i.n.g', 'b.a.b.i', 'b.a.n.g.s.a.t', 'g.o.b.l.o.k', 'k.o.n.t.o.l', 'm.e.m.e.k', + 'n.g.e.n.t.o.t', 'p.e.l.e.r', 't.a.i', 't.o.l.o.l', 'j.a.n.c.o.k', 'j.e.m.b.u.t', + 'k.a.m.p.r.e.t', 's.i.a.l.a.n', 'w.i.b.u', + + // 📱 Variasi dengan Angka & Simbol + '4nj1ng', 'b4b1', 'b4ngs4t', 'g0bl0k', 'k0nt0l', 'm3m3k', 'ng3nt0t', 'p3l3r', + 't4i', 't0l0l', 'j4nc0k', 'j3mbut', 'k4mpr3t', 's14l4n', 'w1bu', + '4nj1ngg', 'b4b11', 'b4ngs4tt', 'g0bl0kk', 'k0nt0ll', 'm3m3kk', 'ng3nt0tt', + 'p3l3rr', 't4ii', 't0l0ll', 'j4nc0kk', 'j3mbutt', 'k4mpr3tt', 's14l4nn', 'w1buu', + + // 🗣️ Kata yang Sering Digunakan dalam Konteks Negatif + 'dasar', 'kamu', 'kau', 'lu', 'lo', 'gue', 'gua', 'kita', 'kami', 'mereka', + 'dasarr', 'kamuu', 'kauu', 'luu', 'loo', 'guee', 'guua', 'kitaa', 'kamii', 'merekaa', + 'dasar bodoh', 'dasar goblok', 'dasar bangsat', 'dasar idiot', 'dasar sialan', + 'dasar bego', 'dasar dungu', 'dasar edan', 'dasar gila', 'dasar sinting', + 'dasar pemalas', 'dasar pengecut', 'dasar penipu', 'dasar najis', 'dasar kampret', + + // 🚫 Kata yang Mengandung Unsur Seksual + 'porno', 'seks', 'mesum', 'bugil', 'telanjang', 'payudara', 'pantat', 'vagina', 'penis', + 'pornoo', 'sekss', 'mesumm', 'bugill', 'telanjangg', 'payudaraa', 'pantatt', 'vaginna', + 'peniss', 'pornoografi', 'pornografi', 'porno graf i', 'seksual', 'seksualitas', + 'pornoograffii', 'pornografffii', 'porno graf ii', 'seksuall', 'seksualitass', + + // 🤬 Kata Kasar dari Bahasa Daerah (Sunda, Jawa, dll) + 'kampret', 'kacung', 'mampus', 'sialan', 'bangsat', 'goblok', 'bodoh', 'tolol', + 'kamprett', 'kacungg', 'mampuss', 'sialann', 'bangsaatt', 'gobllokk', 'bodooh', 'tololl', + 'kampret sunda', 'kacung jawa', 'mampus batak', 'sialan minang', 'bangsat lampung', + 'goblok palembang', 'bodoh medan', 'tolol makassar', + + // 📉 Kata yang Sering Digunakan untuk Menjelekkan Orang +// 'jelek', 'buruk', 'tidak pantas', 'tidak sopan', 'tidak beretika', 'tidak beradab', +// 'jelekk', 'burukk', 'tidak pantass', 'tidak sopann', 'tidak beretikaa', 'tidak beradabb', +// 'jelek banget', 'buruk banget', 'tidak pantas banget', 'tidak sopan banget', +// 'tidak beretika banget', 'tidak beradab banget', + + // 🛑 Kata yang Sering Digunakan untuk Menyebarkan Hoax +// 'hoax', 'bohong', 'palsu', 'tipu', 'menipu', 'menyesatkan', 'menjerumuskan', +// 'hoaxx', 'bohongg', 'palsuu', 'tipuu', 'menipuu', 'menyesatkanng', 'menjerumuskanng', +// 'hoax besar', 'bohong besar', 'palsu besar', 'tipu besar', 'menipu besar', +// 'menyesatkan besar', 'menjerumuskan besar' +]; + +// Normalisasi teks +const normalizeText = (text: string) => { + return text.toLowerCase().replace(/\s+/g, ' ').trim(); +}; + +// Cek apakah teks mengandung kata buruk +const isBadContent = (text: string) => { + const normalized = normalizeText(text); + for (let word of badWordsIndonesia) { + if (normalized.includes(word)) { + return true; + } + } + return false; +}; + +// Saring teks (ganti dengan asterisk) +const censorText = (text: string) => { + let result = text; + for (let word of badWordsIndonesia) { + const regex = new RegExp(word.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'), 'gi'); + result = result.replace(regex, '*'.repeat(word.length)); + } + return result; +}; + +export { + badWordsIndonesia, + isBadContent, + censorText, + normalizeText +}; \ No newline at end of file