LoginSignup
11
0

More than 3 years have passed since last update.

kintoneでいろんなリアクションをしよう!

Last updated at Posted at 2020-12-22

kintone Advent Calendar 2020 22日目の記事です。

はじめに

kintoneにはスレッドやコメントに「いいね!」できる機能があります。
でも、普段のコミュニケーションの中では「いいね!」以外を押したくなることありますよね?

例えば、そのコメントを読んだことを伝えたいだけだったり、すこし真面目な話に「いいね!」は押しにくかったり…

そこで、レコードにいろんなリアクションができるカスタマイズをしてみました😎

アプリの準備

アプリストアから「日報」アプリを追加しましょう。
以下のフィールドを追加してください。

フィールド名 フィールドの種類 フィールドコード 備考    
スペース space ※要素ID
グループ グループ グループ
グッドの数 数値 NUM_good 初期値:0
笑いの数 数値 NUM_haha 初期値:0
びっくりの数 数値 NUM_wow 初期値:0
ぴえんの数 数値 NUM_pien 初期値:0
悲しいの数 数値 NUM_sad 初期値:0

SVGファイルの準備

今回はSVGファイルをbase64エンコードすることで画像を表示しています。
私の場合は、パワポで画像作成して、以下のサイトでbase64エンコードしました。
https://lab.syncer.jp/Tool/Base64-encode/
私が作ったアイコン画像でよければご自由にご利用ください!

カスタマイズ

PC用のJavaScriptファイル

詳細画面表示時に、大きく分けて3つの処理をします。
1. アイコンの要素を作成
2. アイコンマウスオーバー時にアイコン切り替え
3. アイコンクリック時に数を更新

1. アイコンの要素を作成

詳細画面を表示した際に、スペースフィールドにアイコンを表示します。

detailShow.js
function createElementIcon() {
    var span = document.createElement('span');
    var input_radio1 = document.createElement('input');
    var input_radio2 = document.createElement('input');
    var input_radio3 = document.createElement('input');
    var input_radio4 = document.createElement('input');
    var input_radio5 = document.createElement('input');
    var i_1 = document.createElement('i');
    var i_2 = document.createElement('i');
    var i_3 = document.createElement('i');
    var i_4 = document.createElement('i');
    var i_5 = document.createElement('i');
    var massage = document.createElement('div');

    span.className = 'icon-rating';

    input_radio1.type = 'radio';
    input_radio2.type = 'radio';
    input_radio3.type = 'radio';
    input_radio4.type = 'radio';
    input_radio5.type = 'radio';

    input_radio1.name = 'rating';
    input_radio2.name = 'rating';
    input_radio3.name = 'rating';
    input_radio4.name = 'rating';
    input_radio5.name = 'rating';

    input_radio1.value = 'good';
    input_radio2.value = 'haha';
    input_radio3.value = 'wow';
    input_radio4.value = 'pien';
    input_radio5.value = 'sad';

    input_radio1.addEventListener('click', putHyoka, false);
    input_radio2.addEventListener('click', putHyoka, false);
    input_radio3.addEventListener('click', putHyoka, false);
    input_radio4.addEventListener('click', putHyoka, false);
    input_radio5.addEventListener('click', putHyoka, false);
    input_radio1.addEventListener('mouseover', mouseOverHyoka, false);
    input_radio2.addEventListener('mouseover', mouseOverHyoka, false);
    input_radio3.addEventListener('mouseover', mouseOverHyoka, false);
    input_radio4.addEventListener('mouseover', mouseOverHyoka, false);
    input_radio5.addEventListener('mouseover', mouseOverHyoka, false);

    i_1.className = 'good';
    i_2.className = 'haha';
    i_3.className = 'wow';
    i_4.className = 'pien';
    i_5.className = 'sad';

    span.appendChild(input_radio1);
    span.appendChild(i_1);
    span.appendChild(input_radio2);
    span.appendChild(i_2);
    span.appendChild(input_radio3);
    span.appendChild(i_3);
    span.appendChild(input_radio4);
    span.appendChild(i_4);
    span.appendChild(input_radio5);
    span.appendChild(i_5);

    kintone.app.record.getSpaceElement('space').append(span);
  }

2. アイコンクリック時にフィールドの値を更新

アイコンクリックした際に、グループの中のフィールドの値を+1します。

detailShow.js
function putHyoka() {
    var tgtFld = "NUM_" + this.value;
    var beforeValue = Number(event.record[tgtFld].value);
    var afterValue = beforeValue + 1;

    var body = {
      'app': kintone.app.getId(),
      'id': kintone.app.record.getId(),
      'record': {
        [tgtFld] : {
          'value': afterValue
        }
      }
    };

    kintone.api(kintone.api.url('/k/v1/record', true), 'PUT', body, function(resp) {
      // success
      console.log(resp);
    }, function(error) {
      // error
      console.log(error);
    });
}

3. アイコンマウスオーバー時にアイコン切り替え

CSSでもいろいろ設定していますが、マウスオーバーした際に、対象のアイコンのみ表示するようにします。

detailShow.js
function mouseOverHyoka() {
    switch (this.value) {
      case 'good':
        $('.icon-rating i.good')
          .eq(0)
          .css('opacity', '');
        break;
      case 'haha':
        $('.icon-rating i.haha')
          .eq(1)
          .css('opacity', '');
        break;
      case 'wow':
        $('.icon-rating i.wow')
          .eq(2)
          .css('opacity', '');
        break;
      case 'pien':
        $('.icon-rating i.pien')
          .eq(3)
          .css('opacity', '');
        break;
      case 'sad':
        $('.icon-rating i.sad')
          .eq(4)
          .css('opacity', '');
        break;
    }
}

PC用のCSSファイル

それぞれのアイコンの「background」に画像をエンコードした値を設定しています。
あとは、マウスオーバーした際の表示も設定しています。

detailShow.css
/* グレー背景 */
.icon-rating {
    font-size: 0;
    white-space: nowrap;
    display: inline-block;
    width: 250px;
    height: 50px;
    overflow: hidden;
    position: relative;
    background: url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzA0IiBoZWlnaHQ9IjMwNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgb3ZlcmZsb3c9ImhpZGRlbiI+PGRlZnM+PGNsaXBQYXRoIGlkPSJjbGlwMCI+PHBhdGggZD0iTTE4IDI4IDMyMiAyOCAzMjIgMzMyIDE4IDMzMloiIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIi8+PC9jbGlwUGF0aD48L2RlZnM+PGcgY2xpcC1wYXRoPSJ1cmwoI2NsaXAwKSIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTE4IC0yOCkiPjxwYXRoIGQ9Ik0xOSAxNzkuNUMxOSA5NS44Mjg4IDg2LjYwNSAyOCAxNzAgMjggMjUzLjM5NSAyOCAzMjEgOTUuODI4OCAzMjEgMTc5LjUgMzIxIDI2My4xNzEgMjUzLjM5NSAzMzEgMTcwIDMzMSA4Ni42MDUgMzMxIDE5IDI2My4xNzEgMTkgMTc5LjVaIiBmaWxsPSIjRDlEOUQ5IiBmaWxsLXJ1bGU9ImV2ZW5vZGQiLz48L2c+PC9zdmc+');
    background-size: contain;
  }

  /* グッドアイコン */
  .icon-rating i.good {
    opacity: 0;
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 20%;
    z-index: 1;
    background: url('data:image/svg+xml;base64,<svg width="305" height="305" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" overflow="hidden"><defs><clipPath id="clip0"><path d="M358 27 663 27 663 332 358 332Z" fill-rule="evenodd" clip-rule="evenodd"/></clipPath><image width="256" height="256" xlink:href="data:image/png;base64,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" preserveAspectRatio="none" id="img1"></image><clipPath id="clip2"><path d="M33.8866 0 133.512 0 133.512 133.512 33.8866 133.512Z" fill-rule="evenodd" clip-rule="evenodd"/></clipPath></defs><g clip-path="url(#clip0)" transform="translate(-358 -27)"><path d="M359.5 180C359.5 96.3289 427.329 28.5001 511 28.5001 594.671 28.5001 662.5 96.3289 662.5 180 662.5 263.671 594.671 331.5 511 331.5 427.329 331.5 359.5 263.671 359.5 180Z" stroke="#2F528F" stroke-miterlimit="8" fill="#FFD966" fill-rule="evenodd"/><path d="M0 16.5C-2.16433e-15 7.3873 7.61116-2.10067e-15 17-4.20134e-15 26.3888-8.40268e-15 34 7.3873 34 16.5 34 25.6127 26.3888 33 17 33 7.61116 33-1.08216e-14 25.6127 0 16.5Z" stroke="#2F528F" stroke-miterlimit="8" fill="#404040" fill-rule="evenodd" transform="matrix(-1 -8.74228e-08 -8.74228e-08 1 481.5 138.5)"/><path d="M0 16.5C-2.16433e-15 7.3873 7.61116-2.10067e-15 17-4.20134e-15 26.3888-8.40268e-15 34 7.3873 34 16.5 34 25.6127 26.3888 33 17 33 7.61116 33-1.08216e-14 25.6127 0 16.5Z" stroke="#2F528F" stroke-miterlimit="8" fill="#404040" fill-rule="evenodd" transform="matrix(-1 -8.74228e-08 -8.74228e-08 1 574.5 138.5)"/><path d="M555 207.5C555 223.24 536.868 236 514.5 236 492.132 236 474 223.24 474 207.5L488.25 207.5C488.25 215.37 500.003 221.75 514.5 221.75 528.997 221.75 540.75 215.37 540.75 207.5Z" fill="#C1272D" fill-rule="evenodd"/><g clip-path="url(#clip2)" transform="matrix(-0.861331 -0.508044 -0.508045 0.861334 678.956 231.836)"><use width="100%" height="100%" xlink:href="#img1" transform="scale(0.52153 0.52153)"></use></g></g></svg>');
    background-size: contain;
  }

  /* 笑いアイコン */
  .icon-rating i.haha {
    opacity: 0;
    position: absolute;
    left: 20%;
    top: 0;
    height: 100%;
    width: 20%;
    z-index: 1;
    background: url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzA1IiBoZWlnaHQ9IjMwNSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgb3ZlcmZsb3c9ImhpZGRlbiI+PGRlZnM+PGNsaXBQYXRoIGlkPSJjbGlwMCI+PHBhdGggZD0iTTY5OSAxMyAxMDA0IDEzIDEwMDQgMzE4IDY5OSAzMThaIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGNsaXAtcnVsZT0iZXZlbm9kZCIvPjwvY2xpcFBhdGg+PGltYWdlIHdpZHRoPSIxNTAiIGhlaWdodD0iMTUwIiB4bGluazpocmVmPSJkYXRhOmltYWdlL3BuZztiYXNlNjQsaVZCT1J3MEtHZ29BQUFBTlNVaEVVZ0FBQUpZQUFBQ1dDQU1BQUFBTDM0SFFBQUFBQVhOU1IwSUFyczRjNlFBQUFBUm5RVTFCQUFDeGp3djhZUVVBQUFERFVFeFVSUUFBQVA4QUFQOEFBTDlBUU13ek03WWtKTDhnSU13ek04SWtNY1VqTHNFbkxyMGtMTU1vTDc0bkxyOG1MYjhwTHNFb0xiOG5MTUVsTGNJb0xjSW9MNzhuTHNJcExMOG9MTUFvTHNBbkxjQW1MTUVtTHNBbUxiOG5MTUFtTGNBbkxjQW1MY0VvTHNBbkxjRW9Mc0VvTGNFb0xjSW1MY0lvTGNJbkxNRW9Mc0ltTHNFbkxjRW5MY0VvTGNFbkxjRW5MY0VuTGNFbkxjSW1MY0VvTGNFbkxjRW9MY0VuTGNFbkxjRW9MY0VuTGNFbkxzRW5MY0VuTGNFbkxjRW5MY0VuTGNFbkxYV3dOQVVBQUFCQWRGSk9Vd0FCQWdRRkJ3Z0tGUlloSXlZbktDd3RORDQvUjBoTFRFMVZYVjVsYUhGMmZvQ0NqSm1ncHFhc3JiTzV4c2ZLeTlIVDFOdmY0ZUxqNk9ycjd2UDMrLzZIb2tSYkFBQUFDWEJJV1hNQUFBc1RBQUFMRXdFQW1wd1lBQUFEdkVsRVFWUjRYdTJjNlZiaVFCQ0ZneWlJaUtQREV0bDNHR1VaRlRmYzhQMmZha0p5WFpCQWtrNHY5NXpoKzllZHBQcWVFK2hVZDFXWHRVTXY2VnkrWEd1MFhScTFjajZYeGdWVEhCYWIvY25UK3hwUGszNnptTUZOZWptcEQyK2hZZ08zdy9vSmJ0WkR5dTdkWSt3QTdudDJDZzhwWnQ4ZXZHRFFVTHdNN0gwOHFvN2o3aU9HaThCajl4aVBLeUZSR2kwd1VrUVdvMUlDUm1TVHJONWdFQ0Z1cWtrWWtzbGVaUWI3d3N3cWV6QW1qY0lWYk1maXFnQnpjc2hld201c0xyTXdHWitEMWl1TVN1QzFkUUN6TVRtN2hrVkpYSi9CY0J5U25UZVlrOFpiSi9aLzhtZ01XMUlaSDhHOElPZlBNQ1NaNTNNTUlFS2lMVGlwQjdOb0M4LzY2UXZZVU1LRm9MZVltY0tBSXFaQ2ptSTI5c2NtaUpuQTFIcjZnSWNWOG5DS3dVSnpPc2VqU3BsSDFLVkhWVlJkV1ExdjBPTWh3dThyby96WC9zVXM5UDh4L1JlUGFHRWFjdjVLS0oxRjE3a0lOOSszY2JzMjJoaDRLK2ZLdm9PYldJVDRiaDhwOGhtMjhSem81eVNWK0ZkQmpJUDh3ZzV1MUV3SHcyL2dUTHFISEk2M3JmNzlnZVRWUkhpdXQ2MkhXcmpKQUMxSThDRXJjVDBZbGRmTkgwZHBhMmNSTGlGaWpRSnVNTVNHL1lrOUtic2Y0bHo1NytkVWNOa1lGUWhaSWFuUnlmSm41amZYVjNIUklGVkkrVVlpMWc2a0hHN1dQYThTTGhtbEJERmZqSERGS0NPSStlUll1L1BueCtMbi9uMFhGd3pUaFJ5d0x4Q2JVTUhqYWh6R1JyZHhiQWp5R0tEWE9BTUlja2xGaW5tcDVPVjduSS9tSGE2K3hSNzZDT2hCMHBLUXNWUWQzRUdTd3dtNktQaUtiOWZSUTBFZG9peHJpQjRLaGhCbFdRR1pBM3E1aFNncmd3NFNEaUdyaURZSlJjaHFvazFDRTdMNmFKUFFoNndKMmlSTUlNc25wOGdrYzA5VkdrMGF2QjN4SEZvMDVGeFplYlJveUx1eXltalJVSFpsMWRDaW9lYkthcUJGUThPVnBUMllFb1FYYk5uSkNvY255MURnWWpPN2x4Z0ZUeGJwQkVFNm5aSitmRWcvMWFTT0Rha2JTT28wc3k0eFNCZGtwTXRYMHNYK0lkb2tmR3lOa0c0a3NXNjdrVzVTa203cGttNkFzNFlMU0lNcnBLRW8wc0FkYTVpVE5DaE1Ha0puVFRnZ1RjOWdUV1loVGYwaFRaUmlUU3NqVGNKalRWa2tUZkJrVFlkbFRSNG1UYlZtVFV3blRlTm5QZlRBZWtTRTlFQU42L0VqQThFV0w1Z1NCT25STml1dCtJandLbUVQQXJJZW0yUTlaS3J4U080dkRCZ1N6Z1BNck1lOVdRL0hzNVlTVUYxNDRZOWc0UVhXTWhVT2xFVTlIRGhMb0xBV2pIR2dMSy9qd0ZtTXlJR3lkTk1TeWtKWERweGx3UndvaTZndG9TdzU1OEpZb00rRnNweWhTOHJ1M1dIUUFQUVZmd1NFcFRJL2NBdUwramo5ODJWaDBjOHNDMFA4S01QNjIzZ1oxdjhNeS9vSGpBMG4wMHg5eVBVQUFBQUFTVVZPUks1Q1lJST0iIHByZXNlcnZlQXNwZWN0UmF0aW89Im5vbmUiIGlkPSJpbWcxIj48L2ltYWdlPjxjbGlwUGF0aCBpZD0iY2xpcDIiPjxwYXRoIGQ9Ik0wIDU0LjM0NDUgMTQ1IDU0LjM0NDUgMTQ1IDE0NSAwIDE0NVoiIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIi8+PC9jbGlwUGF0aD48L2RlZnM+PGcgY2xpcC1wYXRoPSJ1cmwoI2NsaXAwKSIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTY5OSAtMTMpIj48cGF0aCBkPSJNNzAwLjUgMTY2LjVDNzAwLjUgODMuMTA1IDc2OC4xMDUgMTUuNTAwMSA4NTEuNSAxNS41MDAxIDkzNC44OTUgMTUuNTAwMSAxMDAyLjUgODMuMTA1IDEwMDIuNSAxNjYuNSAxMDAyLjUgMjQ5Ljg5NSA5MzQuODk1IDMxNy41IDg1MS41IDMxNy41IDc2OC4xMDUgMzE3LjUgNzAwLjUgMjQ5Ljg5NSA3MDAuNSAxNjYuNVoiIHN0cm9rZT0iIzJGNTI4RiIgc3Ryb2tlLW1pdGVybGltaXQ9IjgiIGZpbGw9IiNGRkQ5NjYiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMikiIHRyYW5zZm9ybT0ibWF0cml4KDEgMCAtMCAxLjAwMzggNzg0IDEyNS40NDkpIj48dXNlIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIHhsaW5rOmhyZWY9IiNpbWcxIiB0cmFuc2Zvcm09InNjYWxlKDAuOTY2NjY3IDAuOTY2NjY3KSI+PC91c2U+PC9nPjxwYXRoIGQ9Ik03NzkuNDQzIDE1Ni40NjYgODI1LjE3OSAxMzguNDU4IDgyOC43NTQgMTQ3LjUzNyA3ODMuMDE4IDE2NS41NDVaIiBmaWxsPSIjNDA0MDQwIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiLz48cmVjdCB4PSI4Ljg2NTU4IiB5PSIxNS44NjQ3IiB3aWR0aD0iNDkuMTUzNSIgaGVpZ2h0PSI5Ljc1Nzc0IiBmaWxsPSIjNDA0MDQwIiB0cmFuc2Zvcm09Im1hdHJpeCgwLjkzMDQ3NSAwLjM2NjM1NSAwLjM2NjM1NSAtMC45MzA0NzUgNzY1LjM4MiAxNDMuMTUzKSIvPjxyZWN0IHg9IjguODY1NTgiIHk9IjE1Ljg2NDciIHdpZHRoPSI0OS4xNTM1IiBoZWlnaHQ9IjkuNzU3NzQiIGZpbGw9IiM0MDQwNDAiIHRyYW5zZm9ybT0ibWF0cml4KC0wLjkzMDQ3NSAtMC4zNjYzNTUgLTAuMzY2MzU1IDAuOTMwNDc1IDk0MC45NzggMTQyLjQ5OSkiLz48cGF0aCBkPSJNOTI2LjkxNyAxMjkuMTg3IDg4MS4xODEgMTQ3LjE5NCA4NzcuNjA2IDEzOC4xMTUgOTIzLjM0MiAxMjAuMTA3WiIgZmlsbD0iIzQwNDA0MCIgZmlsbC1ydWxlPSJldmVub2RkIi8+PC9nPjwvc3ZnPg==');
    background-size: contain;
  }

  /* びっくりアイコン */
  .icon-rating i.wow {
    opacity: 0;
    position: absolute;
    left: 40%;
    top: 0;
    height: 100%;
    width: 20%;
    z-index: 1;
    background: url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzA1IiBoZWlnaHQ9IjMwNSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgb3ZlcmZsb3c9ImhpZGRlbiI+PGRlZnM+PGNsaXBQYXRoIGlkPSJjbGlwMCI+PHBhdGggZD0iTTE4IDM2MiAzMjMgMzYyIDMyMyA2NjcgMTggNjY3WiIgZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiLz48L2NsaXBQYXRoPjxpbWFnZSB3aWR0aD0iMTUwIiBoZWlnaHQ9IjE1MCIgeGxpbms6aHJlZj0iZGF0YTppbWFnZS9wbmc7YmFzZTY0LGlWQk9SdzBLR2dvQUFBQU5TVWhFVWdBQUFKWUFBQUNXQ0FNQUFBQUwzNEhRQUFBQUFYTlNSMElBcnM0YzZRQUFBQVJuUVUxQkFBQ3hqd3Y4WVFVQUFBRERVRXhVUlFBQUFQOEFBUDhBQUw5QVFNd3pNN1lrSkw4Z0lNd3pNOElrTWNVakxzRW5McjBrTE1Nb0w3NG5McjhtTGI4cExzRW9MYjhuTE1FbExjSW9MY0lvTDc4bkxzSXBMTDhvTE1Bb0xzQW5MY0FtTE1FbUxzQW1MYjhuTE1BbUxjQW5MY0FtTGNFb0xzQW5MY0VvTHNFb0xjRW9MY0ltTGNJb0xjSW5MTUVvTHNJbUxzRW5MY0VuTGNFb0xjRW5MY0VuTGNFbkxjRW5MY0ltTGNFb0xjRW5MY0VvTGNFbkxjRW5MY0VvTGNFbkxjRW5Mc0VuTGNFbkxjRW5MY0VuTGNFbkxjRW5MWFd3TkFVQUFBQkFkRkpPVXdBQkFnUUZCd2dLRlJZaEl5WW5LQ3d0TkQ0L1IwaExURTFWWFY1bGFIRjJmb0NDakptZ3BxYXNyYk81eHNmS3k5SFQxTnZmNGVMajZPcnI3dlAzKy82SG9rUmJBQUFBQ1hCSVdYTUFBQXNUQUFBTEV3RUFtcHdZQUFBRHZFbEVRVlI0WHUyYzZWYmlRQkNGZ3lpSWlLUERFdGwzR0dVWkZUZmM4UDJmYWtKeVhaQkFrazR2OTV6aCs5ZWRwUHFlRStoVWQxV1h0VU12NlZ5K1hHdTBYUnExY2o2WHhnVlRIQmFiL2NuVCt4cFBrMzZ6bU1GTmVqbXBEMitoWWdPM3cvb0pidFpEeXU3ZFkrd0E3bnQyQ2c4cFp0OGV2R0RRVUx3TTdIMDhxbzdqN2lPR2k4Qmo5eGlQS3lGUkdpMHdVa1FXbzFJQ1JtU1RyTjVnRUNGdXFra1lrc2xlWlFiN3dzd3FlekFtamNJVmJNZmlxZ0J6Y3NoZXdtNXNMck13R1orRDFpdU1TdUMxZFFDek1UbTdoa1ZKWEovQmNCeVNuVGVZazhaYkovWi84bWdNVzFJWkg4RzhJT2ZQTUNTWjUzTU1JRUtpTFRpcEI3Tm9DOC82NlF2WVVNS0ZvTGVZbWNLQUlxWkNqbUkyOXNjbWlKbkExSHI2Z0ljVjhuQ0t3VUp6T3NlalNwbEgxS1ZIVlZSZFdRMXYwT01od3U4cm8velgvc1VzOVA4eC9SZVBhR0VhY3Y1S0tKMUYxN2tJTjkrM2NiczIyaGg0SytmS3ZvT2JXSVQ0Ymg4cDhobTI4UnpvNXlTVitGZEJqSVA4d2c1dTFFd0h3Mi9nVExxSEhJNjNyZjc5Z2VUVlJIaXV0NjJIV3JqSkFDMUk4Q0VyY1QwWWxkZk5IMGRwYTJjUkxpRmlqUUp1TU1TRy9ZazlLYnNmNGx6NTcrZFVjTmtZRlFoWklhblJ5ZkpuNWpmWFYzSFJJRlZJK1VZaTFnNmtIRzdXUGE4U0xobWxCREZmakhERktDT0krZVJZdS9QbngrTG4vbjBYRnd6VGhSeXdMeENiVU1IamFoekdScmR4YkFqeUdLRFhPQU1JY2tsRmlubXA1T1Y3bkkvbUhhNit4Ujc2Q09oQjBwS1FzVlFkM0VHU3d3bTZLUGlLYjlmUlEwRWRvaXhyaUI0S2hoQmxXUUdaQTNxNWhTZ3JndzRTRGlHcmlEWUpSY2hxb2sxQ0U3TDZhSlBRaDZ3SjJpUk1JTXNucDhna2MwOVZHazBhdkIzeEhGbzA1RnhaZWJSb3lMdXl5bWpSVUhabDFkQ2lvZWJLYXFCRlE4T1ZwVDJZRW9RWGJObkpDb2NueTFEZ1lqTzdseGdGVHhicEJFRTZuWkorZkVnLzFhU09EYWtiU09vMHN5NHhTQmRrcE10WDBzWCtJZG9rZkd5TmtHNGtzVzY3a1c1U2ttN3BrbTZBczRZTFNJTXJwS0VvMHNBZGE1aVROQ2hNR2tKblRUZ2dUYzlnVFdZaFRmMGhUWlJpVFNzalRjSmpUVmtrVGZCa1RZZGxUUjRtVGJWbVRVd25UZU5uUGZUQWVrU0U5RUFONi9FakE4RVdMNWdTQk9uUk5pdXQrSWp3S21FUEFySWVtMlE5WktyeFNPNHZEQmdTemdQTXJNZTlXUS9IczVZU1VGMTQ0WTlnNFFYV01oVU9sRVU5SERoTG9MQVdqSEdnTEsvandGbU15SUd5ZE5NU3lrSlhEcHhsd1J3b2k2Z3RvU3c1NThKWW9NK0ZzcHloUzhydTNXSFFBUFFWZndTRXBUSS9jQXVMK2pqOTgyVmgwYzhzQzBQOEtNUDYyM2daMXY4TXkvb0hqQTBuMDB4OXlQVUFBQUFBU1VWT1JLNUNZSUk9IiBwcmVzZXJ2ZUFzcGVjdFJhdGlvPSJub25lIiBpZD0iaW1nMSI+PC9pbWFnZT48Y2xpcFBhdGggaWQ9ImNsaXAyIj48cGF0aCBkPSJNMCAwLjAwMDg4IDg4IDAuMDAwODggODggODggMCA4OFoiIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIi8+PC9jbGlwUGF0aD48L2RlZnM+PGcgY2xpcC1wYXRoPSJ1cmwoI2NsaXAwKSIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTE4IC0zNjIpIj48cGF0aCBkPSJNMTkuNTAwMSA1MTQuNUMxOS41MDAxIDQzMS4xMDUgODcuMTA1IDM2My41IDE3MC41IDM2My41IDI1My44OTUgMzYzLjUgMzIxLjUgNDMxLjEwNSAzMjEuNSA1MTQuNSAzMjEuNSA1OTcuODk1IDI1My44OTUgNjY1LjUgMTcwLjUgNjY1LjUgODcuMTA1IDY2NS41IDE5LjUwMDEgNTk3Ljg5NSAxOS41MDAxIDUxNC41WiIgc3Ryb2tlPSIjMkY1MjhGIiBzdHJva2UtbWl0ZXJsaW1pdD0iOCIgZmlsbD0iI0ZGRDk2NiIgZmlsbC1ydWxlPSJldmVub2RkIi8+PHBhdGggZD0iTTAgMTdDLTIuMTAwNjdlLTE1IDcuNjExMTYgNy4zODczLTIuMTY0MzNlLTE1IDE2LjUtNC4zMjg2NWUtMTUgMjUuNjEyNy04LjY1NzMxZS0xNSAzMyA3LjYxMTE2IDMzIDE3IDMzIDI2LjM4ODggMjUuNjEyNyAzNCAxNi41IDM0IDcuMzg3MyAzNC0xLjA1MDM0ZS0xNCAyNi4zODg4IDAgMTdaIiBzdHJva2U9IiMyRjUyOEYiIHN0cm9rZS1taXRlcmxpbWl0PSI4IiBmaWxsPSIjNDA0MDQwIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIHRyYW5zZm9ybT0ibWF0cml4KC0xIC04Ljc0MjI4ZS0wOCAtOC43NDIyOGUtMDggMSAxNDIuNSA0NjkuNSkiLz48cGF0aCBkPSJNMCAxN0MtMi4xMDA2N2UtMTUgNy42MTExNiA3LjM4NzMtMi4xNjQzM2UtMTUgMTYuNS00LjMyODY1ZS0xNSAyNS42MTI3LTguNjU3MzFlLTE1IDMzIDcuNjExMTYgMzMgMTcgMzMgMjYuMzg4OCAyNS42MTI3IDM0IDE2LjUgMzQgNy4zODczIDM0LTEuMDUwMzRlLTE0IDI2LjM4ODggMCAxN1oiIHN0cm9rZT0iIzJGNTI4RiIgc3Ryb2tlLW1pdGVybGltaXQ9IjgiIGZpbGw9IiM0MDQwNDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIgdHJhbnNmb3JtPSJtYXRyaXgoLTEgLTguNzQyMjhlLTA4IC04Ljc0MjI4ZS0wOCAxIDIzNS41IDQ2OS41KSIvPjxwYXRoIGQ9Ik0xMDIuNzYyIDQzNy45OTRDMTAxLjc4OCA0MzAuNDExIDExMi42ODcgNDIyLjc2MiAxMjcuMTA2IDQyMC45MDkgMTQxLjUyNSA0MTkuMDU3IDE1NC4wMDQgNDIzLjcwMyAxNTQuOTc4IDQzMS4yODdMMTQ4LjExMiA0MzIuMTY5QzE0Ny42MjUgNDI4LjM3NyAxMzguNjE1IDQyNi40MSAxMjcuOTg4IDQyNy43NzUgMTE3LjM2MSA0MjkuMTQgMTA5LjE0IDQzMy4zMjEgMTA5LjYyNyA0MzcuMTEyWiIgc3Ryb2tlPSIjMkY1MjhGIiBzdHJva2Utd2lkdGg9IjEuMzMzMzMiIHN0cm9rZS1taXRlcmxpbWl0PSI4IiBmaWxsPSIjNDA0MDQwIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiLz48cGF0aCBkPSJNMCAxNC4xMTU2Qy0zLjM1MTJlLTE1IDYuMzE5NzkgMTEuNzg1LTUuMDI2ODFlLTE1IDI2LjMyMjUtNi43MDI0MWUtMTUgNDAuODYtMS4wMDUzNmUtMTQgNTIuNjQ0OSA2LjMxOTc5IDUyLjY0NDkgMTQuMTE1Nkw0NS41ODcyIDE0LjExNTZDNDUuNTg3MiAxMC4yMTc3IDM2Ljk2MjEgNy4wNTc3OSAyNi4zMjI1IDcuMDU3NzkgMTUuNjgyOSA3LjA1Nzc5IDcuMDU3NzggMTAuMjE3NyA3LjA1Nzc4IDE0LjExNTZaIiBzdHJva2U9IiMyRjUyOEYiIHN0cm9rZS13aWR0aD0iMS4zMzMzMyIgc3Ryb2tlLW1pdGVybGltaXQ9IjgiIGZpbGw9IiM0MDQwNDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIgdHJhbnNmb3JtPSJtYXRyaXgoLTAuOTkxODUgLTAuMTI3NDA4IC0wLjEyNzQwOCAwLjk5MTg1IDI1NC4yNzIgNDI0LjA0OSkiLz48ZyBjbGlwLXBhdGg9InVybCgjY2xpcDIpIiB0cmFuc2Zvcm09Im1hdHJpeCgxIDAgLTAgMS4yNzI3MyAxMjcgNTE1Ljk5OSkiPjx1c2Ugd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgeGxpbms6aHJlZj0iI2ltZzEiIHRyYW5zZm9ybT0ic2NhbGUoMC41ODY2NjcgMC41ODY2NjcpIj48L3VzZT48L2c+PC9nPjwvc3ZnPg==');
    background-size: contain;
  }

  /* ぴえんアイコン */
  .icon-rating i.pien {
    opacity: 0;
    position: absolute;
    left: 60%;
    top: 0;
    height: 100%;
    width: 20%;
    z-index: 1;
    background: url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzA1IiBoZWlnaHQ9IjMwNSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgb3ZlcmZsb3c9ImhpZGRlbiI+PGRlZnM+PGNsaXBQYXRoIGlkPSJjbGlwMCI+PHBhdGggZD0iTTM1OCAzNTkgNjYzIDM1OSA2NjMgNjY0IDM1OCA2NjRaIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGNsaXAtcnVsZT0iZXZlbm9kZCIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0zNTggLTM1OSkiPjxwYXRoIGQ9Ik0zNTkuNSA1MTEuNUMzNTkuNSA0MjguMTA1IDQyNy4zMjkgMzYwLjUgNTExIDM2MC41IDU5NC42NzEgMzYwLjUgNjYyLjUgNDI4LjEwNSA2NjIuNSA1MTEuNSA2NjIuNSA1OTQuODk1IDU5NC42NzEgNjYyLjUgNTExIDY2Mi41IDQyNy4zMjkgNjYyLjUgMzU5LjUgNTk0Ljg5NSAzNTkuNSA1MTEuNVoiIHN0cm9rZT0iIzJGNTI4RiIgc3Ryb2tlLW1pdGVybGltaXQ9IjgiIGZpbGw9IiNGRkQ5NjYiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjxwYXRoIGQ9Ik0wIDI2LjVDLTMuMzczOGUtMTUgMTEuODY0NSAxMS44NjQ1LTMuMzczOGUtMTUgMjYuNS02Ljc0NzYxZS0xNSA0MS4xMzU1LTEuMzQ5NTJlLTE0IDUzIDExLjg2NDUgNTMgMjYuNSA1MyA0MS4xMzU1IDQxLjEzNTUgNTMgMjYuNSA1MyAxMS44NjQ1IDUzLTEuNjg2OWUtMTQgNDEuMTM1NSAwIDI2LjVaIiBzdHJva2U9IiMyRjUyOEYiIHN0cm9rZS1taXRlcmxpbWl0PSI4IiBmaWxsPSIjNDA0MDQwIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIHRyYW5zZm9ybT0ibWF0cml4KC0xIC04Ljc0MjI4ZS0wOCAtOC43NDIyOGUtMDggMSA0OTEuNSA0NjcuNSkiLz48cGF0aCBkPSJNNDQyLjUgNDg2QzQ0Mi41IDQ3OS42NDkgNDQ3LjY0OSA0NzQuNSA0NTQgNDc0LjUgNDYwLjM1MSA0NzQuNSA0NjUuNSA0NzkuNjQ5IDQ2NS41IDQ4NiA0NjUuNSA0OTIuMzUxIDQ2MC4zNTEgNDk3LjUgNDU0IDQ5Ny41IDQ0Ny42NDkgNDk3LjUgNDQyLjUgNDkyLjM1MSA0NDIuNSA0ODZaIiBzdHJva2U9IiMyRjUyOEYiIHN0cm9rZS1taXRlcmxpbWl0PSI4IiBmaWxsPSIjRkZGRkZGIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiLz48cGF0aCBkPSJNNDY1LjUgNTA1LjVDNDY1LjUgNTAxLjA4MiA0NjkuMDgyIDQ5Ny41IDQ3My41IDQ5Ny41IDQ3Ny45MTggNDk3LjUgNDgxLjUgNTAxLjA4MiA0ODEuNSA1MDUuNSA0ODEuNSA1MDkuOTE4IDQ3Ny45MTggNTEzLjUgNDczLjUgNTEzLjUgNDY5LjA4MiA1MTMuNSA0NjUuNSA1MDkuOTE4IDQ2NS41IDUwNS41WiIgc3Ryb2tlPSIjMkY1MjhGIiBzdHJva2UtbWl0ZXJsaW1pdD0iOCIgZmlsbD0iI0ZGRkZGRiIgZmlsbC1ydWxlPSJldmVub2RkIi8+PHBhdGggZD0iTTQ3Mi41IDQ4OC41QzQ3Mi41IDQ4NC4wODIgNDc2LjA4MiA0ODAuNSA0ODAuNSA0ODAuNSA0ODQuOTE4IDQ4MC41IDQ4OC41IDQ4NC4wODIgNDg4LjUgNDg4LjUgNDg4LjUgNDkyLjkxOCA0ODQuOTE4IDQ5Ni41IDQ4MC41IDQ5Ni41IDQ3Ni4wODIgNDk2LjUgNDcyLjUgNDkyLjkxOCA0NzIuNSA0ODguNVoiIHN0cm9rZT0iIzJGNTI4RiIgc3Ryb2tlLW1pdGVybGltaXQ9IjgiIGZpbGw9IiNGRkZGRkYiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjxwYXRoIGQ9Ik0wIDI2Qy0zLjMxMDE1ZS0xNSAxMS42NDA2IDExLjY0MDYtMy4zMTAxNWUtMTUgMjYtNi42MjAyOWUtMTUgNDAuMzU5NC0xLjMyNDA2ZS0xNCA1MiAxMS42NDA2IDUyIDI2IDUyIDQwLjM1OTQgNDAuMzU5NCA1MiAyNiA1MiAxMS42NDA2IDUyLTEuNjU1MDdlLTE0IDQwLjM1OTQgMCAyNloiIHN0cm9rZT0iIzJGNTI4RiIgc3Ryb2tlLW1pdGVybGltaXQ9IjgiIGZpbGw9IiM0MDQwNDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIgdHJhbnNmb3JtPSJtYXRyaXgoLTEgLTguNzQyMjhlLTA4IC04Ljc0MjI4ZS0wOCAxIDU4Mi41IDQ2Ni41KSIvPjxwYXRoIGQ9Ik01MzMuNSA0ODVDNTMzLjUgNDc4LjY0OSA1MzguNjQ5IDQ3My41IDU0NSA0NzMuNSA1NTEuMzUxIDQ3My41IDU1Ni41IDQ3OC42NDkgNTU2LjUgNDg1IDU1Ni41IDQ5MS4zNTEgNTUxLjM1MSA0OTYuNSA1NDUgNDk2LjUgNTM4LjY0OSA0OTYuNSA1MzMuNSA0OTEuMzUxIDUzMy41IDQ4NVoiIHN0cm9rZT0iIzJGNTI4RiIgc3Ryb2tlLW1pdGVybGltaXQ9IjgiIGZpbGw9IiNGRkZGRkYiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjxwYXRoIGQ9Ik01NTYuNSA1MDQuNUM1NTYuNSA1MDAuMDgyIDU2MC4wODIgNDk2LjUgNTY0LjUgNDk2LjUgNTY4LjkxOCA0OTYuNSA1NzIuNSA1MDAuMDgyIDU3Mi41IDUwNC41IDU3Mi41IDUwOC45MTggNTY4LjkxOCA1MTIuNSA1NjQuNSA1MTIuNSA1NjAuMDgyIDUxMi41IDU1Ni41IDUwOC45MTggNTU2LjUgNTA0LjVaIiBzdHJva2U9IiMyRjUyOEYiIHN0cm9rZS1taXRlcmxpbWl0PSI4IiBmaWxsPSIjRkZGRkZGIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiLz48cGF0aCBkPSJNNTYzLjUgNDg3LjVDNTYzLjUgNDgzLjA4MiA1NjcuMDgyIDQ3OS41IDU3MS41IDQ3OS41IDU3NS45MTggNDc5LjUgNTc5LjUgNDgzLjA4MiA1NzkuNSA0ODcuNSA1NzkuNSA0OTEuOTE4IDU3NS45MTggNDk1LjUgNTcxLjUgNDk1LjUgNTY3LjA4MiA0OTUuNSA1NjMuNSA0OTEuOTE4IDU2My41IDQ4Ny41WiIgc3Ryb2tlPSIjMkY1MjhGIiBzdHJva2UtbWl0ZXJsaW1pdD0iOCIgZmlsbD0iI0ZGRkZGRiIgZmlsbC1ydWxlPSJldmVub2RkIi8+PHBhdGggZD0iTTQ3MC41IDU4NkM0NzAuNSA1NzAuMjYgNDg4LjYzMyA1NTcuNSA1MTEgNTU3LjUgNTMzLjM2OCA1NTcuNSA1NTEuNSA1NzAuMjYgNTUxLjUgNTg2TDUzNy4yNSA1ODZDNTM3LjI1IDU3OC4xMyA1MjUuNDk4IDU3MS43NSA1MTEgNTcxLjc1IDQ5Ni41MDMgNTcxLjc1IDQ4NC43NSA1NzguMTMgNDg0Ljc1IDU4NloiIHN0cm9rZT0iIzJGNTI4RiIgc3Ryb2tlLW1pdGVybGltaXQ9IjgiIGZpbGw9IiM0MDQwNDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjxwYXRoIGQ9Ik00NzAuOTg4IDQyNy43NjdDNDc0LjUzNCA0MzMuOTUyIDQ2Ny4xODMgNDQ0LjgyNyA0NTQuNTcxIDQ1Mi4wNTcgNDQxLjk1OCA0NTkuMjg2IDQyOC44NiA0NjAuMTMyIDQyNS4zMTQgNDUzLjk0N0w0MzAuOTE0IDQ1MC43MzdDNDMyLjY4NyA0NTMuODMgNDQxLjg0MSA0NTEuOTEzIDQ1MS4zNjEgNDQ2LjQ1NyA0NjAuODgxIDQ0MSA0NjcuMTYxIDQzNC4wNjkgNDY1LjM4OCA0MzAuOTc3WiIgc3Ryb2tlPSIjMkY1MjhGIiBzdHJva2Utd2lkdGg9IjEuMzMzMzMiIHN0cm9rZS1taXRlcmxpbWl0PSI4IiBmaWxsPSIjNDA0MDQwIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiLz48cGF0aCBkPSJNMCAxMi45MDkyQy0zLjM1MTJlLTE1IDUuNzc5NjQgMTEuNzg1LTMuMzUxMmUtMTUgMjYuMzIyNS02LjcwMjQxZS0xNSA0MC44Ni0xLjAwNTM2ZS0xNCA1Mi42NDQ5IDUuNzc5NjQgNTIuNjQ0OSAxMi45MDkyTDQ2LjE5MDMgMTIuOTA5MkM0Ni4xOTAzIDkuMzQ0NDEgMzcuMjk1MiA2LjQ1NDU5IDI2LjMyMjUgNi40NTQ1OSAxNS4zNDk3IDYuNDU0NTkgNi40NTQ1OSA5LjM0NDQxIDYuNDU0NTkgMTIuOTA5MloiIHN0cm9rZT0iIzJGNTI4RiIgc3Ryb2tlLXdpZHRoPSIxLjMzMzMzIiBzdHJva2UtbWl0ZXJsaW1pdD0iOCIgZmlsbD0iIzQwNDA0MCIgZmlsbC1ydWxlPSJldmVub2RkIiB0cmFuc2Zvcm09Im1hdHJpeCgwLjg2NzU4MSAwLjQ5NzI5NiAwLjQ5NzI5NiAtMC44Njc1ODEgNTQ5LjczNiA0NDAuMTU1KSIvPjwvZz48L3N2Zz4=');
    background-size: contain;
  }

  /* 悲しいアイコン */
  .icon-rating i.sad {
    opacity: 0;
    position: absolute;
    left: 80%;
    top: 0;
    height: 100%;
    width: 20%;
    z-index: 1;
    background: url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzA1IiBoZWlnaHQ9IjMwNSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgb3ZlcmZsb3c9ImhpZGRlbiI+PGRlZnM+PGNsaXBQYXRoIGlkPSJjbGlwMCI+PHBhdGggZD0iTTY5OSAzNTEgMTAwNCAzNTEgMTAwNCA2NTYgNjk5IDY1NloiIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIi8+PC9jbGlwUGF0aD48Y2xpcFBhdGggaWQ9ImNsaXAxIj48cGF0aCBkPSJNODgxIDQ4NCA5NzcgNDg0IDk3NyA1ODAgODgxIDU4MFoiIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIi8+PC9jbGlwUGF0aD48Y2xpcFBhdGggaWQ9ImNsaXAyIj48cGF0aCBkPSJNODgxIDQ4NCA5NzcgNDg0IDk3NyA1ODAgODgxIDU4MFoiIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIi8+PC9jbGlwUGF0aD48Y2xpcFBhdGggaWQ9ImNsaXAzIj48cGF0aCBkPSJNODgxIDQ4NCA5NzcgNDg0IDk3NyA1ODAgODgxIDU4MFoiIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIi8+PC9jbGlwUGF0aD48L2RlZnM+PGcgY2xpcC1wYXRoPSJ1cmwoI2NsaXAwKSIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTY5OSAtMzUxKSI+PHBhdGggZD0iTTcwMC41IDUwMy41QzcwMC41IDQyMC4xMDUgNzY4LjEwNSAzNTIuNSA4NTEuNSAzNTIuNSA5MzQuODk1IDM1Mi41IDEwMDIuNSA0MjAuMTA1IDEwMDIuNSA1MDMuNSAxMDAyLjUgNTg2Ljg5NSA5MzQuODk1IDY1NC41IDg1MS41IDY1NC41IDc2OC4xMDUgNjU0LjUgNzAwLjUgNTg2Ljg5NSA3MDAuNSA1MDMuNVoiIHN0cm9rZT0iIzJGNTI4RiIgc3Ryb2tlLW1pdGVybGltaXQ9IjgiIGZpbGw9IiNGRkQ5NjYiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjxwYXRoIGQ9Ik0wIDE2LjVDLTIuMTAwNjdlLTE1IDcuMzg3MyA3LjM4NzMtMi4xMDA2N2UtMTUgMTYuNS00LjIwMTM0ZS0xNSAyNS42MTI3LTguNDAyNjhlLTE1IDMzIDcuMzg3MyAzMyAxNi41IDMzIDI1LjYxMjcgMjUuNjEyNyAzMyAxNi41IDMzIDcuMzg3MyAzMy0xLjA1MDM0ZS0xNCAyNS42MTI3IDAgMTYuNVoiIHN0cm9rZT0iIzJGNTI4RiIgc3Ryb2tlLW1pdGVybGltaXQ9IjgiIGZpbGw9IiM0MDQwNDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIgdHJhbnNmb3JtPSJtYXRyaXgoLTEgLTguNzQyMjhlLTA4IC04Ljc0MjI4ZS0wOCAxIDgyMS41IDQ1Mi41KSIvPjxwYXRoIGQ9Ik0wIDE2LjVDLTIuMTAwNjdlLTE1IDcuMzg3MyA3LjM4NzMtMi4xMDA2N2UtMTUgMTYuNS00LjIwMTM0ZS0xNSAyNS42MTI3LTguNDAyNjhlLTE1IDMzIDcuMzg3MyAzMyAxNi41IDMzIDI1LjYxMjcgMjUuNjEyNyAzMyAxNi41IDMzIDcuMzg3MyAzMy0xLjA1MDM0ZS0xNCAyNS42MTI3IDAgMTYuNVoiIHN0cm9rZT0iIzJGNTI4RiIgc3Ryb2tlLW1pdGVybGltaXQ9IjgiIGZpbGw9IiM0MDQwNDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIgdHJhbnNmb3JtPSJtYXRyaXgoLTEgLTguNzQyMjhlLTA4IC04Ljc0MjI4ZS0wOCAxIDkxNC41IDQ1Mi41KSIvPjxwYXRoIGQ9Ik0wIDEyLjkwOTJDLTMuMzUxMmUtMTUgNS43Nzk2NCAxMS43ODUtMy4zNTEyZS0xNSAyNi4zMjI1LTYuNzAyNDFlLTE1IDQwLjg2LTEuMDA1MzZlLTE0IDUyLjY0NDkgNS43Nzk2NCA1Mi42NDQ5IDEyLjkwOTJMNDYuMTkwMyAxMi45MDkyQzQ2LjE5MDMgOS4zNDQ0MSAzNy4yOTUyIDYuNDU0NTkgMjYuMzIyNSA2LjQ1NDU5IDE1LjM0OTcgNi40NTQ1OSA2LjQ1NDU5IDkuMzQ0NDEgNi40NTQ1OSAxMi45MDkyWiIgc3Ryb2tlPSIjMkY1MjhGIiBzdHJva2Utd2lkdGg9IjEuMzMzMzMiIHN0cm9rZS1taXRlcmxpbWl0PSI4IiBmaWxsPSIjNDA0MDQwIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIHRyYW5zZm9ybT0ibWF0cml4KC0wLjgwMzIyMyAtMC41OTU2NzggLTAuNTk1Njc4IDAuODAzMjIzIDk1Mi4zNiA0NTMuMjA0KSIvPjxwYXRoIGQ9Ik03NjYuMDg3IDQ2My41NzNDNzYxLjg0IDQ1Ny44NDcgNzY3Ljg2MyA0NDYuMTg0IDc3OS41NCA0MzcuNTI1IDc5MS4yMTcgNDI4Ljg2NSA4MDQuMTI2IDQyNi40ODcgODA4LjM3MiA0MzIuMjE0TDgwMy4xODggNDM2LjA1OUM4MDEuMDY1IDQzMy4xOTUgNzkyLjE5OCA0MzYuMTczIDc4My4zODUgNDQyLjcwOSA3NzQuNTcxIDQ0OS4yNDUgNzY5LjE0OCA0NTYuODY1IDc3MS4yNzEgNDU5LjcyOVoiIHN0cm9rZT0iIzJGNTI4RiIgc3Ryb2tlLXdpZHRoPSIxLjMzMzMzIiBzdHJva2UtbWl0ZXJsaW1pdD0iOCIgZmlsbD0iIzQwNDA0MCIgZmlsbC1ydWxlPSJldmVub2RkIi8+PHBhdGggZD0iTTgxNi41IDU0OUM4MTYuNSA1MzMuMjYgODM0Ljg1NiA1MjAuNSA4NTcuNSA1MjAuNSA4ODAuMTQ0IDUyMC41IDg5OC41IDUzMy4yNiA4OTguNSA1NDlMODg0LjI1IDU0OUM4ODQuMjUgNTQxLjEzIDg3Mi4yNzQgNTM0Ljc1IDg1Ny41IDUzNC43NSA4NDIuNzI2IDUzNC43NSA4MzAuNzUgNTQxLjEzIDgzMC43NSA1NDlaIiBzdHJva2U9IiMyRjUyOEYiIHN0cm9rZS1taXRlcmxpbWl0PSI4IiBmaWxsPSIjNDA0MDQwIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiLz48ZyBjbGlwLXBhdGg9InVybCgjY2xpcDEpIj48ZyBjbGlwLXBhdGg9InVybCgjY2xpcDIpIj48ZyBjbGlwLXBhdGg9InVybCgjY2xpcDMpIj48cGF0aCBkPSJNOTI5IDQ5NEM5MjkgNDk0IDkwNCA1MjkuMiA5MDQgNTQ1IDkwNCA1NTguOCA5MTUuMiA1NzAgOTI5IDU3MCA5NDIuOCA1NzAgOTU0IDU1OC44IDk1NCA1NDUgOTU0IDUyOS4xIDkyOSA0OTQgOTI5IDQ5NFoiIGZpbGw9IiMwMEIwRjAiLz48L2c+PC9nPjwvZz48L2c+PC9zdmc+');
    background-size: contain;
  }

  .icon-rating input {
    -moz-appearance: none;
    -webkit-appearance: none;
    opacity: 0;
    display: inline-block;
    width: 20%;
    height: 100%;
    margin: 0;
    padding: 0;
    z-index: 2;
    position: relative;
  }
  .icon-rating input:hover + i,
  .icon-rating input:checked + i {
    opacity: 1;
  }
  .icon-rating i ~ i {
    width: 40%;
  }
  .icon-rating i ~ i ~ i {
    width: 60%;
  }
  .icon-rating i ~ i ~ i ~ i {
    width: 80%;
  }
  .icon-rating i ~ i ~ i ~ i ~ i {
    width: 100%;
  }

結果

アイコンにマウスオーバーすると・・・
demo.gif

いろんなリアクションができました!!🙂😄😮🥺😢
手作り感満載のアイコンがいい味出してます(笑)
グループフィールドの値も+1されてます。

終わりに

今回は「誰が」押したかまでは分からない、何回でもクリックできるような仕様にしました。
「ユーザー選択フィールド」を追加して誰がそんなリアクションをしたのか分かるようにしてもいいな、と思いました。

🦒1年kintone案件に携わって
コードを書く機会が増えて、こういうフィールドコードにすれば処理がシンプルにかける、とか、
これをやりたいときは、この書き方のパターンで書けばいいんだとかだんだんと分かるようになってきました!
これからは、ただコードを書けるだけじゃなくて、
いいコード(メンテナンスしやすいとか、他の人が見てわかりやすいとか)を書くこと意識して
これからも経験を増やして、エンジニアとしても成長していきたいです。

参考サイト

11
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
11
0