'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); const BONUSES_COUNT = 2; const CARD_COUNT = 109; const GLORY_COUNT = 9; const MEDAILLONS_COUNT = 5; const STANDEES_COUNT = 5; const TRACK_COUNT = 5; const TRACK_LENGTH = 11; const FACTIONS = ['a', 'c', 'm']; console.log('roles', document.getElementById('roles')); const ui = { map: document.getElementById('map'), markers: document.getElementById('markers'), fronts: { a: { front: document.getElementById('aragon_front'), value: document.querySelector('#aragon_front .value'), contributions: document.querySelector('#aragon_front .contributions'), }, m: { front: document.getElementById('madrid_front'), value: document.querySelector('#madrid_front .value'), contributions: document.querySelector('#madrid_front .contributions'), }, n: { front: document.getElementById('northern_front'), value: document.querySelector('#northern_front .value'), contributions: document.querySelector('#northern_front .contributions'), }, s: { front: document.getElementById('southern_front'), value: document.querySelector('#southern_front .value'), contributions: document.querySelector('#southern_front .contributions'), }, }, glory_container: document.getElementById('glory'), hand: document.getElementById('hand'), current_events: document.getElementById('current_events'), stats: { a: { hero_points: document.querySelector('#role_Anarchist .role_stat'), }, c: { hero_points: document.querySelector('#role_Communist .role_stat'), }, m: { hero_points: document.querySelector('#role_Moderate .role_stat'), }, pool: { hero_points: document.getElementById('pool_hero_points'), }, }, tableaus: { a: document.getElementById('tableau_a'), c: document.getElementById('tableau_c'), m: document.getElementById('tableau_m'), }, tracks: document.getElementById('tracks'), hero_points: document.querySelector('#role_Anarchist .role_stat'), year: document.getElementById('year'), blank_markers: [[], [], [], [], []], bonuses: [], tokens_on_front: {}, glory: [], medaillons: [], spaces: [], standees: [], pieces: [], cards: [], }; let action_register = []; const LAYOUT_BONUSES = [ [435, 481], [493, 481], ]; const LAYOUT_CURRENT_EVENTS = [ [172, 648], [309, 648], [445, 648], [584, 648], ]; const LAYOUT_GLORY = [ [801, 647], [860, 647], [897, 647], [848, 718], [775, 771], [812, 771], [849, 771], [885, 771], [922, 771], ]; const LAYOUT_MEDAILLONS = [ [364, 556], [415, 556], [466, 556], [517, 556], [568, 556], ]; const LAYOUT_TRACKS = [ [ [581, 46], [618, 46], [655, 46], [691, 46], [728, 46], [765, 46], [801, 46], [838, 46], [874, 46], [911, 46], [948, 46], ], [ [581, 156], [618, 156], [655, 156], [691, 156], [728, 156], [765, 156], [801, 156], [838, 156], [874, 156], [911, 156], [948, 156], ], [ [581, 267], [618, 267], [655, 267], [691, 267], [728, 267], [765, 267], [801, 267], [838, 267], [874, 267], [911, 267], [948, 267], ], [ [581, 378], [618, 378], [655, 378], [691, 378], [728, 378], [765, 378], [801, 378], [838, 378], [874, 378], [911, 378], [948, 378], ], [ [581, 489], [618, 489], [655, 489], [691, 489], [728, 489], [765, 489], [801, 489], [838, 489], [874, 489], [911, 489], [948, 489], ], ]; console.log('ui', ui); function register_action(e, action, id) { e.my_action = action; e.my_id = id; e.onmousedown = on_click_action; action_register.push(e); } function on_click_action(evt) { console.log('on_click_action', evt); if (evt.button === 0) if (send_action(evt.target.my_action, evt.target.my_id)) evt.stopPropagation(); } function is_action(action, arg) { if (arg === undefined) return !!(view.actions && view.actions[action] === 1); return !!(view.actions && view.actions[action] && view.actions[action].includes(arg)); } let on_init_once = false; function on_init() { console.log('on_init'); if (on_init_once) return; on_init_once = true; console.log('ui', ui); console.log('document', document); for (let t = 0; t < 5; ++t) { for (let bm = 0; bm < TRACK_LENGTH; ++bm) { let e = (ui.blank_markers[t][bm] = document.createElement('div')); e.className = 'blank_marker'; register_action(e, 'blank_marker', bm); } } for (let b = 0; b < BONUSES_COUNT; ++b) { let e = (ui.bonuses[b] = document.createElement('div')); e.className = 'bonus'; e.setAttribute('data-bonus-id', '' + b); e.style.left = LAYOUT_BONUSES[b][0] + 'px'; e.style.top = LAYOUT_BONUSES[b][1] + 'px'; LAYOUT_BONUSES; register_action(e, 'bonus', b); ui.map.appendChild(ui.bonuses[b]); } for (let g = 0; g < GLORY_COUNT; ++g) { let e = (ui.glory[g] = document.createElement('div')); e.className = 'faction_token'; ui.glory_container.appendChild(ui.glory[g]); e.style.left = LAYOUT_GLORY[g][0] + 'px'; e.style.top = LAYOUT_GLORY[g][1] + 'px'; } for (let m = 0; m < MEDAILLONS_COUNT; ++m) { let e = (ui.medaillons[m] = document.createElement('div')); e.className = 'medaillon'; e.setAttribute('data-medaillon-id', '' + m); register_action(e, 'medaillon', m); ui.map.appendChild(ui.medaillons[m]); } for (let s = 0; s < STANDEES_COUNT; ++s) { let e = (ui.standees[s] = document.createElement('div')); e.className = 'standee'; e.setAttribute('data-standee-id', '' + s); register_action(e, 'standee', s); ui.tracks.appendChild(ui.standees[s]); } for (let c = 1; c < CARD_COUNT; ++c) { let e = (ui.cards[c] = document.createElement('div')); e.className = 'card'; e.setAttribute('data-card-id', '' + data.cards[c].id); register_action(e, 'card', c); } data.fronts.forEach((front) => { ui.tokens_on_front[front.id] = {}; FACTIONS.forEach((faction_id) => { let e = (ui.tokens_on_front[front.id][faction_id] = document.createElement('div')); e.className = 'faction_token'; e.setAttribute('data-faction-id', faction_id); }); }); Object.keys(ui.fronts).forEach((front_id) => { register_action(ui.fronts[front_id].front, 'front', front_id); }); } function on_update() { console.log('on_update', view); on_init(); for (let key of Object.keys(view.hero_points)) { ui.stats[key].hero_points.replaceChildren(`Hero Points: ${view.hero_points[key]}`); } ui.current_events.replaceChildren(); for (let i = 0; i < view.current_events.length; i++) { const cardId = view.current_events[i]; ui.current_events.appendChild(ui.cards[cardId]); ui.cards[cardId].classList.add('event'); ui.cards[cardId].style.left = LAYOUT_CURRENT_EVENTS[i][0] + 'px'; ui.cards[cardId].style.top = LAYOUT_CURRENT_EVENTS[i][1] + 'px'; } ui.markers.replaceChildren(); for (let t = 0; t < TRACK_COUNT; ++t) { for (let bm of view.triggered_track_effects[t]) { ui.markers.appendChild(ui.blank_markers[t][bm]); ui.blank_markers[t][bm].style.left = LAYOUT_TRACKS[t][bm][0] + 'px'; ui.blank_markers[t][bm].style.top = LAYOUT_TRACKS[t][bm][1] + 'px'; } } for (let bonus_id of Object.keys(view.bonuses)) { ui.bonuses[bonus_id].setAttribute('data-bonus-on', view.bonuses[bonus_id] + 0); } ui.hand.replaceChildren(); for (let c of view.hand) { ui.cards[c].classList.remove('selected'); ui.hand.appendChild(ui.cards[c]); if (c === view.selected_card || view.final_bid.includes(c)) { ui.cards[c].classList.add('selected'); } } for (let i = 0; i < view.tracks.length; ++i) { ui.standees[i].style.left = LAYOUT_TRACKS[i][view.tracks[i]][0] + 'px'; ui.standees[i].style.top = LAYOUT_TRACKS[i][view.tracks[i]][1] + 'px'; } for (let front_id of Object.keys(view.fronts)) { const front_data = view.fronts[front_id]; ui.fronts[front_id].value.replaceChildren(front_data.status !== null ? front_data.status : front_data.value); ui.fronts[front_id].contributions.replaceChildren(); for (let faction_id of front_data.contributions) { ui.fronts[front_id].contributions.appendChild(ui.tokens_on_front[front_id][faction_id]); } } for (let i = 0; i < view.medaillons.length; ++i) { if (view.medaillons[i] !== null) { ui.medaillons[i].style.left = LAYOUT_MEDAILLONS[i][0] + 'px'; ui.medaillons[i].style.top = LAYOUT_MEDAILLONS[i][1] + 'px'; } } for (let faction_id of FACTIONS) { ui.tableaus[faction_id].replaceChildren(); for (let c of view.tableaus[faction_id]) { ui.cards[c].classList.remove('selected'); ui.tableaus[faction_id].appendChild(ui.cards[c]); } } for (let g = 0; g < view.glory.length; ++g) { ui.glory[g].setAttribute('data-faction-id', view.glory[g]); } for (let e of action_register) e.classList.toggle('action', is_action(e.my_action, e.my_id)); ui.year.replaceChildren(`Year ${view.year}`); action_button('add_to_front', '+1 to a Front'); action_button('soviet_support', 'Soviet Support'); action_button('collectivization', 'Collectivization'); action_button('d_liberty', 'Decrease Liberty'); action_button('d_collectivization', 'Decrease Collectivization'); action_button('d_foreign_aid', 'Decrease Foreign Aid'); action_button('d_government', 'Decrease Government'); action_button('d_soviet_support', 'Decrease Soviet Support'); action_button('draw_card', 'Draw a Card'); action_button('foreign_aid', 'Foreign Aid'); action_button('government', 'Government'); action_button('liberty', 'Liberty'); action_button('government_to_center', 'Government towards center'); action_button('teamwork_on', 'Teamwork Bonus On'); action_button('Anarchist', 'Anarchist'); action_button('Communist', 'Communist'); action_button('Moderate', 'Moderate'); action_button('gain_hp', 'Gain Hero Points'); action_button('play_for_ap', 'Play card for Action Points'); action_button('play_for_event', 'Play card for Event'); action_button('spend_hp', 'Spend Hero Points'); action_button('add_glory', 'Add Glory'); action_button('up', 'Up'); action_button('down', 'Down'); action_button('next', 'Next'); action_button('skip', 'Skip'); action_button('done', 'Done'); action_button('undo', 'Undo'); } function on_log(text) { let p = document.createElement('div'); if (text.match(/^>>/)) { text = text.substring(2); p.className = "ii"; } if (text.match(/^>/)) { text = text.substring(1); p.className = 'i'; } text = text.replace(/&/g, '&'); text = text.replace(//g, '>'); if (text.match(/^\.h1/)) { text = text.substring(4); p.className = 'h1'; } else if (text.match(/^\.h2\.Moderate/)) { text = text.substring(13); p.className = 'h2 moderate'; } else if (text.match(/^\.h2\.Anarchist/)) { text = text.substring(14); p.className = 'h2 anarchist'; } else if (text.match(/^\.h2\.Communist/)) { text = text.substring(14); p.className = 'h2 communist'; } else if (text.match(/^\.h2\.fascist/)) { text = text.substring(11); p.className = 'h2 fascist'; } else if (text.match(/^\.h2/)) { text = text.substring(4); p.className = 'h2'; } else if (text.match(/^\.h3/)) { text = text.substring(4); p.className = 'h3'; } p.innerHTML = text; return p; }