@ckstack/ck-lib-models
Version:
ckstack default database table sequelize models
237 lines (236 loc) • 9.05 kB
JavaScript
;
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.Menu = void 0;
const sequelize_typescript_1 = require("sequelize-typescript");
const dk_lib_1 = require("@dkpkg/dk-lib");
const MyValues_1 = require("../MyValues");
const Role_1 = require("./Role");
const __autoFitString = (data, modelName) => {
const _data = data;
if (_data.name && dk_lib_1.CkUtils.getByteLength(_data.name) > 255) {
_data.name = dk_lib_1.CkUtils.stringCutByByte(_data.name, 255);
dk_lib_1.CkLogger.warnLog2(`${modelName}. name from [${data.name}] to [${_data.name}]`, MyValues_1.PROC_LHD.IP_LHD_HTTP);
}
if (_data.reserve1 && dk_lib_1.CkUtils.getByteLength(_data.reserve1) > 128) {
_data.reserve1 = dk_lib_1.CkUtils.stringCutByByte(_data.reserve1, 128);
dk_lib_1.CkLogger.warnLog2(`${modelName}. reserve1 from [${data.reserve1}] to [${_data.reserve1}]`, MyValues_1.PROC_LHD.IP_LHD_HTTP);
}
if (_data.reserve2 && dk_lib_1.CkUtils.getByteLength(_data.reserve2) > 128) {
_data.reserve2 = dk_lib_1.CkUtils.stringCutByByte(_data.reserve2, 128);
dk_lib_1.CkLogger.warnLog2(`${modelName}. reserve2 from [${data.reserve2}] to [${_data.reserve2}]`, MyValues_1.PROC_LHD.IP_LHD_HTTP);
}
if (_data.reserve3 && dk_lib_1.CkUtils.getByteLength(_data.reserve3) > 255) {
_data.reserve3 = dk_lib_1.CkUtils.stringCutByByte(_data.reserve3, 255);
dk_lib_1.CkLogger.warnLog2(`${modelName}. reserve3 from [${data.reserve3}] to [${_data.reserve3}]`, MyValues_1.PROC_LHD.IP_LHD_HTTP);
}
};
let Menu = class Menu extends sequelize_typescript_1.Model {
static autoFitString(data) {
__autoFitString(data, 'Menu');
}
};
__decorate([
(0, sequelize_typescript_1.Column)({
field: 'id',
type: sequelize_typescript_1.DataType.INTEGER({ scale: 11 }).UNSIGNED,
primaryKey: true,
autoIncrement: true,
allowNull: false,
unique: true,
}),
__metadata("design:type", Number)
], Menu.prototype, "id", void 0);
__decorate([
(0, sequelize_typescript_1.Index)({ name: 'idx_rid', unique: true }),
(0, sequelize_typescript_1.Column)({
field: 'rid',
type: sequelize_typescript_1.DataType.STRING(32),
allowNull: false,
unique: true,
defaultValue: '',
}),
__metadata("design:type", String)
], Menu.prototype, "rid", void 0);
__decorate([
(0, sequelize_typescript_1.ForeignKey)(() => Role_1.Role),
(0, sequelize_typescript_1.Index)('idx_role_id'),
(0, sequelize_typescript_1.Column)({
field: 'role_id',
type: sequelize_typescript_1.DataType.INTEGER({ scale: 11 }).UNSIGNED,
allowNull: false,
defaultValue: 0,
}),
__metadata("design:type", Number)
], Menu.prototype, "role_id", void 0);
__decorate([
(0, sequelize_typescript_1.Index)('idx_parent_menu_id'),
(0, sequelize_typescript_1.Column)({
field: 'parent_menu_id',
type: sequelize_typescript_1.DataType.INTEGER({ scale: 11 }).UNSIGNED,
allowNull: false,
defaultValue: 0,
}),
__metadata("design:type", Number)
], Menu.prototype, "parent_menu_id", void 0);
__decorate([
(0, sequelize_typescript_1.Index)('idx_name'),
(0, sequelize_typescript_1.Column)({
field: 'name',
type: sequelize_typescript_1.DataType.STRING(255),
defaultValue: '',
}),
__metadata("design:type", String)
], Menu.prototype, "name", void 0);
__decorate([
(0, sequelize_typescript_1.Column)({
field: 'url_path',
type: sequelize_typescript_1.DataType.TEXT,
defaultValue: '',
}),
__metadata("design:type", String)
], Menu.prototype, "url_path", void 0);
__decorate([
(0, sequelize_typescript_1.Column)({
field: 'status',
type: sequelize_typescript_1.DataType.ENUM(dk_lib_1.CkValue.STATUS.ENABLE, dk_lib_1.CkValue.STATUS.PAUSE, dk_lib_1.CkValue.STATUS.DISABLE),
allowNull: false,
defaultValue: dk_lib_1.CkValue.STATUS.ENABLE,
}),
__metadata("design:type", Number)
], Menu.prototype, "status", void 0);
__decorate([
(0, sequelize_typescript_1.Column)({
field: 'template_id',
type: sequelize_typescript_1.DataType.INTEGER({ scale: 11 }).UNSIGNED,
allowNull: false,
defaultValue: 0,
}),
__metadata("design:type", Number)
], Menu.prototype, "template_id", void 0);
__decorate([
(0, sequelize_typescript_1.Column)({
field: 'extra',
type: sequelize_typescript_1.DataType.JSON,
defaultValue: {},
}),
__metadata("design:type", Object)
], Menu.prototype, "extra", void 0);
__decorate([
(0, sequelize_typescript_1.Column)({
field: 'depth',
type: sequelize_typescript_1.DataType.TINYINT.UNSIGNED,
allowNull: false,
defaultValue: 0,
}),
__metadata("design:type", Number)
], Menu.prototype, "depth", void 0);
__decorate([
(0, sequelize_typescript_1.Index)('idx_list_order'),
(0, sequelize_typescript_1.Column)({
field: 'list_order',
type: sequelize_typescript_1.DataType.INTEGER({ scale: 11 }).UNSIGNED,
allowNull: false,
defaultValue: 0,
}),
__metadata("design:type", Number)
], Menu.prototype, "list_order", void 0);
__decorate([
(0, sequelize_typescript_1.Index)('idx_rc_page_name'),
(0, sequelize_typescript_1.Column)({
field: 'rc_page_name',
type: sequelize_typescript_1.DataType.STRING(32),
defaultValue: '',
}),
__metadata("design:type", String)
], Menu.prototype, "rc_page_name", void 0);
__decorate([
(0, sequelize_typescript_1.Index)('idx_rc_icon'),
(0, sequelize_typescript_1.Column)({
field: 'rc_icon',
type: sequelize_typescript_1.DataType.STRING(32),
defaultValue: '',
}),
__metadata("design:type", String)
], Menu.prototype, "rc_icon", void 0);
__decorate([
(0, sequelize_typescript_1.Column)({
field: 'is_first_page',
type: sequelize_typescript_1.DataType.ENUM(dk_lib_1.CkValue.YES_OR_NO.YES, dk_lib_1.CkValue.YES_OR_NO.NO),
allowNull: false,
defaultValue: dk_lib_1.CkValue.YES_OR_NO.NO,
}),
__metadata("design:type", Number)
], Menu.prototype, "is_first_page", void 0);
__decorate([
(0, sequelize_typescript_1.Column)({
field: 'reserve1',
type: sequelize_typescript_1.DataType.STRING(128),
defaultValue: '',
}),
__metadata("design:type", String)
], Menu.prototype, "reserve1", void 0);
__decorate([
(0, sequelize_typescript_1.Column)({
field: 'reserve2',
type: sequelize_typescript_1.DataType.STRING(128),
defaultValue: '',
}),
__metadata("design:type", String)
], Menu.prototype, "reserve2", void 0);
__decorate([
(0, sequelize_typescript_1.Column)({
field: 'reserve3',
type: sequelize_typescript_1.DataType.STRING(255),
defaultValue: '',
}),
__metadata("design:type", String)
], Menu.prototype, "reserve3", void 0);
__decorate([
(0, sequelize_typescript_1.Column)({
field: 'c_date',
type: sequelize_typescript_1.DataType.DATE,
allowNull: false,
defaultValue: new Date(),
}),
__metadata("design:type", Date)
], Menu.prototype, "c_date", void 0);
__decorate([
(0, sequelize_typescript_1.Column)({
field: 'u_date',
type: sequelize_typescript_1.DataType.DATE,
allowNull: true,
defaultValue: new Date(),
}),
__metadata("design:type", Date)
], Menu.prototype, "u_date", void 0);
__decorate([
(0, sequelize_typescript_1.BelongsTo)(() => Role_1.Role),
__metadata("design:type", Role_1.Role)
], Menu.prototype, "role", void 0);
__decorate([
sequelize_typescript_1.BeforeCreate,
sequelize_typescript_1.BeforeUpdate,
sequelize_typescript_1.BeforeSave,
sequelize_typescript_1.BeforeUpsert,
__metadata("design:type", Function),
__metadata("design:paramtypes", [Menu]),
__metadata("design:returntype", void 0)
], Menu, "autoFitString", null);
Menu = __decorate([
(0, sequelize_typescript_1.Table)({
tableName: 'tbl_menus',
freezeTableName: true,
underscored: true,
timestamps: false,
})
], Menu);
exports.Menu = Menu;