import { createAsyncThunk, createSlice } from "@reduxjs/toolkit";
import API from "../../api";

const baseURL = process.env.NEXT_PUBLIC_BASE_URL_RETAILER;

export const getPatternByProduct = createAsyncThunk(
  "get/getPatternByProduct",
  async (pattern_id: number, thunkAPI) => {
    try {
      const response: any = await API.get(
        `${baseURL}/quotation/get_color_partan_model/${pattern_id}`
      );
      if (response.data === undefined || typeof response.data !== "object") {
        return thunkAPI.rejectWithValue("Invalid data received");
      }
      console.log(response, "api resp >>>>>")
      return response?.data;
    } catch (error: any) {
      const message =
        (error.response && error.response.data && error.response.data?.message) ||
        error.message ||
        error.toString();
      return thunkAPI.rejectWithValue(message);
    }
  }
);

interface patternState {
  isGetPatternSuccess: boolean;
  patternData: any | null;
  isGetPatternError: string | undefined;
  isGetPatternLoading: boolean;
}

const initialState: patternState = {
  isGetPatternSuccess: false,
  patternData: null,
  isGetPatternError: "",
  isGetPatternLoading: false
};

const patternSlice = createSlice({
  name: "patternSlice",
  initialState,
  reducers: {
    resetGetPattern: (state: patternState) => {
      state.isGetPatternSuccess = false;
      state.patternData = null;
      state.isGetPatternError = "";
      state.isGetPatternLoading = false;
    }
  },
  extraReducers: (builder) => {
    builder
      .addCase(getPatternByProduct.pending, (state: patternState) => {
        state.isGetPatternLoading = true;
        state.isGetPatternError = "";
        state.patternData = null;
        state.isGetPatternSuccess = false;
      })
      .addCase(
        getPatternByProduct.fulfilled,
        (state: patternState, action: ReturnType<typeof getPatternByProduct.fulfilled>) => {
          state.isGetPatternLoading = false;
          state.patternData = action?.payload?.patternData;
          state.isGetPatternSuccess = true;
          state.isGetPatternError = "";
        }
      )
      .addCase(getPatternByProduct.rejected, (state: patternState, action: any) => {
        state.isGetPatternLoading = false;
        state.isGetPatternError = action?.payload || "An error occurred";
        state.isGetPatternSuccess = false;
        state.patternData = null; // Reset data in case of rejection
      })
  },
});

export const { resetGetPattern } = patternSlice.actions;

export default patternSlice.reducer;

