Google AMP-날짜 선택기

AMP Datepicker는 사용자가 날짜를 선택할 수있는 페이지에 달력을 표시하는 amp 구성 요소입니다. AMP datepicker는 정적 달력처럼 표시되거나 입력 선택에 따라 버튼 클릭으로 표시 될 수 있습니다.

amp-date-picker를 작동 시키려면 페이지에 다음 스크립트를 추가해야합니다.

<script async custom-element = "amp-date-picker" 
   src = "https://cdn.ampproject.org/v0/amp-date-picker-0.1.js">
</script>

앰프 날짜 선택기 태그

amp-date-picker의 태그는 다음과 같습니다.

<amp-date-picker layout = "fixed-height" height = "360"></amp-date-picker>

지원되는 속성

amp-date-picker에 다음 속성이 지원됩니다.

Sr. 아니요 속성 및 설명
1

mode

사용 가능한 옵션은 정적 및 오버레이입니다. 정적의 경우 캘린더는 기본적으로 페이지에서 열립니다. 오버레이의 경우 상호 작용할 때 달력이 열립니다.

2

mode

사용 가능한 옵션은 단일 및 범위입니다. 단일의 경우 달력에서 하나의 날짜 만 선택할 수 있습니다. 범위를 사용하면 연속적인 범위에서 둘 이상의 날짜를 선택할 수 있습니다.

input-selector

이것은 날짜 입력을위한 queryselector 일 수 있습니다. 예를 들어, for id는 클래스의 #nameoftheid입니다. nameoftheclass. ID가 할당 된 태그의 날짜가 업데이트됩니다.

4

start-input-selector

이것은 날짜 입력을위한 queryselector 일 수 있습니다. 예를 들어, id는 #nameoftheid 클래스의 경우 .nameoftheclass입니다. ID가 할당 된 태그의 날짜가 업데이트됩니다.

5

end-input-selector

이것은 날짜 입력을위한 queryselector 일 수 있습니다. 예를 들어 id의 경우 #nameoftheid 클래스의 경우 .nameoftheclass입니다. ID가 할당 된 태그의 날짜가 업데이트됩니다.

6

min

사용자가 선택할 수있는 가장 빠른 날짜입니다. ISO 8601 날짜 형식이어야합니다. min 속성이 없으면 현재 날짜가 최소 날짜가됩니다.

7

max

사용자가 선택할 수있는 최신 날짜입니다. ISO 8601 날짜 형식이어야합니다. max 속성이 없으면 날짜 선택기에 최대 날짜가 없습니다.

8

month-format

선택한 날짜를 표시하는 데 필요한 월 형식입니다. 기본적으로 값은 "MMMM YYYY"입니다.

9

format

입력 상자 또는 선택기가 사용되는 모든 html 요소에 날짜를 표시 할 형식입니다. 기본적으로 "YYYY-MM-DD"입니다.

10

week-day-format

요일을 표시하는 형식입니다.

11

locale

달력보기를 표시 할 로캘입니다. 기본적으로 en입니다.

12

minimum-nights

사용자가 날짜 범위에서 선택해야하는 숙박 수입니다. 기본값은 "1"입니다. 값이 "0"이면 사용자가 시작 및 종료 날짜에 대해 동일한 날짜를 선택할 수 있습니다.

13

number-of-months

달력보기에서 한 번에 표시 할 개월 수입니다. 기본값은 "1"입니다.

14

first-day-of-week

한주의 첫 번째 요일로 지정할 요일 (0-6)입니다. 기본값은 "0"(일요일)입니다.

15

day-size

달력보기 표에있는 날짜 셀의 크기 (픽셀)입니다. 기본값은 39입니다.

주요 속성은 다음과 같습니다. typemode. 에 대한mode, 우리는 staticoverlay달력을 입력하십시오. 에 대한type 우리는 가질 수있다 singlerange옵션. 와type = ”single” 달력에서 날짜를 하나만 선택할 수 있습니다. type = ”range” 범위에서 둘 이상의 데이터를 선택할 수 있습니다.

이제 몇 가지 작업 예제를 통해 정적 및 오버레이 유형 달력에 대한 amp-date-picker를 이해하겠습니다.

AMP 정적 날짜 선택기

정적 유형 날짜 선택기의 경우 아래 예제와 같이 mode = static을 지정해야합니다.

<!doctype html>
<html amp lang = "en">
   <head>
      <meta charset = "utf-8">
      <script async src = "https://cdn.ampproject.org/v0.js"></script>
      <title>Google AMP - Amp Date-Picker Static </title>
      <link rel = "canonical" href = " http://example.ampproject.org/article-metadata.html">
      <meta name = "viewport" content = "width = device-width, minimum-scale = 1,initial-scale = 1">

      <style amp-boilerplate>
         body{
            -webkit-animation:
            -amp-start 8s steps(1,end) 0s 1 normal both;-moz-animation:
            -amp-start 8s steps(1,end) 0s 1 normal both;-ms-animation:
            -amp-start 8s steps(1,end) 0s 1 normal both;animation:
            -amp-start 8s steps(1,end) 0s 1 normal both
         }
         @-webkit-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@-moz-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@-ms-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@-o-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}
      </style>
      <noscript>
         <style amp-boilerplate>
            body{-webkit-animation:
            none;-moz-animation:none;-ms-animation:none;animation:none}
         </style>
      </noscript>

      <script async custom-element = "amp-date-picker" 
         src = "https://cdn.ampproject.org/v0/amp-date-picker-0.1.js">
      </script>

      <script async custom-element = "amp-bind" 
         src = "https://cdn.ampproject.org/v0/amp-bind-0.1.js">
      </script>
      <script async custom-template = "amp-mustache" 
         src = "https://cdn.ampproject.org/v0/amp-mustache-0.1.js">
      </script>

      <style>
         input[type = text]{
            width: 50%;
            padding: 12px;
            border: 1px 
            solid #ccc;
            border-radius: 4px;
            resize: vertical;
         }
         label {
            padding: 12px 12px 12px 0;display: inline-block;
         }
         .col-label {
            float: left;width: 25%;margin-top: 6px;
         }
         .col-content {
            float: left;width: 75%;margin-top: 6px;
         }
         .row:after {
            content: "";display: table;clear: both;
         }
         .amp_example {
            background-color: #f1f1f1;
            padding: 0.01em 16px;
            margin: 20px 0;
            box-shadow: 0 2px 4px 0 
            rgba(0,0,0,0.16),0 2px 10px 0 
            rgba(0,0,0,0.12)!important;
         }
         h3{font-family: "Segoe UI",Arial,sans-serif;
         font-weight: 400;margin: 10px 0;}
      </style>
   </head>
   <body>
      <div class = "amp_example">
         <h3>Google AMP - Amp Date-Picker using type = single</h3>
         <amp-date-picker 
            id = "static-date"
            type = "single"
            mode = "static"
            layout = "fixed-height"
            height = "600"
            format = "YYYY-MM-DD"
            input-selector = "#date">
            
            <div class = "row">
               <div class = "col-label">
                  <label for = "start">
                     Date is:
                  </label>
               </div>
               <div class = "col-content">
                  <input type = "text" id = "date" name = "date" 
                     placeholder = "Date Selected Is...">
               </div>
            </div>
         </amp-date-picker>
      <div>
   </body>
</html>

이 예제에서 우리는 기본적으로 화면에 달력, 즉 datepicker를 표시하고 있습니다.

사용자가 선택한 날짜는 아래의 데모 화면과 같이 텍스트 필드에 표시됩니다.

산출

amp-date-picker에서 선택한 날짜를 가져 오는 방법은 무엇입니까?

위의 예를 확인하면 다음과 같은 속성이 있습니다. input-selector텍스트 필드의 ID가 제공됩니다. 사용자가 날짜를 선택하면 입력 필드 안에 표시됩니다.

<amp-date-picker 
   id = "static-date"
   type = "single"
   mode = "static"
   layout = "fixed-height"
   height = "600"
   format = "YYYY-MM-DD"
   input-selector = "#date"
   
   <div class = "row">
      <div class = "col-label">
         <label for = "start">Date is:</label>
      </div>
      <div class = "col-content">
         <input type = "text" id = "date" name = "date" 
         placeholder = "Date Selected Is...">
      </div>
   </div>
   
</amp-date-picker>

다음과 같이 입력 선택기 속성에 이름 속성을 부여 할 수도 있습니다.

<amp-date-picker
   type = "single"
   mode = "static"
   layout = "container"
   input-selector = "[name = date]">
   <input type = "text" id = "date" name = "date" placeholder = "Date Selected Is...">
</amp-date-picker>

입력 선택기가 amp-date-picker보다 지정되지 않은 경우 숨겨진 입력 필드를 만들고 이름을 지정합니다. date or ${id}-date amp-date 선택기의 ID를 사용합니다.

날짜 선택기로 사용할 수있는 다른 속성을 가진 몇 가지 예를 더 설명하겠습니다. 위에서 언급했듯이 단일 날짜를 선택할 수 있습니다.type=”single”정적 모드입니다. 유형을 다음과 같이 지정하여 날짜 범위를 선택할 수도 있습니다.type=”range”.

<!doctype html>
<html amp lang = "en">
   <head>
      <meta charset = "utf-8">
      <script async src = "https://cdn.ampproject.org/v0.js"></script>
      <title>Google AMP - Amp Date-Picker Static </title>
      <link rel = "canonical" href = "http://example.ampproject.org/article-metadata.html">
      <meta name = "viewport" content = "width = device-width, minimum-scale = 1,initial-scale = 1">

      <style amp-boilerplate>
         body{-webkit-animation:
            -amp-start 8s steps(1,end) 0s 1 normal both;-moz-animation:
            -amp-start 8s steps(1,end) 0s 1 normal both;-ms-animation:
            -amp-start 8s steps(1,end) 0s 1 normal both;animation:
            -amp-start 8s steps(1,end) 0s 1 normal both
         }
         @-webkit-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@-moz-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@-ms-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@-o-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}
      </style>
      <noscript>
         <style amp-boilerplate>
            body{
            -webkit-animation:
            none;-moz-animation:none;-ms-animation:none;animation:none}
         </style>
      </noscript>

      <script async custom-element = "amp-date-picker" 
         src = "https://cdn.ampproject.org/v0/amp-date-picker-0.1.js">
      </script>

      <script async custom-element = "amp-bind" 
         src = "https://cdn.ampproject.org/v0/amp-bind-0.1.js">
      </script>

      <script async custom-template = "amp-mustache" 
         src = "https://cdn.ampproject.org/v0/amp-mustache-0.1.js">
      </script>

      <style>
         input[type = text]{
            width: 50%;
            padding: 12px;
            border: 1px solid #ccc;
            border-radius: 4px;
            resize: vertical;
         }
         label {padding: 12px 12px 12px 0;display: inline-block;}
         .col-label {float: left;width: 25%;margin-top: 6px;}
         .col-content {float: left;width: 75%;margin-top: 6px;}
         .row:after {content: "";display: table;clear: both;}
         .amp_example {
            background-color: #f1f1f1;
            padding: 0.01em 16px;
            margin: 20px 0;
            box-shadow: 0 2px 4px 0 
            rgba(0,0,0,0.16),0 2px 10px 0 
            rgba(0,0,0,0.12)!important;
         }
         h3{
            font-family: "Segoe UI",Arial,sans-serif;
            font-weight: 400;margin: 10px 0;
         }
      </style>
   </head>
   <body>
      <div class = "amp_example">
         <h3>Google AMP - Amp Date-Picker Static Multi Select Dates using type = range</h3>
         <amp-date-picker 
            id = "static-date"
            type = "range"
            mode = "static"
            layout = "fixed-height"
            height = "600"
            start-input-selector = "#start"
            end-input-selector = "#end"
            format = "YYYY-MM-DD"
            input-selector = "#static-date-input">
            
            <div class = "row">
               <div class = "col-label">
                  <label for = "start">Start Date:</label>
               </div>
               <div class = "col-content">
                  <input type = "text" id = "start" 
                  name = "start" placeholder = "Start Date">
               </div>
            </div>
            <div class = "row">
               <div class = "col-label">
                  <label for = "end">End Date:</label>
               </div>
               <div class = "col-content">
                  <input type = "text" id = "end" 
                  name = "end" placeholder = "End Date">
               </div>
            </div>
         </amp-date-picker>
      </div>
   </body>
</html>

산출

위에 표시된 코드의 출력은 다음과 같습니다.

How to get the start and end date using type= ”range” selected from amp-date-picker?

시작일과 종료일을 확인하기 위해 amp-date-picker 속성을 사용했습니다. start-input-selectorend-input-selector.

구문에 대한 자세한 내용은 다음과 같습니다.

<amp-date-picker 
   id = "static-date" 
   type = "range" 
   mode = "static" 
   layout = "fixed-height" 
   height = "600"
   start-input-selector = "#start" 
   end-input-selector="#end" 
   format = "YYYY-MM-DD" 
   input-selector = "#static-date-input">
   
   <input type = "text" id = "start" name = "start" placeholder="Start Date">
   <input type = "text" id = "end" name = "end" placeholder = "End Date">
</amp-date-picker>

두 선택자 모두 시작 및 종료 날짜를 표시 할 입력 필드 ID가 있습니다. 여기에 설명 된대로 입력 필드의 이름을 지정할 수도 있습니다.

AMP 오버레이 날짜 선택기

오버레이 모드 날짜 선택기의 경우 입력 필드에 대한 응답으로 달력이 표시됩니다. 정적 날짜 선택기에서 본 것처럼 type =”single”및 type =”range”로 오버레이 할 수 있습니다.

이제 오버레이 유형 날짜 선택기의 날짜 범위를 선택하는 작업 예를 살펴 보겠습니다.

<!doctype html>
<html amp lang = "en">
   <head>
      <meta charset = "utf-8">
      <script async src = "https://cdn.ampproject.org/v0.js"></script>
      <itle>Google AMP - Amp Date-Picker Static</title>
      <link rel = "canonical" href = "http://example.ampproject.org/article-metadata.html">
      <meta name = "viewport" content = "width = device-width,minimum-scale = 1,initial-scale = 1">
      <style amp-boilerplate>
         body{
            -webkit-animation:
            -amp-start 8s steps(1,end) 0s 1 normal both;-moz-animation:
            -amp-start 8s steps(1,end) 0s 1 normal both;-ms-animation:
            -amp-start 8s steps(1,end) 0s 1 normal both;animation:
            -amp-start 8s steps(1,end) 0s 1 normal both
         }
         @-webkit-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@-moz-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@-ms-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@-o-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}
      </style>
      <noscript>
         <style amp-boilerplate>
            body{
            -webkit-animation:
            none;-moz-animation:none;-ms-animation:none;animation:none}
         </style>
      </noscript>
   
      <script async custom-element = "amp-date-picker" 
         src = "https://cdn.ampproject.org/v0/amp-date-picker-0.1.js">
      </script>
      <script async custom-element = "amp-bind" 
         src = "https://cdn.ampproject.org/v0/amp-bind-0.1.js">
      </script>
      <script async custom-template = "amp-mustache" 
         src = "https://cdn.ampproject.org/v0/amp-mustache-0.1.js">
      </script>
   
      <style>
         input[type=text]{
            width: 50%;
            padding: 12px;border: 
            1px solid #ccc;
            border-radius: 4px;resize: vertical;
         }
         label {
            padding: 12px 12px 12px 0;
            display: inline-block; 
            font-family: "Segoe UI",Arial,sans-serif;
            font-weight: 400;
         }
         .col-label {float: left;width: 25%;margin-top: 6px;}
         .col-content {float: left;width: 75%;margin-top: 6px;}
         .row:after {content: "";display: table;clear: both;}
         .amp_example {
            background-color: #f1f1f1;
            padding: 0.01em 16px;
            margin: 20px 0;
            box-shadow: 0 2px 4px 0 
            rgba(0,0,0,0.16),0 2px 10px 0 
            rgba(0,0,0,0.12)!important;
         }
         h3{font-family: "Segoe UI",Arial,sans-serif;font-weight: 400;margin: 10px 0;}
         button { background-color: #ACAD5C; 
            color: white; 
            padding: 12px 20px; 
            border: none; 
            border-radius: 4px; 
            cursor: pointer; 
            float: right;
         }
      </style>
   </head>
   <body>
      <div class = "amp_example">
         <h3>Google AMP - Amp Date-Picker Overlay Multi Select Dates using type = rangelt;/h3>
         <amp-date-picker id = "overlay-date"
            type = "range"
            mode = "overlay"
            start-input-selector = "#start"
            end-input-selector = "#end"
            format = "YYYY-MM-DD"
            open-after-select
            input-selector = "#start">
            
            <div class = "row">
               <div class = "col-label">
                  <label for = "start">Start Date:lt;/label>
               </div>
               <div class = "col-content">
                  <input type = "text" id = "start" 
                     name = "start" placeholder = "Start Date">
               </div>
            </div>
            <div class = "row">
               <div class = "col-label">
                  <label for = "end">End Date:lt;/label>
               </div>
               <div class = "col-content">
                  <input type = "text" id="end" name = "end" 
                     placeholder = "End Date">
               </div>
            </div>
            <div class = "row">
               <div class = "col-label">
               </div>
               <div class = "col-content">
                  <button class = "ampstart-btn caps" on = "tap:overlay-date.clear">
                     Clear
                  </button>
               </div>
            </div>
        </amp-date-picker>
     </div>
  </body>
</html>

산출

위에 표시된 코드의 출력은 다음과 같습니다.

우리는 이미 시작일과 종료일을 얻는 방법을 보았습니다. 여기서 하나 이상의 속성을 사용했는지 확인하십시오.open-after-select. 이 속성은 선택한 후에도 오버레이를 열어 둡니다. 날짜 선택기 외부를 클릭하면 닫힙니다. clear라는 버튼도 추가되었습니다. 지우기 버튼을 클릭하면 선택한 날짜가 지워집니다.이를 수행하는 구문은 다음과 같습니다.

<button class = "ampstart-btn caps" on = "tap:overlay-date.clear">
   Clear
</button>

이벤트를 추가하려면 on속성. 이벤트에 대한 자세한 내용은Events이 튜토리얼의 장. 우리는 태그 동작을 사용했으며 datepicker의 ID가 주어졌고 선택된 날짜 범위를 지우는 이벤트를 지 웁니다.

다음으로 amp-date-picker를 라이트 박스로 사용하는 방법을 살펴 보겠습니다.

AMP 라이트 박스 날짜 선택기

날짜 선택기는 모달 창에서 사용할 수 있습니다. 라이트 박스 날짜 선택기를 사용할 수도 있습니다. 실제 예제의 도움으로 이것을 이해합시다.

라이트 박스 내에서 날짜 선택기를 사용하려면 아래와 같이 라이트 박스 스크립트를 추가해야합니다.

<script async custom-element = "amp-lightbox" 
   src = "https://cdn.ampproject.org/v0/amp-lightbox-0.1.js">
</script>

<!doctype html>
<html amp lang = "en">
   <head>
      <meta charset = "utf-8">
      <script async src = "https://cdn.ampproject.org/v0.js"></script>
      <title>Google AMP - Amp Date-Picker Static </title>
      <link rel = "canonical" href = "http://example.ampproject.org/article-metadata.html">
      <meta name = "viewport" content = "width=device-width,minimum-scale = 1,initial-scale = 1">

      <style amp-boilerplate>
         body{
            -webkit-animation:
            -amp-start 8s steps(1,end) 0s 1 normal both;-moz-animation:
            -amp-start 8s steps(1,end) 0s 1 normal both;-ms-animation:
            -amp-start 8s steps(1,end) 0s 1 normal both;animation:
            -amp-start 8s steps(1,end) 0s 1 normal both
         }
         @-webkit-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@-moz-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@-ms-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@-o-keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}@keyframes 
         -amp-start{from{visibility:hidden}to{visibility:visible}}
      </style>
      <noscript>
         <style amp-boilerplate>
            body{
               -webkit-animation:none;
               -moz-animation:none;
               -ms-animation:none;
               animation:none}
         </style>
      </noscript>

      <script async custom-element = "amp-date-picker" 
         src = "https://cdn.ampproject.org/v0/amp-date-picker-0.1.js">
      </script>

      <script async custom-element = "amp-bind" src = "
      https://cdn.ampproject.org/v0/amp-bind-0.1.js">
      <script>

      <script async custom-template = "amp-mustache" 
         src = "https://cdn.ampproject.org/v0/amp-mustache-0.1.js">
      </script>

      <script async custom-element = "amp-lightbox" 
         src = "https://cdn.ampproject.org/v0/amp-lightbox-0.1.js">
      </script>

      <style>
         input[type=text]{
            width: 50%;
            padding: 12px;
            border: 1px solid #ccc;
            border-radius: 4px;
            resize: vertical;
         }
         label {
            padding: 12px 12px 12px 0;
            display: inline-block; 
            font-family: "Segoe UI",Arial,sans-serif;
            font-weight: 400;
         }
         .col-label {
            float: left;width: 25%;
            margin-top: 6px;
         }
         .col-content {
            float: left;
            width: 75%;
            margin-top: 6px;
         }
         .row:after {
            content: "";
            display: table;clear: both;
         }
         .amp_example {
            background-color: #f1f1f1;
            padding: 0.01em 16px;
            margin: 20px 0;
            box-shadow: 0 2px 4px 0 rgba(0,0,0,0.16),0 2px 10px 0rgba(0,0,0,0.12)!important;
         }
         h3{font-family: "Segoe UI",Arial,sans-serif;
            font-weight: 400;
            margin: 10px 0;
         }
         button { 
            background-color: #ACAD5C; 
            color: white; 
            padding: 12px 20px; 
            border: none; 
            border-radius: 4px; 
            cursor: pointer; 
            float: right;
         }
         .lightbox {background-color: rgba(100, 100, 100, 0.5);}
      </style>
   </head>
   <body>
      <div class = "amp_example">
         <h3>Google AMP - Amp Date-Picker Overlay Multi Select Dates using type = range</h3>
         <div class = "row">
            <div class = "col-label">
               <label for = "start">Start Date:</label>
            <div>
            <div class = "col-content">
               <input type = "text" id = "start" name = 
               "start" placeholder = "Start Date" on = "tap:lightbox.open">
            </div>
         </div>
         <div class = "row">
            <div class = "col-label">
               <label for = "end">End Date:</label>
            </div>
            <div class = "col-content">
               <input type = "text" id = "end" name = 
                  "end" placeholder = "End Date" on = "tap:lightbox.open">
            </div>
         </div>
         <div class = "row">
            <div class = "col-label"></div>
            <div class = "col-content">
            <button class = "ampstart-btn caps" on = 
               "tap:overlay-date.clear">Clear</button>
            </div>
         </div>
         <amp-lightbox id = "lightbox" layout = "nodisplay" class = "lightbox">
            <amp-date-picker id = "overlay-date"
               type = "range"
               layout = "fill"
               start-input-selector = "#start"
               end-input-selector = "#end"
               format = "YYYY-MM-DD"
               on = "activate: lightbox.open;deactivate: lightbox.close">
            </amp-date-picker>
         </amp-lightbox>
      </div>
   </body>
</html>

산출

사용자가 입력 필드를 클릭하면 아래와 같이 라이트 박스 내부에서 날짜 선택기가 열립니다.

이를 수행하기 위해 아래와 같이 입력 필드에 이벤트가 추가됩니다.

<input type = "text" id = "start" name = "start" 
   placeholder = "Start Date" on = "tap:lightbox.open">

<input type = "text" id = "end" name = "end" 
   placeholder = "End Date" on = "tap:lightbox.open">

참고 “on” tap-lightbox.open을 호출하여 라이트 박스를 여는 이벤트입니다.

여기서 lightbox는 아래와 같이 amp-lightbox에 부여 된 ID입니다. Amp-date-picker는 amp-lightbox 내부에서 호출되며 입력 필드를 탭하면 활성화됩니다.

<amp-lightbox id = "lightbox" layout = "nodisplay" class = "lightbox">
   <amp-date-picker id = "overlay-date"
      type = "range"
      layout = "fill"
      start-input-selector = "#start"
      end-input-selector = "#end"
      format = "YYYY-MM-DD"
      on = "activate: lightbox.open;deactivate: lightbox.close">
   </amp-date-picker>
</amp-lightbox>