Bereinigen und Entfernen von nicht mehr benötigten TinyMCE-Dateien und -Plugins; Aktualisierung der Internationalisierung für Deutsch und Englisch in den Falukant- und Navigationsmodulen; Verbesserung der Statusleiste und Router-Implementierung.

This commit is contained in:
Torsten Schulz (local)
2025-08-21 16:10:21 +02:00
parent 53c748a074
commit 3eb7ae4e93
170 changed files with 3850 additions and 7924 deletions

View File

@@ -0,0 +1,40 @@
import { sequelize } from '../../utils/sequelize.js';
import { DataTypes } from 'sequelize';
const Campaign = sequelize.define('Campaign', {
id: {
type: DataTypes.INTEGER,
primaryKey: true,
autoIncrement: true
},
name: {
type: DataTypes.STRING(255),
allowNull: false
},
description: {
type: DataTypes.TEXT,
allowNull: true
},
isActive: {
type: DataTypes.BOOLEAN,
defaultValue: true
},
order: {
type: DataTypes.INTEGER,
defaultValue: 1
},
createdAt: {
type: DataTypes.DATE,
defaultValue: DataTypes.NOW
},
updatedAt: {
type: DataTypes.DATE,
defaultValue: DataTypes.NOW
}
}, {
tableName: 'match3_campaigns',
schema: 'match3',
timestamps: true
});
export default Campaign;

View File

@@ -0,0 +1,61 @@
import { sequelize } from '../../utils/sequelize.js';
import { DataTypes } from 'sequelize';
const Level = sequelize.define('Level', {
id: {
type: DataTypes.INTEGER,
primaryKey: true,
autoIncrement: true
},
campaignId: {
type: DataTypes.INTEGER,
allowNull: false
},
name: {
type: DataTypes.STRING(255),
allowNull: false
},
description: {
type: DataTypes.TEXT,
allowNull: true
},
order: {
type: DataTypes.INTEGER,
defaultValue: 1
},
boardSize: {
type: DataTypes.INTEGER,
defaultValue: 8
},
tileTypes: {
type: DataTypes.JSON,
allowNull: false,
defaultValue: ['gem', 'star', 'heart', 'diamond', 'circle', 'square']
},
moveLimit: {
type: DataTypes.INTEGER,
allowNull: true
},
timeLimit: {
type: DataTypes.INTEGER,
allowNull: true
},
isActive: {
type: DataTypes.BOOLEAN,
defaultValue: true
},
createdAt: {
type: DataTypes.DATE,
defaultValue: DataTypes.NOW
},
updatedAt: {
type: DataTypes.DATE,
defaultValue: DataTypes.NOW
}
}, {
tableName: 'match3_levels',
schema: 'match3',
timestamps: true
});
export default Level;

View File

@@ -0,0 +1,52 @@
import { sequelize } from '../../utils/sequelize.js';
import { DataTypes } from 'sequelize';
const Objective = sequelize.define('Objective', {
id: {
type: DataTypes.INTEGER,
primaryKey: true,
autoIncrement: true
},
levelId: {
type: DataTypes.INTEGER,
allowNull: false
},
type: {
type: DataTypes.ENUM('score', 'matches', 'moves', 'time', 'special'),
allowNull: false
},
description: {
type: DataTypes.STRING(500),
allowNull: false
},
target: {
type: DataTypes.INTEGER,
allowNull: false
},
operator: {
type: DataTypes.ENUM('>=', '<=', '=', '>', '<'),
defaultValue: '>='
},
order: {
type: DataTypes.INTEGER,
defaultValue: 1
},
isRequired: {
type: DataTypes.BOOLEAN,
defaultValue: true
},
createdAt: {
type: DataTypes.DATE,
defaultValue: DataTypes.NOW
},
updatedAt: {
type: DataTypes.DATE,
defaultValue: DataTypes.NOW
}
}, {
tableName: 'match3_objectives',
schema: 'match3',
timestamps: true
});
export default Objective;

View File

@@ -0,0 +1,78 @@
import { sequelize } from '../../utils/sequelize.js';
import { DataTypes } from 'sequelize';
const UserLevelProgress = sequelize.define('UserLevelProgress', {
id: {
type: DataTypes.INTEGER,
primaryKey: true,
autoIncrement: true
},
userProgressId: {
type: DataTypes.INTEGER,
allowNull: false
},
levelId: {
type: DataTypes.INTEGER,
allowNull: false
},
score: {
type: DataTypes.INTEGER,
defaultValue: 0
},
moves: {
type: DataTypes.INTEGER,
defaultValue: 0
},
time: {
type: DataTypes.INTEGER,
defaultValue: 0
},
stars: {
type: DataTypes.INTEGER,
defaultValue: 0
},
isCompleted: {
type: DataTypes.BOOLEAN,
defaultValue: false
},
attempts: {
type: DataTypes.INTEGER,
defaultValue: 1
},
bestScore: {
type: DataTypes.INTEGER,
defaultValue: 0
},
bestMoves: {
type: DataTypes.INTEGER,
defaultValue: 0
},
bestTime: {
type: DataTypes.INTEGER,
defaultValue: 0
},
completedAt: {
type: DataTypes.DATE,
allowNull: true
},
createdAt: {
type: DataTypes.DATE,
defaultValue: DataTypes.NOW
},
updatedAt: {
type: DataTypes.DATE,
defaultValue: DataTypes.NOW
}
}, {
tableName: 'match3_user_level_progress',
schema: 'match3',
timestamps: true,
indexes: [
{
unique: true,
fields: ['userProgressId', 'levelId']
}
]
});
export default UserLevelProgress;

View File

@@ -0,0 +1,62 @@
import { sequelize } from '../../utils/sequelize.js';
import { DataTypes } from 'sequelize';
const UserProgress = sequelize.define('UserProgress', {
id: {
type: DataTypes.INTEGER,
primaryKey: true,
autoIncrement: true
},
userId: {
type: DataTypes.STRING(255),
allowNull: false
},
campaignId: {
type: DataTypes.INTEGER,
allowNull: false
},
totalScore: {
type: DataTypes.INTEGER,
defaultValue: 0
},
totalStars: {
type: DataTypes.INTEGER,
defaultValue: 0
},
levelsCompleted: {
type: DataTypes.INTEGER,
defaultValue: 0
},
currentLevel: {
type: DataTypes.INTEGER,
defaultValue: 1
},
isCompleted: {
type: DataTypes.BOOLEAN,
defaultValue: false
},
lastPlayed: {
type: DataTypes.DATE,
defaultValue: DataTypes.NOW
},
createdAt: {
type: DataTypes.DATE,
defaultValue: DataTypes.NOW
},
updatedAt: {
type: DataTypes.DATE,
defaultValue: DataTypes.NOW
}
}, {
tableName: 'match3_user_progress',
schema: 'match3',
timestamps: true,
indexes: [
{
unique: true,
fields: ['userId', 'campaignId']
}
]
});
export default UserProgress;