Menu structure của Drupal
• Menu Structure giúp người quản trị quản lý cấu
trúc giao diện, trong đó:
– Blocks: Quản lý nội dung xuất hiện trên các vùng
chính, hoặc các khối trên trang Drupal.
– Content Types: Cấu hình loại trang nội dung có thể
được tạo, cũng như loại thông tin có thể lưu trữ và
cách thông tin đó hiển thị. Quản lý các thiết lập cho
mỗi loại nội dung.
– Menus: Kiểm soát định vị và các liên kết của các menu
trên trang chính Drupal.
– Triggers: Định nghĩa các luật ràng buộc các hành động.
– Forums: tạo và quản lý diển đàn.
49 trang |
Chia sẻ: thanhle95 | Lượt xem: 483 | Lượt tải: 1
Bạn đang xem trước 20 trang tài liệu Bài giảng Phát triển phần mềm mã nguồn mở - Bài 3: Giới thiệu Drupal, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
Giới thiệu Drupal
Phát triển phần mềm mã nguồn mở
Nội dung
• Cài đặt và sử dụng module
• Tạo Estore
• Phát triển thêm
– Tạo module
– CSDL và page
– Form API
– Theme
Cài đặt Drupal
• Cài IIS và CSDL (WampServer 2.0i)
• Tạo CSDL, và admin account cho hệ thống.
• Vào thư mục C:\wamp\www\, unzip nội dung
file drupal-7.0.tar vào.
Thêm module ubercart vào Drupal
• Có module ubercart-7.x-3.0.tar
• Có các module hỗ trợ:
– ctools-7.x-1.0.tar
– entity-7.x-1.0-rc1.tar
– rules-7.x-2.1.tar
– views-7.x-3.3.tar
• Đưa tất cả các module này vào thư mục:
C:\wamp\www\drupal-7.0\sites\all\modules
Menu structure của Drupal
• Menu Structure giúp người quản trị quản lý cấu
trúc giao diện, trong đó:
– Blocks: Quản lý nội dung xuất hiện trên các vùng
chính, hoặc các khối trên trang Drupal.
– Content Types: Cấu hình loại trang nội dung có thể
được tạo, cũng như loại thông tin có thể lưu trữ và
cách thông tin đó hiển thị. Quản lý các thiết lập cho
mỗi loại nội dung.
– Menus: Kiểm soát định vị và các liên kết của các menu
trên trang chính Drupal.
– Triggers: Định nghĩa các luật ràng buộc các hành động.
– Forums: tạo và quản lý diển đàn.
2. Tạo menu EStore
• Vào menu Structure, nhấn Menus
• Nhấn Add menu, nhập EStore
• Chọn tab LIST LINKS, tạo menu item "Tất cả
sản phẩm" (path: catalog)
2. Hiển thị menu lên màn hình
• Vào menu Structure, nhấn Blocks.
• Kiếm EStore, chọn Sidebar first
• Ra trang chủ sẽ thấy menu mới
2. Tạo catalog (loại hàng)
• Vào menu Store, chọn Catalog > Catalog
• Nhấn Add term để thêm danh mục sản phẩm:
– Thuốc,
– Thực phẩm,
– Đồ điện gia dụng
2. Tạo sản phẩm
• Vào menu Content, nhấn Add contents, nhấn
Products
• Nhập tên sản phẩm, nhập hình, nhập giá cả
• Ở mục catalog, chọn danh mục cho sản phẩm
này.
2. Làm thêm
• Tạo menu item: "Thuốc" hiển thị các sản phẩm
thuốc (đường dẩn: catalog/x)
• Tạo menu item: "Đồ điện gia dụng" hiển thị
các sản phẩm điện gia dụng. (đường dẫn
catalog/x)
• Muốn biết đường dẩn thì vào menu item “Tất
cả sản phẩm”, rê chuột lên từng loại sản phẩm
để biết đường dẫn)
2. Chức năng tìm kiếm
• Vào Configuration, tìm Search settings
• Nhấn nút Reindex để tạo index
• Vào Configuration, nhấn Cron, chạy Cron.
2. Cấu hình credit card security
(xác định thư mục lưu khóa mã hóa)
• Vào store > payment method
• chọn settings của credit card
• chọn tab security settings
• nhập c:\wamp\key (tạo thư mục
c:\wamp\key), nhấn Save Configuration
Phát triển mã nguồn mở
• Nên dùng Zend Studio để viết mã PHP.
• Tham khảo các tài liệu của Drupal
3. Nguồn tài liệu tham khảo
• Các modules:
• Sách:
– Drupal 7 Professional Development
– Drupal 7 Module Development
• Tài liệu:
– User guides
– Developer guides
• API references
3. Nội dung cần đọc
• Node là gì? Comment là gì? Entity là gì?
• Drupal flow
• Drupal theme
• Drupal forms
• Module là gì? Cách cài đặt và module được
load lên như thế nào?Làm thế nào để phát
triển module mới?
3. Drupal flow
• Cách thức thông tin di
chuyển giữa các tầng
của hệ thống.
– Tiếp nhận dữ liệu
– Nơi module sống
– Block thường là kết quả
đầu ra của module hoặc
những hiển thị do ta tạo
– Cấp quyền
– Site theme
3. Vd: module myblock
• Tạo thư mục: C:\wamp\www\drupal-
7.0\sites\all\modules\custom\myblock
• Tạo file myblock.info với nội dung:
name = myblock
description = Block cua toi
package = Dai Hoc Sai Gon
core = 7.x
files[] = myblock.module
3. Vd: module myblock
• Tạo file myblock.module
<?php
/* Implements hook_block_info */
function myblock_block_info() {
$blocks['myblock'] = array(
'info' => t('Block cua toi'),
);
return $blocks;
}
/* Implements hook_block_view */
function myblock_block_view($delta) {
switch($delta){
case 'myblock':
$block['subject'] = t("Myblock subject");
$block['content'] = 'Hello, world';
break;
}
return $block;
}
3. Vd: module myblock
• Vào menu Modules, cài module myblock
• Vào menu Structures > Blocks,
cài đặt hiển thị “Block cua toi” ở Sidebarfirst
region
3. Bài tập
• Tạo module timeblock:
– Hiển thị ngày giờ hiện tại.
• Hướng dẫn:
– Phép toán nối chuổi: .
– Hàm thời gian: date('Y-m-d, H:m:s')
4. Tạo page – hook_menu
day03.module: hook_menu
function day03_menu(){
$items = array();
$items['day03/book_list'] = array(
'title' => 'Books',
'description' => "Mua sách",
'page callback' => 'page_book_list',
'access callback' => TRUE,
'type' => MENU_NORMAL_ITEM,
);
return $items;
}
4. Tạo page – page callback
day03.module: page call back
function page_book_list(){
$bookTable = array(
'header' => array('Actions', 'Tựa sách', 'Tác giả', 'Giá'),
'rows' => array());
for($i = 0; $i < 10; $i++){
$link_remove = l(
'Remove', 'day03/book_remove',
array('query' => array('bookid' => $i))
);
$bookTable['rows'][] = array(
$link_remove,
'title ' . $i,
'author ' . $i,
'price ' . $i);
}
$link_add = l('Add new book', 'day03/book_add');
return $link_add . theme('table', $bookTable);
}
4. Database - hook_schema
day03.install: hook_schema
function day03_schema() {
$schema['book_store'] = array(
'description' => 'Kho sách',
'fields' => array(
'book_id' => array(
'type' => 'serial',
'unsigned' => TRUE,
'not null' => TRUE,
'description' => "book's id",
),
'title' => array(
'type' => 'varchar',
'length' => 256,
'not null' => TRUE,
'default' => '',
'description' => "Tựa sách",
),
4. Database – executes SQL query (1)
QUERY
$result = db_query(
'SELECT book_id, title, author, price
FROM book_store
WHERE title LIKE :title
ORDER BY title',
array(':title' => '%' . $search . '%'));
foreach ($result as $record){
$bookTable['rows'][] = array(
$record->title,
$record->author,
$record->price
);
}
4. Database – executes SQL query (2)
INSERT
db_insert('book_store')
->fields(array(
'title' => 'Drupal 7 Module Development',
'author' => 'Không biết',
'price' => 5000000,
))
->execute();
4. Database – executes SQL query (2)
UPDATE
$n = db_update('book_store')
->fields(array(
'title' => 'Drupal 7 FFFF Development',
'author' => 'Không biết',
'price' => 5000000,
))
->condition('book_id', 1, '=')
->execute();
4. Database – executes SQL query
DELETE
db_delete('book_store')
->condition('book_id', 1, '=')
->execute();
4. Bài tập
• Tạo module day03 với các page sau:
– day03/book_list:
• Hiện danh sách các quyển sách mà nhà sách có
• Có các button cho phép thêm/xoá danh mục sách
– day03/book_add:
– day03/book_remove:
5. Drupal Form – Tổng quát
day04.module
drupal_get_form('add_book_form');
function add_book_form($form, &$form_state)
function add_book_form_validate($form, &$form_state);
function add_book_form_submit($form, &$form_state)
5. Drupal Form
function page_add_book(){
return
drupal_get_form('add_book_form');
}
5. Drupal Form
function add_book_form($form, &$form_state){
$form['title'] = array(
'#title' => 'Tựa sách',
'#type' => 'textfield',
'#required' => TRUE,
'#cols' => 10,
'#default_value' => 'Book title');
$form['price'] = array(
'#title' => 'Giá',
'#type' => 'textfield',
'#cols' => 6);
$form['submit'] = array(
'#type' => 'submit',
'#value' => t('Submit'),
);
return $form;
}
5. Drupal Form
function add_book_form_validate($form, &$form_state){
if (!is_numeric($form_state['values']['price'])){
form_set_error('price', 'Giá trị nhập không hợp lệ');
}
}
function add_book_form_submit($form, &$form_state){
// insert sách mới vào database
drupal_set_message('Đã add sách vào database');
// redirect về trang khác
$form_state['redirect'] = array('day03/book_list');
}
6. Tài liệu tham khảo
Hướng dẫn sử dụng ở mức user
Form API
Các hàm của drupal
Sách
Drupal 7 Professional Development
Drupal 7 Module Development
6. Sử dụng theme tường minh
• theme_table($variables)
$variables là một mảng chứa:
– Phần tử ‘header’: chứa các header của bảng
– Phần tử ‘rows’: các dòng của bảng.
• theme_item_list($variables)
$variables là một mảng chứa:
– Phần tử ‘items’: danh sách các item
– Phần tử ‘type’: loại danh sách: ‘ul’ ‘ol’.
Vd: drupal_set_message(theme('item_list',
array('items'=>array('Mot', 'Hai', 'Ba'),
'type'=>'ol')));
Sử dụng theme tường minh
• theme_link($variables)
$variable bao gồm:
– ‘text’: link text
– ‘path’: link url
Vd: l('Google', '
Theme ngầm định
Mặc dù không chỉ rõ ra, nhưng kết quả của hook_block_view sẽ được render
bởi theme_block
function hook_block_info() {
$blocks*‘example'+ = array(
'info' => ‘example block’,
'cache' => DRUPAL_NO_CACHE, );
return $blocks;
}
function hook_block_view($delta = '') {
switch ($delta) {
case ‘example':
$block*'subject'+ = ‘Vd về block’;
$block*'content'+ = ‘1 + 1 = 2’;
return $block;
}
}
Render element
• Là một mảng các mảng chứa:
– Mô tả cách render các giá trị
– Các render element con
– Đường dẫn tới các css và java script file khác.
6. Render element
Page callback:
day05_book_list(){
return array(
‘#type’ => ‘table’,
‘#header’ => array(‘col1’, ‘col2’, ‘col3’),
‘#rows’ => array(
array(‘val11’, ‘val12’, ‘val13’),
array(‘val21’, ‘val22’, ‘val23’));
}
Page callback:
day05_book_list(){
$output = array();
$output*‘form’+ = drupal_get_form(‘myform’);
$output*‘bang’+ = array(
‘#type’ => ‘table’,
‘#header’ => array(‘col1’, ‘col2’, ‘col3’),
‘#rows’ => array(
array(‘val11’, ‘val12’, ‘val13’),
array(‘val21’, ‘val22’, ‘val23’));
$output*‘htmlData’+ = array(
‘#markup’ => ‘about us’,
);
}
6. Bài tập
• Tạo các page demo các theme của drupal
– demo/theme/item_list
• Dùng drupal form tạo form gồm 5 field
– Field thứ nhất để user chọn loại danh sách: ul hoặc ol
– Các field còn lại để user điền các item cho item list.
• Và một button “Render”, khi user click render, dùng theme item_list để
render danh sách lên màn hình.
– demo/theme/link
• Dùng drupal form tạo form gồm 2 field
– Field thứ nhất chứa tên link
– Field thứ hai chứa địa chỉ url của link
• Và một button “Render”, khi user click vào button, dùng
theme link để render link lên màn hình
– demo/theme/breadcumb
• Tương tự như demo/theme/item_list
6. JQuery
• Là thư viện viết bằng java script.
• Đơn giản hoá việc thao tác HTML DOM Tree
jquery-1.5.1.min.js
jquery-ui-1.8.12.custom.min.js
6. JQuery Widgets
6. Vd về JQuery
Tạo file test.html ở ổ C:\
Tab1
Tab2
Tab3
n?i dung 1
n?i dung 2
n?i dung 3
$( "#mytabs" ).tabs()
;
6. Tạo theme
1. Info file
; $Id
name = day05
description = Học sử dụng Drupal Theme
package = Drupal 7 Learning
version = VERSION
core = 7.x
files[] = day05.module
engine = phptemplate
scripts[] = js/jquery-1.5.1.min.js
scripts[] = js/jquery-ui-1.8.12.custom.min.js
stylesheets[all][] = css/ui-lightness/jquery-ui-
1.8.12.custom.css
6. Tạo theme
2. Đăng ký theme bằng cách implement hook_theme
function day05_theme($existing, $type, $theme, $path){
return array(
'jquery_tabs' => array(
'variables' => array(
'id' => null,
'titles' => array(),
'contents' => array(),
),
),
);
}
6. Tạo theme
3. Implement theme function
function theme_jquery_tabs($variables){
$id = $variables['id'];
$titles = $variables['titles'];
$contents = $variables['contents'];
//-------------------------------------------------
// tab titles
//-------------------------------------------------
$output = '';
$output .= "";
$output .= "";
.
return $output;
}
6. Tạo theme
3. Hoặc tạo template file
6. Bài tập
• Trong JQuery-UI có phương thức dialog dùng để hiện dialog. Các sử dụng
như sau:
• Tạo theme jquery_dialog sao cho:
theme(‘jquery_dialog’, array(‘title’ => ‘Tiêu đề’, ‘content’ => ‘Nội dung’));