分身AI.com × 自分を知るワーク(Session 4)
Session 4: コミュニケーションスタイル (Communication Style)
あなたらしい伝え方を分身AIに移植します。正解はありません。普段どおりの感覚で答えてください。
全8問 / 所要時間: 約8-12分
Q1 / 8
13%
なぜそう思う?(任意)
スキップしました。後からいつでも答え直せます
折り返し地点です
あと4問で分身AIの話し方が完成します。
ここまでの回答はすべて自動保存されています。
Session 4 完了!
0
回答数
0
スキップ数
全体進捗(全48問)
0%
話し方の設定ができました。最後に事業の核心を固めます。
このブラウザに自動保存済みです。次回は同じ端末から続きを再開できます。

    (function () {
      var qfsScript = document.currentScript;
      var qfsContainer = qfsScript ? qfsScript.closest('.qf-soul-container') : null;
      if (!qfsContainer) {
        return;
      }

      var urlParams = new URLSearchParams(window.location.search);

      function qfOne(selector) {
        return qfsContainer.querySelector(selector);
      }

      function qfAll(selector) {
        return qfsContainer.querySelectorAll(selector);
      }

      /* ── Questions ─────────────────────────────────── */

      var QF_SOUL_QUESTIONS = [
        { id: 'D1', type: 'choice', question: '複雑な内容を説明する時、あなたのやり方に近いのは？', options: ['まず結論から', '背景から順に', '例え話で伝える', '図や箇条書きで整理'], bbSection: 'TONE', bbField: '口調・文体' },
        { id: 'D2', type: 'choice', question: '普段のメッセージ文体に最も近いトーンは？', options: ['丁寧・フォーマル', '親しみ・カジュアル', '端的・業務的', '明るく遊び心あり'], bbSection: 'TONE', bbField: '口調・文体' },
        { id: 'D3', type: 'scale', question: '返信速度に対するこだわりを選んでください。', scaleLabels: ['ほぼ気にしない', '少し気にする', '普通', 'かなり気にする', '最優先で即返信'], bbSection: 'TONE', bbField: '口調・文体' },
        { id: 'D4', type: 'choice', question: '意見がぶつかった時の初動に近いのは？', options: ['まず相手を聞く', 'すぐ自分の意見を伝える', '一旦持ち帰る', '論点整理してから話す'], bbSection: 'TONE', bbField: '口調・文体' },
        { id: 'D5', type: 'choice', question: '相手に伝える時、最も重視することは？', options: ['正確さ', '速さ', 'わかりやすさ', '感情への配慮'], bbSection: 'TONE', bbField: '口調・文体' },
        { id: 'D6', type: 'short_text', question: '断りや修正依頼を伝える時のあなたの言い方を教えてください。', placeholder: '実際に送るメッセージをそのまま書いてください...', bbSection: 'TONE', bbField: 'NGワード+キラーフレーズ' },
        { id: 'D7', type: 'choice', question: 'あなたの思考整理に合う出力形式はどれですか？', options: ['箇条書き', '短い要約', '会話形式', 'ステップ手順'], bbSection: 'TONE', bbField: 'NGワード+キラーフレーズ' },
        { id: 'D8', type: 'long_text', question: '分身AIに日常で使ってほしい話し方を具体的に教えてください。', placeholder: '語尾、一人称、敬語の度合い、口癖など具体的に...', bbSection: 'TONE', bbField: 'NGワード+キラーフレーズ' }
      ];

      var GROWTH_STAGES = [
        { min: 0, max: 19, name: 'たまご', emoji: '\uD83E\uDD5A' },
        { min: 20, max: 39, name: 'ひび割れ', emoji: '\uD83D\uDC23' },
        { min: 40, max: 59, name: 'ふ化', emoji: '\uD83D\uDC25' },
        { min: 60, max: 79, name: 'よちよち分身AI', emoji: '\uD83E\uDD16' },
        { min: 80, max: 100, name: '相棒モード', emoji: '\uD83E\uDDBE' }
      ];

      var SHALLOW_PATTERNS = [
        /臨機応変に/,
        /相手に合わせて/,
        /普通に/,
        /特にない/,
        /なんとなく/,
        /ケースバイケース/,
        /時と場合/,
        /丁寧に/
      ];

      var FIVE_SENSE_HINT = 'その言葉を伝えた時、相手の表情はどう変わりましたか？';

      var SESSION_NUMBER = 4;
      var SESSION_QUESTIONS = 8;

      /* ── DOM refs ──────────────────────────────────── */

      var qfsScreens = {
        welcome: qfOne('[data-qf-soul-screen="welcome"]'),
        quiz: qfOne('[data-qf-soul-screen="quiz"]'),
        midpoint: qfOne('[data-qf-soul-screen="midpoint"]'),
        complete: qfOne('[data-qf-soul-screen="complete"]')
      };

      var qfsUI = {
        startButton: qfOne('[data-qf-soul-action="start"]'),
        counter: qfOne('[data-qf-soul-counter]'),
        percent: qfOne('[data-qf-soul-percent]'),
        progressBar: qfOne('[data-qf-soul-progress]'),
        questionBox: qfOne('[data-qf-soul-question-box]'),
        questionLabel: qfOne('[data-qf-soul-question-label]'),
        questionText: qfOne('[data-qf-soul-question-text]'),
        inputArea: qfOne('[data-qf-soul-input-area]'),
        rejection: qfOne('[data-qf-soul-rejection]'),
        rejectionMsg: qfOne('[data-qf-soul-rejection-msg]'),
        rejectionHint: qfOne('[data-qf-soul-hint]'),
        followup: qfOne('[data-qf-soul-followup]'),
        followupInput: qfOne('[data-qf-soul-followup-input]'),
        nextBtn: qfOne('[data-qf-soul-action="next"]'),
        skipBtn: qfOne('[data-qf-soul-action="skip"]'),
        skipMsg: qfOne('[data-qf-soul-skip-msg]'),
        continueBtn: qfOne('[data-qf-soul-action="continue"]'),
        endBtn: qfOne('[data-qf-soul-action="end"]'),
        saveConfirm: qfOne('[data-qf-soul-save-confirm]'),
        growthBadge: qfOne('[data-qf-soul-growth-badge]'),
        growthEmoji: qfOne('[data-qf-soul-growth-emoji]'),
        growthName: qfOne('[data-qf-soul-growth-name]'),
        midEmoji: qfOne('[data-qf-soul-mid-emoji]'),
        midGrowthEmoji: qfOne('[data-qf-soul-mid-growth-emoji]'),
        midGrowthName: qfOne('[data-qf-soul-mid-growth-name]'),
        completeEmoji: qfOne('[data-qf-soul-complete-emoji]'),
        completeGrowthEmoji: qfOne('[data-qf-soul-complete-growth-emoji]'),
        completeGrowthName: qfOne('[data-qf-soul-complete-growth-name]'),
        statAnswered: qfOne('[data-qf-soul-stat-answered]'),
        statSkipped: qfOne('[data-qf-soul-stat-skipped]'),
        overallPercent: qfOne('[data-qf-soul-overall-percent]'),
        overallBar: qfOne('[data-qf-soul-overall-bar]'),
        completeMsg: qfOne('[data-qf-soul-complete-msg]'),
        remainingMsg: qfOne('[data-qf-soul-remaining-msg]')
      };

      /* ── State & Storage ───────────────────────────── */

      var TOTAL_QUESTIONS = 48;
      var userId = urlParams.get('uid') || '';
      if (!userId) { try { userId = localStorage.getItem('qfSoulWork:currentUser') || ''; } catch(ig) {} }
      if (!userId) {
        userId = 'u_' + Math.random().toString(36).slice(2, 10) + Date.now().toString(36);
      }
      try { localStorage.setItem('qfSoulWork:currentUser', userId); } catch(ig) {}

      var STORAGE_KEY = 'qfSoulWork:v1:' + userId;

      function loadStorage() {
        try {
          var raw = localStorage.getItem(STORAGE_KEY);
          if (raw) {
            return JSON.parse(raw);
          }
        } catch (e) {
          /* ignore */
        }
        return null;
      }

      function createDefaultStorage() {
        var axisScores = {};
        var axisKeys = ['hold', 'deleg', 'ai', 'blind'];
        var i;
        for (i = 0; i < axisKeys.length; i += 1) {
          var v = urlParams.get(axisKeys[i]);
          if (v) {
            axisScores[axisKeys[i]] = parseInt(v, 10) || 0;
          }
        }

        return {
          version: '1.0.0',
          userId: userId,
          quizType: urlParams.get('type') || 'unknown',
          axisScores: axisScores,
          progress: {
            currentSession: SESSION_NUMBER,
            completedSessions: [],
            answeredCount: 0,
            totalCount: TOTAL_QUESTIONS
          },
          answers: {}
        };
      }

      function saveStorage(data) {
        try {
          localStorage.setItem(STORAGE_KEY, JSON.stringify(data));
        } catch (e) {
          /* ignore */
        }
      }

      var storageData = loadStorage() || createDefaultStorage();

      /* ── Growth Stage ──────────────────────────────── */

      function getGrowthStage(answeredCount) {
        var pct = Math.round((answeredCount / TOTAL_QUESTIONS) * 100);
        var i;
        for (i = 0; i < GROWTH_STAGES.length; i += 1) {
          if (pct >= GROWTH_STAGES[i].min && pct <= GROWTH_STAGES[i].max) {
            return GROWTH_STAGES[i];
          }
        }
        return GROWTH_STAGES[0];
      }

      function updateGrowthDisplay() {
        var stage = getGrowthStage(storageData.progress.answeredCount);
        if (qfsUI.growthEmoji) {
          qfsUI.growthEmoji.textContent = stage.emoji;
        }
        if (qfsUI.growthName) {
          qfsUI.growthName.textContent = stage.name;
        }
      }

      /* ── Quiz State ────────────────────────────────── */

      var qfsState = {
        index: 0,
        rejectionCount: 0,
        selectedChoice: null,
        selectedScale: null,
        showingMidpoint: false
      };

      /* ── Screen Navigation ─────────────────────────── */

      function qfsShowScreen(name) {
        var keys = Object.keys(qfsScreens);
        var i;
        for (i = 0; i < keys.length; i += 1) {
          qfsScreens[keys[i]].classList.remove('qf-soul-active');
        }
        qfsScreens[name].classList.add('qf-soul-active');
      }

      /* ── Shallow Detection ─────────────────────────── */

      function isShallow(text) {
        if (!text || text.length < 20) {
          return true;
        }
        var i;
        for (i = 0; i < SHALLOW_PATTERNS.length; i += 1) {
          if (SHALLOW_PATTERNS[i].test(text)) {
            return true;
          }
        }
        return false;
      }

      /* ── Progress ──────────────────────────────────── */

      function updateProgress() {
        var current = qfsState.index + 1;
        var pct = Math.round((current / SESSION_QUESTIONS) * 100);
        qfsUI.counter.textContent = 'Q' + current + ' / ' + SESSION_QUESTIONS;
        qfsUI.percent.textContent = pct + '%';
        qfsUI.progressBar.style.width = pct + '%';
      }

      /* ── Render Question ───────────────────────────── */

      function renderQuestion() {
        var item = QF_SOUL_QUESTIONS[qfsState.index];
        qfsState.rejectionCount = 0;
        qfsState.selectedChoice = null;
        qfsState.selectedScale = null;

        updateProgress();

        qfsUI.questionLabel.textContent = item.bbSection + ' > ' + item.bbField;
        qfsUI.questionText.textContent = item.question;
        qfsUI.inputArea.innerHTML = '';
        qfsUI.rejection.classList.remove('qf-soul-rejection-visible');
        qfsUI.rejectionMsg.textContent = '';
        qfsUI.rejectionHint.textContent = '';
        qfsUI.followupInput.value = '';
        qfsUI.skipBtn.style.display = 'none';
        qfsUI.skipMsg.style.display = 'none';
        qfsUI.nextBtn.style.display = '';

        /* Restore existing answer if any */
        var existing = storageData.answers[item.id];

        if (item.type === 'choice') {
          qfsUI.followup.style.display = '';
          var i;
          for (i = 0; i < item.options.length; i += 1) {
            (function (optionText, idx) {
              var btn = document.createElement('button');
              btn.type = 'button';
              btn.className = 'qf-soul-btn qf-soul-btn-option';
              btn.textContent = optionText;
              if (existing && existing.value === optionText) {
                btn.classList.add('qf-soul-btn-option-selected');
                qfsState.selectedChoice = optionText;
              }
              btn.addEventListener('click', function () {
                var allOpts = qfsUI.inputArea.querySelectorAll('.qf-soul-btn-option');
                var j;
                for (j = 0; j < allOpts.length; j += 1) {
                  allOpts[j].classList.remove('qf-soul-btn-option-selected');
                }
                btn.classList.add('qf-soul-btn-option-selected');
                qfsState.selectedChoice = optionText;
              });
              qfsUI.inputArea.appendChild(btn);
            })(item.options[i], i);
          }
          if (existing && existing.why) {
            qfsUI.followupInput.value = existing.why;
          }
          return;
        }

        if (item.type === 'scale') {
          qfsUI.followup.style.display = '';
          var scaleWrap = document.createElement('div');
          scaleWrap.className = 'qf-soul-scale-wrap';
          var s;
          for (s = 0; s < item.scaleLabels.length; s += 1) {
            (function (label, num) {
              var btn = document.createElement('button');
              btn.type = 'button';
              btn.className = 'qf-soul-scale-btn';
              var numSpan = document.createElement('span');
              numSpan.className = 'qf-soul-scale-num';
              numSpan.textContent = num;
              btn.appendChild(numSpan);
              var labelNode = document.createTextNode(label);
              btn.appendChild(labelNode);
              if (existing && existing.value === num) {
                btn.classList.add('qf-soul-scale-selected');
                qfsState.selectedScale = num;
              }
              btn.addEventListener('click', function () {
                var allScale = scaleWrap.querySelectorAll('.qf-soul-scale-btn');
                var j;
                for (j = 0; j < allScale.length; j += 1) {
                  allScale[j].classList.remove('qf-soul-scale-selected');
                }
                btn.classList.add('qf-soul-scale-selected');
                qfsState.selectedScale = num;
              });
              scaleWrap.appendChild(btn);
            })(item.scaleLabels[s], s + 1);
          }
          qfsUI.inputArea.appendChild(scaleWrap);
          if (existing && existing.why) {
            qfsUI.followupInput.value = existing.why;
          }
          return;
        }

        /* short_text or long_text */
        qfsUI.followup.style.display = '';
        var maxLen = item.type === 'short_text' ? 160 : 1000;

        if (item.type === 'short_text') {
          var inp = document.createElement('input');
          inp.type = 'text';
          inp.className = 'qf-soul-input';
          inp.placeholder = item.placeholder || '';
          inp.maxLength = maxLen;
          inp.setAttribute('data-qf-soul-main-input', '');
          if (existing && existing.value) {
            inp.value = existing.value;
          }
          qfsUI.inputArea.appendChild(inp);
        } else {
          var ta = document.createElement('textarea');
          ta.className = 'qf-soul-textarea';
          ta.placeholder = item.placeholder || '';
          ta.maxLength = maxLen;
          ta.setAttribute('data-qf-soul-main-input', '');
          if (existing && existing.value) {
            ta.value = existing.value;
          }
          qfsUI.inputArea.appendChild(ta);

          var cc = document.createElement('div');
          cc.className = 'qf-soul-char-count';
          cc.setAttribute('data-qf-soul-char-count', '');
          cc.textContent = (existing && existing.value ? existing.value.length : 0) + ' / ' + maxLen;
          qfsUI.inputArea.appendChild(cc);

          ta.addEventListener('input', function () {
            var len = ta.value.length;
            cc.textContent = len + ' / ' + maxLen;
            if (len > maxLen * 0.9) {
              cc.classList.add('qf-soul-char-warn');
            } else {
              cc.classList.remove('qf-soul-char-warn');
            }
          });
        }

        if (existing && existing.why) {
          qfsUI.followupInput.value = existing.why;
        }

        /* Restore rejection state */
        if (existing && existing.rejectionCount) {
          qfsState.rejectionCount = existing.rejectionCount;
          if (qfsState.rejectionCount >= 2) {
            qfsUI.skipBtn.style.display = '';
          }
        }
      }

      /* ── Answer Logic ──────────────────────────────── */

      function getCurrentValue() {
        var item = QF_SOUL_QUESTIONS[qfsState.index];
        if (item.type === 'choice') {
          return qfsState.selectedChoice || '';
        }
        if (item.type === 'scale') {
          return qfsState.selectedScale || '';
        }
        var mainInput = qfOne('[data-qf-soul-main-input]');
        return mainInput ? mainInput.value.trim() : '';
      }

      function saveAnswer(value, skipped) {
        var item = QF_SOUL_QUESTIONS[qfsState.index];
        var whyVal = qfsUI.followupInput.value.trim();

        storageData.answers[item.id] = {
          type: item.type,
          value: value,
          why: whyVal,
          skipped: !!skipped,
          rejectionCount: qfsState.rejectionCount,
          updatedAt: new Date().toISOString()
        };

        /* Recount answered */
        var count = 0;
        var keys = Object.keys(storageData.answers);
        var i;
        for (i = 0; i < keys.length; i += 1) {
          if (!storageData.answers[keys[i]].skipped) {
            count += 1;
          }
        }
        storageData.progress.answeredCount = count;

        saveStorage(storageData);
      }

      function handleNext() {
        var item = QF_SOUL_QUESTIONS[qfsState.index];
        var value = getCurrentValue();

        /* Choice: must select */
        if (item.type === 'choice' && !value) {
          return;
        }

        /* Scale: must select */
        if (item.type === 'scale' && !value) {
          return;
        }

        /* Text: shallow detection */
        if (item.type !== 'choice' && item.type !== 'scale') {
          if (isShallow(value) && qfsState.rejectionCount < 2) {
            qfsState.rejectionCount += 1;
            qfsUI.rejection.classList.add('qf-soul-rejection-visible');

            if (qfsState.rejectionCount === 1) {
              qfsUI.rejectionMsg.textContent = 'もう少し具体的に教えてください。情景が浮かぶような回答が、あなたの分身AIを強くします \uD83D\uDCAA';
              qfsUI.rejectionHint.textContent = FIVE_SENSE_HINT;
            } else {
              qfsUI.rejectionMsg.textContent = 'ここは大事なポイントです。でも、今すぐ答えが出なくても大丈夫。後で戻ってくることもできます';
              qfsUI.rejectionHint.textContent = '';
              qfsUI.skipBtn.style.display = '';
            }
            return;
          }
        }

        saveAnswer(value, false);
        advanceQuestion();
      }

      function handleSkip() {
        saveAnswer('', true);
        qfsUI.skipMsg.style.display = 'block';
        setTimeout(function () {
          qfsUI.skipMsg.style.display = 'none';
          advanceQuestion();
        }, 1200);
      }

      function advanceQuestion() {
        qfsState.index += 1;

        /* Midpoint after Q4 (index 4) */
        if (qfsState.index === 4 && !qfsState.showingMidpoint) {
          qfsState.showingMidpoint = true;
          showMidpoint();
          return;
        }

        if (qfsState.index >= SESSION_QUESTIONS) {
          showComplete();
          return;
        }

        leaveAndRender();
      }

      function leaveAndRender() {
        qfsUI.questionBox.classList.add('qf-soul-leaving');
        setTimeout(function () {
          qfsUI.questionBox.classList.remove('qf-soul-leaving');
          renderQuestion();
        }, 240);
      }

      /* ── Midpoint ──────────────────────────────────── */

      function showMidpoint() {
        var stage = getGrowthStage(storageData.progress.answeredCount);
        qfsUI.midEmoji.textContent = stage.emoji;
        qfsUI.midGrowthEmoji.textContent = stage.emoji;
        qfsUI.midGrowthName.textContent = stage.name;
        qfsShowScreen('midpoint');
      }

      /* ── Complete ──────────────────────────────────── */

      function showComplete() {
        /* Mark session completed */
        if (storageData.progress.completedSessions.indexOf(SESSION_NUMBER) === -1) {
          storageData.progress.completedSessions.push(SESSION_NUMBER);
        }
        saveStorage(storageData);

        var stage = getGrowthStage(storageData.progress.answeredCount);
        qfsUI.completeEmoji.textContent = stage.emoji;
        qfsUI.completeGrowthEmoji.textContent = stage.emoji;
        qfsUI.completeGrowthName.textContent = stage.name;

        /* Stats */
        var answered = 0;
        var skipped = 0;
        var keys = Object.keys(storageData.answers);
        var i;
        for (i = 0; i < keys.length; i += 1) {
          if (keys[i].charAt(0) === 'D') {
            if (storageData.answers[keys[i]].skipped) {
              skipped += 1;
            } else {
              answered += 1;
            }
          }
        }
        qfsUI.statAnswered.textContent = answered;
        qfsUI.statSkipped.textContent = skipped;

        /* Overall progress */
        var overallPct = Math.round((storageData.progress.answeredCount / TOTAL_QUESTIONS) * 100);
        qfsUI.overallPercent.textContent = overallPct + '%';
        setTimeout(function () {
          qfsUI.overallBar.style.width = overallPct + '%';
        }, 100);

        /* Messages */
        qfsUI.completeMsg.textContent = '話し方の設定ができました。最後に事業の核心を固めます。';
        var remaining = TOTAL_QUESTIONS - storageData.progress.answeredCount;
        qfsUI.remainingMsg.textContent = 'あと' + remaining + '問で、分身AIがあなたの言葉で話せるようになります。';

        qfsShowScreen('complete');
      }

      /* ── Find First Unanswered ─────────────────────── */

      function findFirstUnanswered() {
        var i;
        for (i = 0; i < QF_SOUL_QUESTIONS.length; i += 1) {
          var qid = QF_SOUL_QUESTIONS[i].id;
          if (!storageData.answers[qid]) {
            return i;
          }
        }
        return -1;
      }

      /* ── Initialization ────────────────────────────── */

      updateGrowthDisplay();

      /* Check if session already completed */
      var allAnswered = true;
      var k;
      for (k = 0; k < QF_SOUL_QUESTIONS.length; k += 1) {
        if (!storageData.answers[QF_SOUL_QUESTIONS[k].id]) {
          allAnswered = false;
          break;
        }
      }

      if (allAnswered && storageData.progress.completedSessions.indexOf(SESSION_NUMBER) !== -1) {
        /* Already completed - show complete screen */
        setTimeout(function () {
          showComplete();
        }, 100);
      }

      /* ── Event Listeners ───────────────────────────── */

      qfsUI.startButton.addEventListener('click', function () {
        var resumeIndex = findFirstUnanswered();
        if (resumeIndex === -1) {
          /* All answered */
          qfsState.index = 0;
        } else {
          qfsState.index = resumeIndex;
          /* If past midpoint, mark as shown */
          if (qfsState.index >= 4) {
            qfsState.showingMidpoint = true;
          }
        }
        qfsShowScreen('quiz');
        renderQuestion();
      });

      qfsUI.nextBtn.addEventListener('click', function () {
        handleNext();
      });

      qfsUI.skipBtn.addEventListener('click', function () {
        handleSkip();
      });

      qfsUI.continueBtn.addEventListener('click', function () {
        qfsShowScreen('quiz');
        renderQuestion();
      });

      qfsUI.endBtn.addEventListener('click', function () {
        qfsUI.saveConfirm.style.display = 'block';
      });

      var nextSessionBtn = qfOne('[data-qf-soul-action="next-session"]');
      if (nextSessionBtn) {
        nextSessionBtn.addEventListener('click', function (e) {
          e.preventDefault();
          window.location.href = '/soul-session5/?uid=' + encodeURIComponent(storageData.userId);
        });
      }
    })();
  
