Security News
UK Officials Consider Banning Ransomware Payments from Public Entities
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.
fenextjs-hook
Advanced tools
Hook of Fenextjs
Hook for handling Data Object
//for CJS
import { useData } from "fenextjs-hook/cjs/useData";
//for ESM
import { useData } from "fenextjs-hook/esm/useData";
//interface of value
interface ValueProps {
//....
}
//interface of value Memo(optional)
interface ValueMemoProps {
//....
}
const {
data, // value
onChangeData, // change one value by key
isChange, // boolean if change data
setData, // set value
dataMemo, // data parse by onMemo
setIsChange, // set isChange
} = useData<
ValueProps, // intefate of value
ValueMemoProps //interface of value Memo(optional)
>(
defaultValue, // default value
{
//function execute after change value
onChangeDataAfter: (data: ValueProps) => {
},
//function execute for parse data to dataMemo
onMemo: (data: ValueProps) => {
const dataMemo : ValueMemoProps = {
//...
}
return dataMemo
};
}
);
Hook for request, loader and errors, with query and autoRequest
//for CJS
import { useRequest } from "fenextjs-hook/cjs/useRequest";
//for ESM
import { useRequest } from "fenextjs-hook/esm/useRequest";
//interface of query
interface QueryProps {
//....
}
//interface of result
interface ResultProps {
//....
}
//interface of error
interface ErrorProps {
//....
}
//type of type result
type TypeProps = RequestResultTypeProps;
const {
result, // result of request,
loader, // boolean of loader,
error, // error failing the request
onRequest, // function request,
} = useRequest<
QueryProps, // intefate of query
ResultProps, //interface of result
ErrorProps, //interface of error Request(optional)
TypeProps //type of type result Request(optional)(default RequestResultTypeProps)
>({
query, // query by use in request
request, // function request
autoRequest, // boolean if auto execute request is change query (optional)(default = false)
});
Hook to save modal settings to localstorage using uselocalstoragenextjs
//for CJS
import { useModal } from "fenextjs-hook/cjs/useModal";
//for ESM
import { useModal } from "fenextjs-hook/esm/useModal";
//inteface of content valueModal
interface useModalConfigContentProps {
key: string; // key of config modal
data: any; // config modal
}
//inteface of valueModal
interface useModalConfigProps {
active?: boolean; // if active modal
use?: boolean; // if use modal in current page
loader?: boolean; // if loader modal
content?: useModalConfigContentProps[]; // content config modal
}
const {
valueModal, // value of config modal, inteface useModalConfigProps
loadModal, // boolean if load modal
updateModal, // update one value of config modal by key
setModal, // set value of config modal, inteface useModalConfigProps
} = useModal();
Hook to save notification settings to localstorage using uselocalstoragenextjs
//for CJS
import { useNotification } from "fenextjs-hook/cjs/useNotification";
//for ESM
import { useNotification } from "fenextjs-hook/esm/useNotification";
//type of notification
type NotificationType = "none" | "normal" | "ok" | "error" | "warning";
//iterfate of notification
interface NotificationProps {
type?: NotificationType;
message: string;
}
const {
loadNotification, // boolean if load notification,
notification, // value of notification, interface NotificationProps
pop, // function of add notification by time
reset, // reset notification (remove)
} = useNotification({
time: 2000, // time of show notification (optional)(default = 2000)
});
Hook for handling Query Router
//for CJS
import { useQuery } from "fenextjs-hook/cjs/useQuery";
//for ESM
import { useQuery } from "fenextjs-hook/esm/useQuery";
const {
query, // query value, interface useQuery_QueryProps
setQuery, // set query value
onChangeQuery, // change one query value by key
isChange, // boolean if change query
} = useQuery();
Hook for handling User Auth
//for CJS
import { useUser } from "fenextjs-hook/cjs/useUser";
//for ESM
import { useUser } from "fenextjs-hook/esm/useUser";
const {
load, // boolean if load
user, // user value, interface UserProps | null
setUser, // set user value
onLogin, // set user if login and validateToken
onLogOut, //set user in null
} = useUser({
// function for validate token (optiona)
// this example is default
validateTokenUser = async (user: UserProps) => {
if (!user.token) {
throw {
type: RequestResultTypeProps.ERROR,
message: "User not Token",
error: {
code: ErrorCode.USER_TOKEN_NOT_FOUNT,
message: "User not Token",
},
} as RequestResultDataProps;
}
try {
const token: UserProps = jwt_decode(user.token);
if (token?.id) {
return {
type: RequestResultTypeProps.OK,
message: "User Validate Ok",
} as RequestResultDataProps;
}
throw {
type: RequestResultTypeProps.ERROR,
message: "Token Invalid",
error: {
code: ErrorCode.USER_TOKEN_INVALID,
message: "Token Invalid",
},
} as RequestResultDataProps;
} catch (error) {
throw {
type: RequestResultTypeProps.ERROR,
message: "Token Invalid",
error: {
code: ErrorCode.USER_TOKEN_INVALID,
message: "Token Invalid",
},
} as RequestResultDataProps;
}
},
});
Hook for handling Phone with code and number
//for CJS
import { usePhone } from "fenextjs-hook/cjs/usePhone";
//for ESM
import { usePhone } from "fenextjs-hook/esm/usePhone";
const {
load, // boolean if load list code
codes, // list of code phone, interface PhoneCodeProps
phone, // phone selected, interface PhoneProps
setCode, // set code of phone
setNumber, // set number of phone
} = useUser({
//default value of phone, (optional), interface PhoneProps
defaultValue: {
code: "",
number: "",
},
});
Email blancofrancisco34@gmail.com
FAQs
Unknown package
We found that fenextjs-hook demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.