Skip to content

jinbonetwork/taogi-timeline

 
 

Repository files navigation

따오기 타임라인

**따오기 타임라인**은 진보네트워크센터에서 knight labTimelineJS에 미디어 관련 기능을 추가한 PHP & JavaScript 라이브러리입니다. 주된 특징은 다음과 같습니다.

  • 웹페이지 주소 분석 패턴을 추가했습니다.
  • 미디어 소스로 임베드 코드를 입력할 수 있습니다.
  • 타임라인 출력 모델을 선택할 수 있습니다.
  • 기본 모델 touchcarousel은 네 가지 추가기능을 포함합니다.
    • 터치 인터페이스
    • 갤러리 출력 기능
    • 스킨 선택 기능
    • 반응형 레이아웃이 적용된 기본 스킨

미리보기

목차

  1. 설치
    1. 요구 사항 확인
    2. 업로드
    3. 설정
    4. 내용 작성
    5. 배포
  2. 데이터 형식
    1. 구글 스프레드시트
    2. JSON 파일
  3. 지원하는 미디어 형식
  4. 라이선스

  1. 설치 =======

  2. 요구 사항 확인


따오기 타임라인은 PHP 5.2와 JavaScript로 동작하며, 외부 라이브러리들을 사용하고 있으므로 각 라이브러리들의 요구 사항도 충족되어야 합니다. 사용 중인 라이브러리들의 목록과 라이선스, 저장 위치는 다음과 같습니다.

라이브러리 라이선스 디렉토리
TimelineJS MPL model/timelineJS/
jQuery MIT resources/script/jquery-1.11.0.min.js
MediaElement.js MIT resources/mediaelement/
PDFObject MIT resources/pdfobject/
PHP Proxy MIT library/php-proxy/
Twitteroauth [?] library/twitteroauth/
FontAwesome OFL resources/font-awesome/
  1. 업로드

사용하고자 하는 웹서비스 디렉토리에 업로드한 뒤 권한을 확인합니다. 일반적인 환경이라면 cache 폴더의 other 쓰기 권한을 부여하는 것으로 충분합니다.

chmod 707 cache
디렉토리 권한 비고
cache 707 타임라인 JSON 파일을 저장합니다.
  1. 설정

(생략 가능) conf/config.php에서 기본 모델, 페이스북 앱 아이디, 언어 등의 기본 설정을 변경할 수 있습니다.

변수 기본값 선택지
$timelineConfig['default_model'] touchcarousel 4. 내용 작성 항목의 model 매개변수 참조
$timelineConfig['cache'] 60
$timelineConfig['cache_path'] ./cache
$timelineConfig['use_sns'] true true, false
$timelineConfig['fb_app'] 없음 페이스북 앱 아이디
$timelineConfig['theme'] defaults 4. 내용 작성 항목의 skinname 매개변수 참조
$timelineConfig['taogiauth'] 없음 임의의 문자열
$timelineConfig['lang'] ko_KR ko_KR, en_US
  1. 내용 작성

  1. 2. 데이터 형식 항목을 참조해서 타임라인으로 구성하고자 하는 내용을 작성합니다.
  2. 따오기 타임라인이 설치된 웹서비스 주소를 src 매개변수로 json 파일 경로를 지정해서 호출합니다.
http://yourdomain.com/taogi-timeline/?src=yourfile.json

src 매개변수와 같이 주소 형식으로 지정할 수 있는 설정값은 다음과 같습니다.

매개변수 기본값 선택지
src json 파일의 URI 없음(필수)
model 사용할 출력 모델 touchcarousel touchcarousel, timelineJS
skinname 사용할 스킨 이름 default
  1. 데이터 형식 ==============

  2. 구글 스프레드시트


TimelineJS에서 지원하는 스프레드시트 형식을 그대로 쓸 수 있습니다. 단, 이 경우에는 갤러리를 사용할 수 없게 됩니다.

  1. JSON 파일

따오기 타임라인에서 사용하는 JSON 파일은 TimelineJS에서 사용하는 JSON 파일 형식에 추가정보와 각 슬라이드별 갤러리 항목을 추가한 것입니다. 다음 JSON 예제들을 참고하세요.

또는, TimelineJS의 예제들을 확인할 수 있습니다. TimelineJS 형식의 JSON 파일을 사용할 경우에는 추가 기능이 적용되지 않습니다.

  1. 지원하는 미디어 형식 =======================

media 필드에는 TimelineJS와 마찬가지로 몇 가지 형식의 미디어 소스를 입력할 수 있습니다. 기본적으로는 웹페이지 주소를 입력받아 Facebook Open Graph Protocol, Twitter Cards Protocol, API 등을 이용해서 마크업을 출력하고, 적당한 마크업을 얻어낼 수 없으면 Page Peeker를 이용해서 해당 페이지의 캡쳐 이미지를 사용합니다. 파일 주소, 임베드 코드 등을 직접 입력할 수도 있습니다. 유튜브처럼 웹페이지 주소를 통한 API 호출 기능, Open Graph, 임베드 코드를 모두 제공하는 경우에는 원하는 입력방식을 선택할 수 있습니다.

형식 처리
웹페이지 주소 http:로 시작하는 주소를 입력할 경우 웹페이지 주소로 처리합니다.
파일 주소 http:로 시작하는 주소에 확장자가 포함된 경우에는 파일 주소로 처리합니다.
임베드 코드 <object>, <embed>, <iframe> 태그를 임베드 코드로 처리합니다.
인용문 위 항목에 해당하지 않는 경우에는 입력된 문자열을 바로 출력합니다.
  1. 라이선스 ===========

따오기 타임라인의 고유 파일들은 MPL 2.0 라이선스를 따르며, 포함된 라이브러리 파일들은 각자의 라이선스를 따릅니다. 라이브러리 목록은 1. 설치 - 1. 요구 사항 확인 항목에서 확인할 수 있습니다.


About

Taogi Timeline: a date-based media slideshow supporting touch jestures.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 73.0%
  • PHP 17.9%
  • CSS 8.8%
  • HTML 0.3%