Changes between Initial Version and Version 1 of expertCreateCourse


Ignore:
Timestamp:
01/25/26 18:57:03 (5 days ago)
Author:
231175
Comment:

--

Legend:

Unmodified
Added
Removed
Modified
  • expertCreateCourse

    v1 v1  
     1== Креирање на курс
     2=== Актери
     3- Најавен корисник
     4=== Чекор 1
     5При клик на копчето за креирање на курс на навбарот на корисникот му се прикажува форма со полиња. При пополнување на овие полиња и клик на копчето "Create" се креира курс во базата.
     6
     7{{{
     8DROP TABLE IF EXISTS temp_course_id;
     9DROP TABLE IF EXISTS temp_course_version_id;
     10DROP TABLE IF EXISTS temp_course_translate_id;
     11DROP TABLE IF EXISTS temp_course_content_id;
     12DROP TABLE IF EXISTS temp_course_lecture_id;
     13DROP TABLE IF EXISTS temp_tag_id;
     14
     15CREATE TEMP TABLE temp_course_id (id BIGINT);
     16CREATE TEMP TABLE temp_course_version_id (id BIGINT);
     17CREATE TEMP TABLE temp_course_translate_id (id BIGINT, language VARCHAR(2));
     18CREATE TEMP TABLE temp_course_content_id (id BIGINT);
     19CREATE TEMP TABLE temp_course_lecture_id (id BIGINT);
     20CREATE TEMP TABLE temp_tag_id (id BIGINT, type VARCHAR(50));
     21
     22WITH new_course AS (
     23    INSERT INTO course (image_url, difficulty, duration_minutes, price, color)
     24    VALUES ('https://example.com/image.png', 'INTERMEDIATE', 120, 50, '#008CC2')
     25    RETURNING id
     26)
     27INSERT INTO temp_course_id (id)
     28SELECT id FROM new_course;
     29
     30WITH new_course_version AS (
     31    INSERT INTO course_version (version_number, creation_date, active, course_id)
     32    SELECT 1, CURRENT_DATE, true, id FROM temp_course_id
     33    RETURNING id
     34)
     35INSERT INTO temp_course_version_id (id)
     36SELECT id FROM new_course_version;
     37
     38WITH new_course_translate_en AS (
     39    INSERT INTO course_translate (language, title_short, title, description_short, description, description_long, course_id)
     40    SELECT 'en', 'Advanced Sales', 'Advanced Sales For Senior Salesman', 'Short desc', 'Normal desc', 'Long desc', id FROM temp_course_id
     41    RETURNING id, language
     42)
     43INSERT INTO temp_course_translate_id (id, language)
     44SELECT id, language FROM new_course_translate_en;
     45
     46WITH new_course_translate_mk AS (
     47    INSERT INTO course_translate (language, title_short, title, description_short, description, description_long, course_id)
     48    SELECT 'mk', 'Напредна Продажба', 'Напредна Продажба за Сениор Продавачи', 'Кратка дескрипција', 'Нормална дескрипција', 'Долга дескрипција', id FROM temp_course_id
     49    RETURNING id, language
     50)
     51INSERT INTO temp_course_translate_id (id, language)
     52SELECT id, language FROM new_course_translate_mk;
     53
     54WITH new_course_content AS (
     55    INSERT INTO course_content (position, course_version_id)
     56    SELECT 1, id FROM temp_course_version_id
     57    RETURNING id
     58)
     59INSERT INTO temp_course_content_id (id)
     60SELECT id FROM new_course_content;
     61
     62INSERT INTO course_content_translate (title, language, course_content_id)
     63SELECT 'Module 1: Sales Strategies', 'en', id FROM temp_course_content_id;
     64
     65INSERT INTO course_content_translate (title, language, course_content_id)
     66SELECT 'Модул 1: Продажни Стратегии', 'mk', id FROM temp_course_content_id;
     67
     68WITH new_course_lecture AS (
     69    INSERT INTO course_lecture (duration_minutes, position, content_type, course_content_id)
     70    SELECT 30, 1, 'video', id FROM temp_course_content_id
     71    RETURNING id
     72)
     73INSERT INTO temp_course_lecture_id (id)
     74SELECT id FROM new_course_lecture;
     75
     76INSERT INTO course_lecture_translate (title, language, content_file_name, description, content_text, course_lecture_id)
     77SELECT 'Lecture 1: Intro', 'en', 'lecture1.mp4', 'Introduction to advanced sales', 'Video text content', id
     78FROM temp_course_lecture_id;
     79
     80INSERT INTO course_lecture_translate (title, language, content_file_name, description, content_text, course_lecture_id)
     81SELECT 'Предавање 1: Вовед', 'mk', 'lecture1.mp4', 'Вовед во напредна продажба', 'Тмп', id
     82FROM temp_course_lecture_id;
     83
     84WITH new_tags AS (
     85    INSERT INTO tag (type)
     86    VALUES ('skill'), ('interest')
     87    RETURNING id, type
     88)
     89INSERT INTO temp_tag_id (id, type)
     90SELECT id, type FROM new_tags;
     91
     92INSERT INTO tag_translate (language, value, tag_id)
     93SELECT 'en', CASE type WHEN 'skill' THEN 'Skill' WHEN 'interest' THEN 'Interest' END, id FROM temp_tag_id;
     94
     95INSERT INTO tag_translate (language, value, tag_id)
     96SELECT 'mk', CASE type WHEN 'skill' THEN 'Вештина' WHEN 'interest' THEN 'Интерес' END, id FROM temp_tag_id;
     97
     98INSERT INTO course_tag (tag_id, course_id)
     99SELECT t.id, c.id
     100FROM temp_tag_id t
     101CROSS JOIN temp_course_id c;
     102
     103INSERT INTO expert_course (course_id, expert_id)
     104SELECT id, 1
     105FROM temp_course_id;
     106
     107INSERT INTO course_translate_what_will_be_learned (course_translate_id, what_will_be_learned)
     108SELECT id, 'Advanced sales techniques'
     109FROM temp_course_translate_id
     110WHERE language = 'en';
     111
     112INSERT INTO course_translate_what_will_be_learned (course_translate_id, what_will_be_learned)
     113SELECT id, 'How to successfully close deals'
     114FROM temp_course_translate_id
     115WHERE language = 'en';
     116
     117INSERT INTO course_translate_what_will_be_learned (course_translate_id, what_will_be_learned)
     118SELECT id, 'Напредни техники на продажба'
     119FROM temp_course_translate_id
     120WHERE language = 'mk';
     121
     122INSERT INTO course_translate_what_will_be_learned (course_translate_id, what_will_be_learned)
     123SELECT id, 'Како до успешно затворање на продажби'
     124FROM temp_course_translate_id
     125WHERE language = 'mk';
     126}}}