HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux spn-python 5.15.0-89-generic #99-Ubuntu SMP Mon Oct 30 20:42:41 UTC 2023 x86_64
User: arjun (1000)
PHP: 8.1.2-1ubuntu2.20
Disabled: NONE
Upload Files
File: //home/arjun/projects/good-life-be/models/Questions.js
import { Sequelize, DataTypes } from 'sequelize';
import sequelize from '../config/sequelize-config.js';

const Question = sequelize.define(
  'questions',
  {
    id: {
      primaryKey: true,
      type: DataTypes.INTEGER,
      autoIncrement: true,
    },
    parent_id: {
      type: DataTypes.INTEGER,
      allowNull: true,
    },
    category_id: {
      type: DataTypes.INTEGER,
      allowNull: true,
    },
    subcategory_id: {
      type: DataTypes.INTEGER,
      allowNull: true,
    },
    question: {
      type: DataTypes.TEXT,
      allowNull: false,
    },
    answer: {
      type: DataTypes.JSON,
      allowNull: false,
    },
    answer_type: {
      type: DataTypes.ENUM(
        'text',
        'dropdown',
        'radio',
        'checkbox',
        'time_range',
        'slider',
        'time',
        'duration',
        'date',
        'date_range',
        'button'
      ),
    },
    createdAt: {
      type: DataTypes.DATE,
      allowNull: false,
      defaultValue: Sequelize.literal('CURRENT_TIMESTAMP'),
    },
    updatedAt: {
      type: DataTypes.DATE,
      allowNull: false,
      defaultValue: Sequelize.literal('CURRENT_TIMESTAMP'),
      onUpdate: Sequelize.literal('CURRENT_TIMESTAMP'),
    },
  },

  {
    timestamps: true,
  }
);

Question.associate = (models) => {
  Question.belongsTo(models.questions, {
    as: 'parentQuestion',
    foreignKey: 'parent_id',
  });
  Question.hasMany(models.questions, {
    as: 'childQuestions',
    foreignKey: 'parent_id',
  });
  Question.belongsTo(models.sub_category, {
    foreignKey: 'subcategory_id',
    as: 'subcategory',
  });
};

export default Question;